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