Merge branch 'jc/rerere'
[git] / t / t0050-filesystem.sh
1 #!/bin/sh
2
3 test_description='Various filesystem issues'
4
5 . ./test-lib.sh
6
7 auml=`printf '\xc3\xa4'`
8 aumlcdiar=`printf '\x61\xcc\x88'`
9
10 case_insensitive=
11 test_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
37 if test "$case_insensitive"
38 then
39 test_expect_success "detection of case insensitive filesystem during repo init" '
40
41         test $(git config --bool core.ignorecase) = true
42 '
43 else
44 test_expect_success "detection of case insensitive filesystem during repo init" '
45
46         ! git config --bool core.ignorecase >/dev/null ||
47         test $(git config --bool core.ignorecase) = false
48 '
49 fi
50
51 test_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
92 test_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
122 test_done