Merge branch 'rr/triangle'
[git] / t / t0050-filesystem.sh
1 #!/bin/sh
2
3 test_description='Various filesystem issues'
4
5 . ./test-lib.sh
6
7 auml=$(printf '\303\244')
8 aumlcdiar=$(printf '\141\314\210')
9
10 if test_have_prereq CASE_INSENSITIVE_FS
11 then
12         say "will test on a case insensitive filesystem"
13         test_case=test_expect_failure
14 else
15         test_case=test_expect_success
16 fi
17
18 if test_have_prereq UTF8_NFD_TO_NFC
19 then
20         say "will test on a unicode corrupting filesystem"
21         test_unicode=test_expect_failure
22 else
23         test_unicode=test_expect_success
24 fi
25
26 test_have_prereq SYMLINKS ||
27         say "will test on a filesystem lacking symbolic links"
28
29 if test_have_prereq CASE_INSENSITIVE_FS
30 then
31 test_expect_success "detection of case insensitive filesystem during repo init" '
32         test $(git config --bool core.ignorecase) = true
33 '
34 else
35 test_expect_success "detection of case insensitive filesystem during repo init" '
36         test_must_fail git config --bool core.ignorecase >/dev/null ||
37         test $(git config --bool core.ignorecase) = false
38 '
39 fi
40
41 if test_have_prereq SYMLINKS
42 then
43 test_expect_success "detection of filesystem w/o symlink support during repo init" '
44         test_must_fail git config --bool core.symlinks ||
45         test "$(git config --bool core.symlinks)" = true
46 '
47 else
48 test_expect_success "detection of filesystem w/o symlink support during repo init" '
49         v=$(git config --bool core.symlinks) &&
50         test "$v" = false
51 '
52 fi
53
54 test_expect_success "setup case tests" '
55         git config core.ignorecase true &&
56         touch camelcase &&
57         git add camelcase &&
58         git commit -m "initial" &&
59         git tag initial &&
60         git checkout -b topic &&
61         git mv camelcase tmp &&
62         git mv tmp CamelCase &&
63         git commit -m "rename" &&
64         git checkout -f master
65 '
66
67 $test_case 'rename (case change)' '
68         git mv camelcase CamelCase &&
69         git commit -m "rename"
70 '
71
72 test_expect_success 'merge (case change)' '
73         rm -f CamelCase &&
74         rm -f camelcase &&
75         git reset --hard initial &&
76         git merge topic
77 '
78
79
80
81 test_expect_failure CASE_INSENSITIVE_FS 'add (with different case)' '
82         git reset --hard initial &&
83         rm camelcase &&
84         echo 1 >CamelCase &&
85         git add CamelCase &&
86         camel=$(git ls-files | grep -i camelcase) &&
87         test $(echo "$camel" | wc -l) = 1 &&
88         test "z$(git cat-file blob :$camel)" = z1
89 '
90
91 test_expect_success "setup unicode normalization tests" '
92         test_create_repo unicode &&
93         cd unicode &&
94         touch "$aumlcdiar" &&
95         git add "$aumlcdiar" &&
96         git commit -m initial &&
97         git tag initial &&
98         git checkout -b topic &&
99         git mv $aumlcdiar tmp &&
100         git mv tmp "$auml" &&
101         git commit -m rename &&
102         git checkout -f master
103 '
104
105 $test_unicode 'rename (silent unicode normalization)' '
106         git mv "$aumlcdiar" "$auml" &&
107         git commit -m rename
108 '
109
110 $test_unicode 'merge (silent unicode normalization)' '
111         git reset --hard initial &&
112         git merge topic
113 '
114
115 test_done