|  | #!/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 |