grep: add a test helper function for less verbose -f \0 tests
Add a helper function to make the tests which check for patterns with \0 in them more succinct. Right now this isn't a big win, but subsequent commits will add a lot more of these tests. The helper is based on the match() function in t3070-wildmatch.sh. Signed-off-by: Ævar Arnfjörð Bjarmason <avarab@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>maint
							parent
							
								
									5ee6f1a21b
								
							
						
					
					
						commit
						77f6f4406f
					
				|  | @ -4,6 +4,29 @@ test_description='git grep in binary files' | ||||||
|  |  | ||||||
| . ./test-lib.sh | . ./test-lib.sh | ||||||
|  |  | ||||||
|  | nul_match () { | ||||||
|  | 	matches=$1 | ||||||
|  | 	flags=$2 | ||||||
|  | 	pattern=$3 | ||||||
|  | 	pattern_human=$(echo "$pattern" | sed 's/Q/<NUL>/g') | ||||||
|  |  | ||||||
|  | 	if test "$matches" = 1 | ||||||
|  | 	then | ||||||
|  | 		test_expect_success "git grep -f f $flags '$pattern_human' a" " | ||||||
|  | 			printf '$pattern' | q_to_nul >f && | ||||||
|  | 			git grep -f f $flags a | ||||||
|  | 		" | ||||||
|  | 	elif test "$matches" = 0 | ||||||
|  | 	then | ||||||
|  | 		test_expect_success "git grep -f f $flags '$pattern_human' a" " | ||||||
|  | 			printf '$pattern' | q_to_nul >f && | ||||||
|  | 			test_must_fail git grep -f f $flags a | ||||||
|  | 		" | ||||||
|  | 	else | ||||||
|  | 		test_expect_success "PANIC: Test framework error. Unknown matches value $matches" 'false' | ||||||
|  | 	fi | ||||||
|  | } | ||||||
|  |  | ||||||
| test_expect_success 'setup' " | test_expect_success 'setup' " | ||||||
| 	echo 'binaryQfile' | q_to_nul >a && | 	echo 'binaryQfile' | q_to_nul >a && | ||||||
| 	git add a && | 	git add a && | ||||||
|  | @ -69,35 +92,12 @@ test_expect_failure 'git grep .fi a' ' | ||||||
| 	git grep .fi a | 	git grep .fi a | ||||||
| ' | ' | ||||||
|  |  | ||||||
| test_expect_success 'git grep -F y<NUL>f a' " | nul_match 1 '-F' 'yQf' | ||||||
| 	printf 'yQf' | q_to_nul >f && | nul_match 0 '-F' 'yQx' | ||||||
| 	git grep -f f -F a | nul_match 1 '-Fi' 'YQf' | ||||||
| " | nul_match 0 '-Fi' 'YQx' | ||||||
|  | nul_match 1 '' 'yQf' | ||||||
| test_expect_success 'git grep -F y<NUL>x a' " | nul_match 0 '' 'yQx' | ||||||
| 	printf 'yQx' | q_to_nul >f && |  | ||||||
| 	test_must_fail git grep -f f -F a |  | ||||||
| " |  | ||||||
|  |  | ||||||
| test_expect_success 'git grep -Fi Y<NUL>f a' " |  | ||||||
| 	printf 'YQf' | q_to_nul >f && |  | ||||||
| 	git grep -f f -Fi a |  | ||||||
| " |  | ||||||
|  |  | ||||||
| test_expect_success 'git grep -Fi Y<NUL>x a' " |  | ||||||
| 	printf 'YQx' | q_to_nul >f && |  | ||||||
| 	test_must_fail git grep -f f -Fi a |  | ||||||
| " |  | ||||||
|  |  | ||||||
| test_expect_success 'git grep y<NUL>f a' " |  | ||||||
| 	printf 'yQf' | q_to_nul >f && |  | ||||||
| 	git grep -f f a |  | ||||||
| " |  | ||||||
|  |  | ||||||
| test_expect_success 'git grep y<NUL>x a' " |  | ||||||
| 	printf 'yQx' | q_to_nul >f && |  | ||||||
| 	test_must_fail git grep -f f a |  | ||||||
| " |  | ||||||
|  |  | ||||||
| test_expect_success 'grep respects binary diff attribute' ' | test_expect_success 'grep respects binary diff attribute' ' | ||||||
| 	echo text >t && | 	echo text >t && | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 Ævar Arnfjörð Bjarmason
						Ævar Arnfjörð Bjarmason