 0843acfd2c
			
		
	
	0843acfd2c
	
	
	
		
			
			This has been broken in v1.6.0 due to the reorganization of the revision option parsing code. The "-i" is completely ignored, but works fine in "git log --grep -i". What happens is that the code for "-i" looks for revs->grep_filter; if it is NULL, we do nothing, since there are no grep filters. But that is obviously not correct, since we want it to influence the later --grep option. Doing it the other way around works, since "-i" just impacts the existing grep_filter option. Instead, we now always initialize the grep_filter member and just fill in options and patterns as we get them. This means that we can no longer check grep_filter for NULL, but instead must check the pattern list to see if we have any actual patterns. Signed-off-by: Jeff King <peff@peff.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
			
				
	
	
		
			98 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			98 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/sh
 | |
| 
 | |
| test_description='git log'
 | |
| 
 | |
| . ./test-lib.sh
 | |
| 
 | |
| test_expect_success setup '
 | |
| 
 | |
| 	echo one >one &&
 | |
| 	git add one &&
 | |
| 	test_tick &&
 | |
| 	git commit -m initial &&
 | |
| 
 | |
| 	echo ichi >one &&
 | |
| 	git add one &&
 | |
| 	test_tick &&
 | |
| 	git commit -m second &&
 | |
| 
 | |
| 	mkdir a &&
 | |
| 	echo ni >a/two &&
 | |
| 	git add a/two &&
 | |
| 	test_tick &&
 | |
| 	git commit -m third &&
 | |
| 
 | |
| 	echo san >a/three &&
 | |
| 	git add a/three &&
 | |
| 	test_tick &&
 | |
| 	git commit -m fourth &&
 | |
| 
 | |
| 	git rm a/three &&
 | |
| 	test_tick &&
 | |
| 	git commit -m fifth
 | |
| 
 | |
| '
 | |
| 
 | |
| test_expect_success 'diff-filter=A' '
 | |
| 
 | |
| 	actual=$(git log --pretty="format:%s" --diff-filter=A HEAD) &&
 | |
| 	expect=$(echo fourth ; echo third ; echo initial) &&
 | |
| 	test "$actual" = "$expect" || {
 | |
| 		echo Oops
 | |
| 		echo "Actual: $actual"
 | |
| 		false
 | |
| 	}
 | |
| 
 | |
| '
 | |
| 
 | |
| test_expect_success 'diff-filter=M' '
 | |
| 
 | |
| 	actual=$(git log --pretty="format:%s" --diff-filter=M HEAD) &&
 | |
| 	expect=$(echo second) &&
 | |
| 	test "$actual" = "$expect" || {
 | |
| 		echo Oops
 | |
| 		echo "Actual: $actual"
 | |
| 		false
 | |
| 	}
 | |
| 
 | |
| '
 | |
| 
 | |
| test_expect_success 'diff-filter=D' '
 | |
| 
 | |
| 	actual=$(git log --pretty="format:%s" --diff-filter=D HEAD) &&
 | |
| 	expect=$(echo fifth) &&
 | |
| 	test "$actual" = "$expect" || {
 | |
| 		echo Oops
 | |
| 		echo "Actual: $actual"
 | |
| 		false
 | |
| 	}
 | |
| 
 | |
| '
 | |
| 
 | |
| test_expect_success 'setup case sensitivity tests' '
 | |
| 	echo case >one &&
 | |
| 	test_tick &&
 | |
| 	git commit -a -m Second
 | |
| '
 | |
| 
 | |
| test_expect_success 'log --grep' '
 | |
| 	echo second >expect &&
 | |
| 	git log -1 --pretty="tformat:%s" --grep=sec >actual &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'log -i --grep' '
 | |
| 	echo Second >expect &&
 | |
| 	git log -1 --pretty="tformat:%s" -i --grep=sec >actual &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'log --grep -i' '
 | |
| 	echo Second >expect &&
 | |
| 	git log -1 --pretty="tformat:%s" --grep=sec -i >actual &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_done
 | |
| 
 |