t0050: Test autodetect core.ignorecase
[alt-git.git] / t / t0050-filesystem.sh
blob66d3647bdad7a5bc0e9fb2d15bfa3909138b5501
1 #!/bin/sh
3 test_description='Various filesystem issues'
5 . ./test-lib.sh
7 auml=`printf '\xc3\xa4'`
8 aumlcdiar=`printf '\x61\xcc\x88'`
10 case_insensitive=
11 test_expect_success 'see if we expect ' '
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"
32 *) ;;
33 esac &&
34 rm -fr junk
37 if test "$case_insensitive"
38 then
39 test_expect_success "detection of case insensitive filesystem during repo init" '
41 test $(git config --bool core.ignorecase) = true
43 else
44 test_expect_success "detection of case insensitive filesystem during repo init" '
46 ! git config --bool core.ignorecase >/dev/null ||
47 test $(git config --bool core.ignorecase) = false
51 test_expect_success "setup case tests" '
53 touch camelcase &&
54 git add camelcase &&
55 git commit -m "initial" &&
56 git tag initial &&
57 git checkout -b topic &&
58 git mv camelcase tmp &&
59 git mv tmp CamelCase &&
60 git commit -m "rename" &&
61 git checkout -f master
65 $test_case 'rename (case change)' '
67 git mv camelcase CamelCase &&
68 git commit -m "rename"
72 $test_case 'merge (case change)' '
74 git reset --hard initial &&
75 git merge topic
79 test_expect_success "setup unicode normalization tests" '
81 test_create_repo unicode &&
82 cd unicode &&
83 touch "$aumlcdiar" &&
84 git add "$aumlcdiar" &&
85 git commit -m initial
86 git tag initial &&
87 git checkout -b topic &&
88 git mv $aumlcdiar tmp &&
89 git mv tmp "$auml" &&
90 git commit -m rename &&
91 git checkout -f master
95 $test_unicode 'rename (silent unicode normalization)' '
97 git mv "$aumlcdiar" "$auml" &&
98 git commit -m rename
102 $test_unicode 'merge (silent unicode normalization)' '
104 git reset --hard initial &&
105 git merge topic
109 test_done