 c4c2a96ec7
			
		
	
	c4c2a96ec7
	
	
	
		
			
			7187c7bbb8(t4210: skip i18n tests that don't work on FreeBSD, 2019-11-27) adds a REG_ILLSEQ prerequisite, and to do that copies the common branch in test-lib and expands it to include it in a special case for FreeBSD. Instead; test for it using a previously added extension to test-tool and use that, together with a function that identifies when regcomp/regexec will be called with broken patterns to avoid any test that would otherwise rely on undefined behaviour. The description of the first test which wasn't accurate has been corrected, and the test rearranged for clarity, including a helper function that avoids overly long lines. Only the affected engines will have their tests suppressed, also including "fixed" if the PCRE optimization that uses LIBPCRE2 sinceb65abcafc7(grep: use PCRE v2 for optimized fixed-string search, 2019-07-01) is not available. Helped-by: Eric Sunshine <sunshine@sunshineco.com> Signed-off-by: Carlo Marcelo Arenas Belón <carenas@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
			
				
	
	
		
			135 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			135 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/sh
 | |
| 
 | |
| test_description='test log with i18n features'
 | |
| . ./lib-gettext.sh
 | |
| 
 | |
| # two forms of é
 | |
| utf8_e=$(printf '\303\251')
 | |
| latin1_e=$(printf '\351')
 | |
| 
 | |
| # invalid UTF-8
 | |
| invalid_e=$(printf '\303\50)') # ")" at end to close opening "("
 | |
| 
 | |
| have_reg_illseq=
 | |
| if test_have_prereq GETTEXT_LOCALE &&
 | |
| 	! LC_ALL=$is_IS_locale test-tool regex --silent $latin1_e
 | |
| then
 | |
| 	have_reg_illseq=1
 | |
| fi
 | |
| 
 | |
| test_expect_success 'create commits in different encodings' '
 | |
| 	test_tick &&
 | |
| 	cat >msg <<-EOF &&
 | |
| 	utf8
 | |
| 
 | |
| 	t${utf8_e}st
 | |
| 	EOF
 | |
| 	git add msg &&
 | |
| 	git -c i18n.commitencoding=utf8 commit -F msg &&
 | |
| 	cat >msg <<-EOF &&
 | |
| 	latin1
 | |
| 
 | |
| 	t${latin1_e}st
 | |
| 	EOF
 | |
| 	git add msg &&
 | |
| 	git -c i18n.commitencoding=ISO-8859-1 commit -F msg
 | |
| '
 | |
| 
 | |
| test_expect_success 'log --grep searches in log output encoding (utf8)' '
 | |
| 	cat >expect <<-\EOF &&
 | |
| 	latin1
 | |
| 	utf8
 | |
| 	EOF
 | |
| 	git log --encoding=utf8 --format=%s --grep=$utf8_e >actual &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_expect_success !MINGW 'log --grep searches in log output encoding (latin1)' '
 | |
| 	cat >expect <<-\EOF &&
 | |
| 	latin1
 | |
| 	utf8
 | |
| 	EOF
 | |
| 	git log --encoding=ISO-8859-1 --format=%s --grep=$latin1_e >actual &&
 | |
| 	test_cmp expect actual
 | |
| '
 | |
| 
 | |
| test_expect_success !MINGW 'log --grep does not find non-reencoded values (utf8)' '
 | |
| 	git log --encoding=utf8 --format=%s --grep=$latin1_e >actual &&
 | |
| 	test_must_be_empty actual
 | |
| '
 | |
| 
 | |
| test_expect_success 'log --grep does not find non-reencoded values (latin1)' '
 | |
| 	git log --encoding=ISO-8859-1 --format=%s --grep=$utf8_e >actual &&
 | |
| 	test_must_be_empty actual
 | |
| '
 | |
| 
 | |
| triggers_undefined_behaviour () {
 | |
| 	local engine=$1
 | |
| 
 | |
| 	case $engine in
 | |
| 	fixed)
 | |
| 		if test -n "$have_reg_illseq" &&
 | |
| 			! test_have_prereq LIBPCRE2
 | |
| 		then
 | |
| 			return 0
 | |
| 		fi
 | |
| 		;;
 | |
| 	basic|extended)
 | |
| 		if test -n "$have_reg_illseq"
 | |
| 		then
 | |
| 			return 0
 | |
| 		fi
 | |
| 		;;
 | |
| 	esac
 | |
| 	return 1
 | |
| }
 | |
| 
 | |
| mismatched_git_log () {
 | |
| 	local pattern=$1
 | |
| 
 | |
| 	LC_ALL=$is_IS_locale git log --encoding=ISO-8859-1 --format=%s \
 | |
| 		--grep=$pattern
 | |
| }
 | |
| 
 | |
| for engine in fixed basic extended perl
 | |
| do
 | |
| 	prereq=
 | |
| 	if test $engine = "perl"
 | |
| 	then
 | |
| 		prereq=PCRE
 | |
| 	fi
 | |
| 	force_regex=
 | |
| 	if test $engine != "fixed"
 | |
| 	then
 | |
| 		force_regex='.*'
 | |
| 	fi
 | |
| 
 | |
| 	test_expect_success $prereq "config grep.patternType=$engine" "
 | |
| 		git config grep.patternType $engine
 | |
| 	"
 | |
| 
 | |
| 	test_expect_success GETTEXT_LOCALE,$prereq "log --grep does not find non-reencoded values (latin1 + locale)" "
 | |
| 		mismatched_git_log '$force_regex$utf8_e' >actual &&
 | |
| 		test_must_be_empty actual
 | |
| 	"
 | |
| 
 | |
| 	if ! triggers_undefined_behaviour $engine
 | |
| 	then
 | |
| 		test_expect_success !MINGW,GETTEXT_LOCALE,$prereq "log --grep searches in log output encoding (latin1 + locale)" "
 | |
| 			cat >expect <<-\EOF &&
 | |
| 			latin1
 | |
| 			utf8
 | |
| 			EOF
 | |
| 			mismatched_git_log '$force_regex$latin1_e' >actual &&
 | |
| 			test_cmp expect actual
 | |
| 		"
 | |
| 
 | |
| 		test_expect_success GETTEXT_LOCALE,$prereq "log --grep does not die on invalid UTF-8 value (latin1 + locale + invalid needle)" "
 | |
| 			mismatched_git_log '$force_regex$invalid_e' >actual &&
 | |
| 			test_must_be_empty actual
 | |
| 		"
 | |
| 	fi
 | |
| done
 | |
| 
 | |
| test_done
 |