diff options
Diffstat (limited to 't/annotate-tests.sh')
| -rw-r--r-- | t/annotate-tests.sh | 39 | 
1 files changed, 25 insertions, 14 deletions
| diff --git a/t/annotate-tests.sh b/t/annotate-tests.sh index 396b9653a3..c56a77d237 100644 --- a/t/annotate-tests.sh +++ b/t/annotate-tests.sh @@ -1,5 +1,5 @@  # This file isn't used as a test script directly, instead it is -# sourced from t8001-annotate.sh and t8001-blame.sh. +# sourced from t8001-annotate.sh and t8002-blame.sh.  check_count () {  	head= @@ -8,27 +8,27 @@ check_count () {  	$PROG file $head >.result || return 1  	cat .result | perl -e '  		my %expect = (@ARGV); -		my %count = (); +		my %count = map { $_ => 0 } keys %expect;  		while (<STDIN>) {  			if (/^[0-9a-f]+\t\(([^\t]+)\t/) {  				my $author = $1;  				for ($author) { s/^\s*//; s/\s*$//; } -				if (exists $expect{$author}) { -					$count{$author}++; -				} +				$count{$author}++;  			}  		}  		my $bad = 0;  		while (my ($author, $count) = each %count) {  			my $ok; -			if ($expect{$author} != $count) { +			my $value = 0; +			$value = $expect{$author} if defined $expect{$author}; +			if ($value != $count) {  				$bad = 1;  				$ok = "bad";  			}  			else {  				$ok = "good";  			} -			print STDERR "Author $author (expected $expect{$author}, attributed $count) $ok\n"; +			print STDERR "Author $author (expected $value, attributed $count) $ok\n";  		}  		exit($bad);  	' "$@" @@ -38,8 +38,8 @@ test_expect_success \      'prepare reference tree' \      'echo "1A quick brown fox jumps over the" >file &&       echo "lazy dog" >>file && -     git add file -     GIT_AUTHOR_NAME="A" git commit -a -m "Initial."' +     git add file && +     GIT_AUTHOR_NAME="A" GIT_AUTHOR_EMAIL="A@test.git" git commit -a -m "Initial."'  test_expect_success \      'check all lines blamed on A' \ @@ -49,7 +49,7 @@ test_expect_success \      'Setup new lines blamed on B' \      'echo "2A quick brown fox jumps over the" >>file &&       echo "lazy dog" >> file && -     GIT_AUTHOR_NAME="B" git commit -a -m "Second."' +     GIT_AUTHOR_NAME="B" GIT_AUTHOR_EMAIL="B@test.git" git commit -a -m "Second."'  test_expect_success \      'Two lines blamed on A, two on B' \ @@ -60,7 +60,7 @@ test_expect_success \      'git checkout -b branch1 master &&       echo "3A slow green fox jumps into the" >> file &&       echo "well." >> file && -     GIT_AUTHOR_NAME="B1" git commit -a -m "Branch1-1"' +     GIT_AUTHOR_NAME="B1" GIT_AUTHOR_EMAIL="B1@test.git" git commit -a -m "Branch1-1"'  test_expect_success \      'Two lines blamed on A, two on B, two on B1' \ @@ -71,7 +71,7 @@ test_expect_success \      'git checkout -b branch2 master &&       sed -e "s/2A quick brown/4A quick brown lazy dog/" < file > file.new &&       mv file.new file && -     GIT_AUTHOR_NAME="B2" git commit -a -m "Branch2-1"' +     GIT_AUTHOR_NAME="B2" GIT_AUTHOR_EMAIL="B2@test.git" git commit -a -m "Branch2-1"'  test_expect_success \      'Two lines blamed on A, one on B, one on B2' \ @@ -105,7 +105,7 @@ test_expect_success \  test_expect_success \      'an incomplete line added' \      'echo "incomplete" | tr -d "\\012" >>file && -    GIT_AUTHOR_NAME="C" git commit -a -m "Incomplete"' +    GIT_AUTHOR_NAME="C" GIT_AUTHOR_EMAIL="C@test.git" git commit -a -m "Incomplete"'  test_expect_success \      'With incomplete lines.' \ @@ -119,8 +119,19 @@ test_expect_success \  	echo      } | sed -e "s/^3A/99/" -e "/^1A/d" -e "/^incomplete/d" > file &&      echo "incomplete" | tr -d "\\012" >>file && -    GIT_AUTHOR_NAME="D" git commit -a -m "edit"' +    GIT_AUTHOR_NAME="D" GIT_AUTHOR_EMAIL="D@test.git" git commit -a -m "edit"'  test_expect_success \      'some edit' \      'check_count A 1 B 1 B1 1 B2 1 "A U Thor" 1 C 1 D 1' + +test_expect_success \ +    'an obfuscated email added' \ +    'echo "No robots allowed" > file.new && +     cat file >> file.new && +     mv file.new file && +     GIT_AUTHOR_NAME="E" GIT_AUTHOR_EMAIL="E at test dot git" git commit -a -m "norobots"' + +test_expect_success \ +    'obfuscated email parsed' \ +    'check_count A 1 B 1 B1 1 B2 1 "A U Thor" 1 C 1 D 1 E 1' | 
