 0ba9c9a0fb
			
		
	
	0ba9c9a0fb
	
	
	
		
			
			Remove hard coded sha1 values, obtain the values using 'git rev-parse HEAD' which should be future proof regardless of the hash function used. Additionally future-proof the test by hard coding the abbreviation length of the hash. Signed-off-by: Stefan Beller <sbeller@google.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
			
				
	
	
		
			110 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			110 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/sh
 | |
| 
 | |
| test_description='blame output in various formats on a simple case'
 | |
| . ./test-lib.sh
 | |
| 
 | |
| test_expect_success 'setup' '
 | |
| 	echo a >file &&
 | |
| 	git add file &&
 | |
| 	test_tick &&
 | |
| 	git commit -m one &&
 | |
| 	echo b >>file &&
 | |
| 	echo c >>file &&
 | |
| 	echo d >>file &&
 | |
| 	test_tick &&
 | |
| 	git commit -a -m two &&
 | |
| 	ID1=$(git rev-parse HEAD^) &&
 | |
| 	shortID1="^$(git rev-parse HEAD^ |cut -c 1-17)" &&
 | |
| 	ID2=$(git rev-parse HEAD) &&
 | |
| 	shortID2="$(git rev-parse HEAD |cut -c 1-18)"
 | |
| '
 | |
| 
 | |
| cat >expect <<EOF
 | |
| $shortID1 (A U Thor 2005-04-07 15:13:13 -0700 1) a
 | |
| $shortID2 (A U Thor 2005-04-07 15:14:13 -0700 2) b
 | |
| $shortID2 (A U Thor 2005-04-07 15:14:13 -0700 3) c
 | |
| $shortID2 (A U Thor 2005-04-07 15:14:13 -0700 4) d
 | |
| EOF
 | |
| test_expect_success 'normal blame output' '
 | |
| 	git blame --abbrev=17 file >actual &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| COMMIT1="author A U Thor
 | |
| author-mail <author@example.com>
 | |
| author-time 1112911993
 | |
| author-tz -0700
 | |
| committer C O Mitter
 | |
| committer-mail <committer@example.com>
 | |
| committer-time 1112911993
 | |
| committer-tz -0700
 | |
| summary one
 | |
| boundary
 | |
| filename file"
 | |
| COMMIT2="author A U Thor
 | |
| author-mail <author@example.com>
 | |
| author-time 1112912053
 | |
| author-tz -0700
 | |
| committer C O Mitter
 | |
| committer-mail <committer@example.com>
 | |
| committer-time 1112912053
 | |
| committer-tz -0700
 | |
| summary two
 | |
| previous $ID1 file
 | |
| filename file"
 | |
| 
 | |
| cat >expect <<EOF
 | |
| $ID1 1 1 1
 | |
| $COMMIT1
 | |
| 	a
 | |
| $ID2 2 2 3
 | |
| $COMMIT2
 | |
| 	b
 | |
| $ID2 3 3
 | |
| 	c
 | |
| $ID2 4 4
 | |
| 	d
 | |
| EOF
 | |
| test_expect_success 'blame --porcelain output' '
 | |
| 	git blame --porcelain file >actual &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| cat >expect <<EOF
 | |
| $ID1 1 1 1
 | |
| $COMMIT1
 | |
| 	a
 | |
| $ID2 2 2 3
 | |
| $COMMIT2
 | |
| 	b
 | |
| $ID2 3 3
 | |
| $COMMIT2
 | |
| 	c
 | |
| $ID2 4 4
 | |
| $COMMIT2
 | |
| 	d
 | |
| EOF
 | |
| test_expect_success 'blame --line-porcelain output' '
 | |
| 	git blame --line-porcelain file >actual &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_expect_success '--porcelain detects first non-blank line as subject' '
 | |
| 	(
 | |
| 		GIT_INDEX_FILE=.git/tmp-index &&
 | |
| 		export GIT_INDEX_FILE &&
 | |
| 		echo "This is it" >single-file &&
 | |
| 		git add single-file &&
 | |
| 		tree=$(git write-tree) &&
 | |
| 		commit=$(printf "%s\n%s\n%s\n\n\n  \noneline\n\nbody\n" \
 | |
| 			"tree $tree" \
 | |
| 			"author A <a@b.c> 123456789 +0000" \
 | |
| 			"committer C <c@d.e> 123456789 +0000" |
 | |
| 		git hash-object -w -t commit --stdin) &&
 | |
| 		git blame --porcelain $commit -- single-file >output &&
 | |
| 		grep "^summary oneline$" output
 | |
| 	)
 | |
| '
 | |
| 
 | |
| test_done
 |