Merge branch 'maint'
[git] / t / t3902-quoted.sh
1 #!/bin/sh
2 #
3 # Copyright (c) 2006 Junio C Hamano
4 #
5
6 test_description='quoted output'
7
8 . ./test-lib.sh
9
10 FN='濱野'
11 GN='純'
12 HT='    '
13 LF='
14 '
15 DQ='"'
16
17 echo foo 2>/dev/null > "Name and an${HT}HT"
18 if ! test -f "Name and an${HT}HT"
19 then
20         # FAT/NTFS does not allow tabs in filenames
21         say 'Your filesystem does not allow tabs in filenames'
22 else
23         test_set_prereq TABS_IN_FILENAMES
24 fi
25
26 for_each_name () {
27         for name in \
28             Name "Name and a${LF}LF" "Name and an${HT}HT" "Name${DQ}" \
29             "$FN$HT$GN" "$FN$LF$GN" "$FN $GN" "$FN$GN" "$FN$DQ$GN" \
30             "With SP in it" "$FN/file"
31         do
32                 eval "$1"
33         done
34 }
35
36 test_expect_success TABS_IN_FILENAMES 'setup' '
37
38         mkdir "$FN" &&
39         for_each_name "echo initial >\"\$name\"" &&
40         git add . &&
41         git commit -q -m Initial &&
42
43         for_each_name "echo second >\"\$name\"" &&
44         git commit -a -m Second &&
45
46         for_each_name "echo modified >\"\$name\""
47
48 '
49
50 test_expect_success TABS_IN_FILENAMES 'setup expected files' '
51 cat >expect.quoted <<\EOF &&
52 Name
53 "Name and a\nLF"
54 "Name and an\tHT"
55 "Name\""
56 With SP in it
57 "\346\277\261\351\207\216\t\347\264\224"
58 "\346\277\261\351\207\216\n\347\264\224"
59 "\346\277\261\351\207\216 \347\264\224"
60 "\346\277\261\351\207\216\"\347\264\224"
61 "\346\277\261\351\207\216/file"
62 "\346\277\261\351\207\216\347\264\224"
63 EOF
64
65 cat >expect.raw <<\EOF
66 Name
67 "Name and a\nLF"
68 "Name and an\tHT"
69 "Name\""
70 With SP in it
71 "濱野\t純"
72 "濱野\n純"
73 濱野 純
74 "濱野\"純"
75 濱野/file
76 濱野純
77 EOF
78 '
79
80 test_expect_success TABS_IN_FILENAMES 'check fully quoted output from ls-files' '
81
82         git ls-files >current && test_cmp expect.quoted current
83
84 '
85
86 test_expect_success TABS_IN_FILENAMES 'check fully quoted output from diff-files' '
87
88         git diff --name-only >current &&
89         test_cmp expect.quoted current
90
91 '
92
93 test_expect_success TABS_IN_FILENAMES 'check fully quoted output from diff-index' '
94
95         git diff --name-only HEAD >current &&
96         test_cmp expect.quoted current
97
98 '
99
100 test_expect_success TABS_IN_FILENAMES 'check fully quoted output from diff-tree' '
101
102         git diff --name-only HEAD^ HEAD >current &&
103         test_cmp expect.quoted current
104
105 '
106
107 test_expect_success TABS_IN_FILENAMES 'check fully quoted output from ls-tree' '
108
109         git ls-tree --name-only -r HEAD >current &&
110         test_cmp expect.quoted current
111
112 '
113
114 test_expect_success TABS_IN_FILENAMES 'setting core.quotepath' '
115
116         git config --bool core.quotepath false
117
118 '
119
120 test_expect_success TABS_IN_FILENAMES 'check fully quoted output from ls-files' '
121
122         git ls-files >current && test_cmp expect.raw current
123
124 '
125
126 test_expect_success TABS_IN_FILENAMES 'check fully quoted output from diff-files' '
127
128         git diff --name-only >current &&
129         test_cmp expect.raw current
130
131 '
132
133 test_expect_success TABS_IN_FILENAMES 'check fully quoted output from diff-index' '
134
135         git diff --name-only HEAD >current &&
136         test_cmp expect.raw current
137
138 '
139
140 test_expect_success TABS_IN_FILENAMES 'check fully quoted output from diff-tree' '
141
142         git diff --name-only HEAD^ HEAD >current &&
143         test_cmp expect.raw current
144
145 '
146
147 test_expect_success TABS_IN_FILENAMES 'check fully quoted output from ls-tree' '
148
149         git ls-tree --name-only -r HEAD >current &&
150         test_cmp expect.raw current
151
152 '
153
154 test_done