1#!/bin/sh
2
3test_description='Various filesystem issues'
4
5. ./test-lib.sh
6
7auml=`printf '\xc3\xa4'`
8aumlcdiar=`printf '\x61\xcc\x88'`
9
10case_insensitive=
11test_expect_success 'see if we expect ' '
12
13 test_case=test_expect_success
14 test_unicode=test_expect_success
15 mkdir junk &&
16 echo good >junk/CamelCase &&
17 echo bad >junk/camelcase &&
18 if test "$(cat junk/CamelCase)" != good
19 then
20 test_case=test_expect_failure
21 case_insensitive=t
22 say "will test on a case insensitive filesystem"
23 fi &&
24 rm -fr junk &&
25 mkdir junk &&
26 >junk/"$auml" &&
27 case "$(cd junk && echo *)" in
28 "$aumlcdiar")
29 test_unicode=test_expect_failure
30 say "will test on a unicode corrupting filesystem"
31 ;;
32 *) ;;
33 esac &&
34 rm -fr junk
35'
36
37if test "$case_insensitive"
38then
39test_expect_success "detection of case insensitive filesystem during repo init" '
40
41 test $(git config --bool core.ignorecase) = true
42'
43else
44test_expect_success "detection of case insensitive filesystem during repo init" '
45
46 test_must_fail git config --bool core.ignorecase >/dev/null ||
47 test $(git config --bool core.ignorecase) = false
48'
49fi
50
51test_expect_success "setup case tests" '
52
53 git config core.ignorecase true &&
54 touch camelcase &&
55 git add camelcase &&
56 git commit -m "initial" &&
57 git tag initial &&
58 git checkout -b topic &&
59 git mv camelcase tmp &&
60 git mv tmp CamelCase &&
61 git commit -m "rename" &&
62 git checkout -f master
63
64'
65
66$test_case 'rename (case change)' '
67
68 git mv camelcase CamelCase &&
69 git commit -m "rename"
70
71'
72
73$test_case 'merge (case change)' '
74
75 rm -f CamelCase &&
76 rm -f camelcase &&
77 git reset --hard initial &&
78 git merge topic
79
80'
81
82$test_case 'add (with different case)' '
83
84 git reset --hard initial &&
85 rm camelcase &&
86 echo 1 >CamelCase &&
87 git add CamelCase &&
88 test $(git ls-files | grep -i camelcase | wc -l) = 1
89
90'
91
92test_expect_success "setup unicode normalization tests" '
93
94 test_create_repo unicode &&
95 cd unicode &&
96 touch "$aumlcdiar" &&
97 git add "$aumlcdiar" &&
98 git commit -m initial
99 git tag initial &&
100 git checkout -b topic &&
101 git mv $aumlcdiar tmp &&
102 git mv tmp "$auml" &&
103 git commit -m rename &&
104 git checkout -f master
105
106'
107
108$test_unicode 'rename (silent unicode normalization)' '
109
110 git mv "$aumlcdiar" "$auml" &&
111 git commit -m rename
112
113'
114
115$test_unicode 'merge (silent unicode normalization)' '
116
117 git reset --hard initial &&
118 git merge topic
119
120'
121
122test_done