]>
Commit | Line | Data |
---|---|---|
d2c11a38 JH |
1 | #!/bin/sh |
2 | # | |
3 | # Copyright (c) 2006 Junio C Hamano | |
4 | # | |
5 | ||
6 | test_description='commit and log output encodings' | |
7 | ||
8 | . ./test-lib.sh | |
9 | ||
10 | compare_with () { | |
304b5af6 | 11 | git show -s $1 | sed -e '1,/^$/d' -e 's/^ //' >current && |
eb127887 JH |
12 | case "$3" in |
13 | '') | |
14 | test_cmp "$2" current ;; | |
15 | ?*) | |
39d404d1 AR |
16 | iconv -f "$3" -t UTF-8 >current.utf8 <current && |
17 | iconv -f "$3" -t UTF-8 >expect.utf8 <"$2" && | |
eb127887 JH |
18 | test_cmp expect.utf8 current.utf8 |
19 | ;; | |
20 | esac | |
d2c11a38 JH |
21 | } |
22 | ||
23 | test_expect_success setup ' | |
24 | : >F && | |
5be60078 JH |
25 | git add F && |
26 | T=$(git write-tree) && | |
bfdbee98 | 27 | C=$(git commit-tree $T <"$TEST_DIRECTORY"/t3900/1-UTF-8.txt) && |
5be60078 | 28 | git update-ref HEAD $C && |
0cb0e143 | 29 | git tag C0 |
d2c11a38 JH |
30 | ' |
31 | ||
32 | test_expect_success 'no encoding header for base case' ' | |
5be60078 | 33 | E=$(git cat-file commit C0 | sed -ne "s/^encoding //p") && |
d2c11a38 JH |
34 | test z = "z$E" |
35 | ' | |
36 | ||
0ed45a1c | 37 | test_expect_success 'UTF-16 refused because of NULs' ' |
37576c14 | 38 | echo UTF-16 >F && |
0ed45a1c | 39 | test_must_fail git commit -a -F "$TEST_DIRECTORY"/t3900/UTF-16.txt |
37576c14 NTND |
40 | ' |
41 | ||
28110d4b | 42 | test_expect_success 'UTF-8 invalid characters refused' ' |
36a6f49c | 43 | test_when_finished "rm -f \"\$HOME/stderr\" \"\$HOME/invalid\"" && |
28110d4b | 44 | echo "UTF-8 characters" >F && |
45 | printf "Commit message\n\nInvalid surrogate:\355\240\200\n" \ | |
46 | >"$HOME/invalid" && | |
47 | git commit -a -F "$HOME/invalid" 2>"$HOME"/stderr && | |
4fa4b315 | 48 | test_i18ngrep "did not conform" "$HOME"/stderr |
e82bd6cc | 49 | ' |
50 | ||
51 | test_expect_success 'UTF-8 overlong sequences rejected' ' | |
36a6f49c | 52 | test_when_finished "rm -f \"\$HOME/stderr\" \"\$HOME/invalid\"" && |
e82bd6cc | 53 | rm -f "$HOME/stderr" "$HOME/invalid" && |
54 | echo "UTF-8 overlong" >F && | |
55 | printf "\340\202\251ommit message\n\nThis is not a space:\300\240\n" \ | |
56 | >"$HOME/invalid" && | |
57 | git commit -a -F "$HOME/invalid" 2>"$HOME"/stderr && | |
4fa4b315 | 58 | test_i18ngrep "did not conform" "$HOME"/stderr |
81050ac6 PK |
59 | ' |
60 | ||
61 | test_expect_success 'UTF-8 non-characters refused' ' | |
36a6f49c | 62 | test_when_finished "rm -f \"\$HOME/stderr\" \"\$HOME/invalid\"" && |
81050ac6 PK |
63 | echo "UTF-8 non-character 1" >F && |
64 | printf "Commit message\n\nNon-character:\364\217\277\276\n" \ | |
65 | >"$HOME/invalid" && | |
66 | git commit -a -F "$HOME/invalid" 2>"$HOME"/stderr && | |
4fa4b315 | 67 | test_i18ngrep "did not conform" "$HOME"/stderr |
81050ac6 PK |
68 | ' |
69 | ||
70 | test_expect_success 'UTF-8 non-characters refused' ' | |
36a6f49c | 71 | test_when_finished "rm -f \"\$HOME/stderr\" \"\$HOME/invalid\"" && |
81050ac6 PK |
72 | echo "UTF-8 non-character 2." >F && |
73 | printf "Commit message\n\nNon-character:\357\267\220\n" \ | |
74 | >"$HOME/invalid" && | |
75 | git commit -a -F "$HOME/invalid" 2>"$HOME"/stderr && | |
4fa4b315 | 76 | test_i18ngrep "did not conform" "$HOME"/stderr |
28110d4b | 77 | ' |
37576c14 | 78 | |
5ae93dfd | 79 | for H in ISO8859-1 eucJP ISO-2022-JP |
d2c11a38 JH |
80 | do |
81 | test_expect_success "$H setup" ' | |
5be60078 | 82 | git config i18n.commitencoding $H && |
0cb0e143 | 83 | git checkout -b $H C0 && |
d2c11a38 | 84 | echo $H >F && |
9b8ae93a | 85 | git commit -a -F "$TEST_DIRECTORY"/t3900/$H.txt |
d2c11a38 JH |
86 | ' |
87 | done | |
88 | ||
5ae93dfd | 89 | for H in ISO8859-1 eucJP ISO-2022-JP |
d2c11a38 JH |
90 | do |
91 | test_expect_success "check encoding header for $H" ' | |
5be60078 | 92 | E=$(git cat-file commit '$H' | sed -ne "s/^encoding //p") && |
d2c11a38 JH |
93 | test "z$E" = "z'$H'" |
94 | ' | |
95 | done | |
96 | ||
e0d10e1c | 97 | test_expect_success 'config to remove customization' ' |
5be60078 JH |
98 | git config --unset-all i18n.commitencoding && |
99 | if Z=$(git config --get-all i18n.commitencoding) | |
d2c11a38 JH |
100 | then |
101 | echo Oops, should have failed. | |
102 | false | |
103 | else | |
104 | test z = "z$Z" | |
105 | fi && | |
5ae93dfd | 106 | git config i18n.commitencoding UTF-8 |
d2c11a38 JH |
107 | ' |
108 | ||
5ae93dfd BC |
109 | test_expect_success 'ISO8859-1 should be shown in UTF-8 now' ' |
110 | compare_with ISO8859-1 "$TEST_DIRECTORY"/t3900/1-UTF-8.txt | |
d2c11a38 JH |
111 | ' |
112 | ||
5ae93dfd | 113 | for H in eucJP ISO-2022-JP |
d2c11a38 JH |
114 | do |
115 | test_expect_success "$H should be shown in UTF-8 now" ' | |
bfdbee98 | 116 | compare_with '$H' "$TEST_DIRECTORY"/t3900/2-UTF-8.txt |
d2c11a38 JH |
117 | ' |
118 | done | |
119 | ||
e0d10e1c | 120 | test_expect_success 'config to add customization' ' |
5be60078 JH |
121 | git config --unset-all i18n.commitencoding && |
122 | if Z=$(git config --get-all i18n.commitencoding) | |
d2c11a38 JH |
123 | then |
124 | echo Oops, should have failed. | |
125 | false | |
126 | else | |
127 | test z = "z$Z" | |
128 | fi | |
129 | ' | |
130 | ||
5ae93dfd | 131 | for H in ISO8859-1 eucJP ISO-2022-JP |
d2c11a38 JH |
132 | do |
133 | test_expect_success "$H should be shown in itself now" ' | |
5be60078 | 134 | git config i18n.commitencoding '$H' && |
bfdbee98 | 135 | compare_with '$H' "$TEST_DIRECTORY"/t3900/'$H'.txt |
d2c11a38 JH |
136 | ' |
137 | done | |
138 | ||
e0d10e1c | 139 | test_expect_success 'config to tweak customization' ' |
5ae93dfd | 140 | git config i18n.logoutputencoding UTF-8 |
d2c11a38 JH |
141 | ' |
142 | ||
5ae93dfd BC |
143 | test_expect_success 'ISO8859-1 should be shown in UTF-8 now' ' |
144 | compare_with ISO8859-1 "$TEST_DIRECTORY"/t3900/1-UTF-8.txt | |
d2c11a38 JH |
145 | ' |
146 | ||
5ae93dfd | 147 | for H in eucJP ISO-2022-JP |
d2c11a38 JH |
148 | do |
149 | test_expect_success "$H should be shown in UTF-8 now" ' | |
bfdbee98 | 150 | compare_with '$H' "$TEST_DIRECTORY"/t3900/2-UTF-8.txt |
d2c11a38 JH |
151 | ' |
152 | done | |
153 | ||
5ae93dfd | 154 | for J in eucJP ISO-2022-JP |
7255ff04 | 155 | do |
eb127887 JH |
156 | if test "$J" = ISO-2022-JP |
157 | then | |
158 | ICONV=$J | |
159 | else | |
160 | ICONV= | |
161 | fi | |
5be60078 | 162 | git config i18n.logoutputencoding $J |
5ae93dfd | 163 | for H in eucJP ISO-2022-JP |
7255ff04 JH |
164 | do |
165 | test_expect_success "$H should be shown in $J now" ' | |
eb127887 | 166 | compare_with '$H' "$TEST_DIRECTORY"/t3900/'$J'.txt $ICONV |
7255ff04 JH |
167 | ' |
168 | done | |
169 | done | |
170 | ||
5ae93dfd | 171 | for H in ISO8859-1 eucJP ISO-2022-JP |
00079283 JH |
172 | do |
173 | test_expect_success "No conversion with $H" ' | |
bfdbee98 | 174 | compare_with "--encoding=none '$H'" "$TEST_DIRECTORY"/t3900/'$H'.txt |
00079283 JH |
175 | ' |
176 | done | |
177 | ||
b1a6c0a9 PN |
178 | test_commit_autosquash_flags () { |
179 | H=$1 | |
180 | flag=$2 | |
181 | test_expect_success "commit --$flag with $H encoding" ' | |
182 | git config i18n.commitencoding $H && | |
183 | git checkout -b $H-$flag C0 && | |
184 | echo $H >>F && | |
185 | git commit -a -F "$TEST_DIRECTORY"/t3900/$H.txt && | |
186 | test_tick && | |
187 | echo intermediate stuff >>G && | |
188 | git add G && | |
189 | git commit -a -m "intermediate commit" && | |
190 | test_tick && | |
191 | echo $H $flag >>F && | |
23ce5c39 | 192 | git commit -a --$flag HEAD~1 && |
b1a6c0a9 PN |
193 | E=$(git cat-file commit '$H-$flag' | |
194 | sed -ne "s/^encoding //p") && | |
195 | test "z$E" = "z$H" && | |
196 | git config --unset-all i18n.commitencoding && | |
197 | git rebase --autosquash -i HEAD^^^ && | |
198 | git log --oneline >actual && | |
3fb0459b | 199 | test_line_count = 3 actual |
b1a6c0a9 PN |
200 | ' |
201 | } | |
202 | ||
203 | test_commit_autosquash_flags eucJP fixup | |
204 | ||
23ce5c39 | 205 | test_commit_autosquash_flags ISO-2022-JP squash |
7951bd30 | 206 | |
d2c11a38 | 207 | test_done |