Merge branch 'yd/doc-merge-annotated-tag' into maint
[git/jnareb-git.git] / t / t0050-filesystem.sh
blob05d78d22a6d0fa5534ae3f37cb3c289595b6c1c5
1 #!/bin/sh
3 test_description='Various filesystem issues'
5 . ./test-lib.sh
7 auml=$(printf '\303\244')
8 aumlcdiar=$(printf '\141\314\210')
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
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
26 test_have_prereq SYMLINKS ||
27 say "will test on a filesystem lacking symbolic links"
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
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
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
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
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
67 $test_case 'rename (case change)' '
68 git mv camelcase CamelCase &&
69 git commit -m "rename"
72 test_expect_success 'merge (case change)' '
73 rm -f CamelCase &&
74 rm -f camelcase &&
75 git reset --hard initial &&
76 git merge topic
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
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
105 $test_unicode 'rename (silent unicode normalization)' '
106 git mv "$aumlcdiar" "$auml" &&
107 git commit -m rename
110 $test_unicode 'merge (silent unicode normalization)' '
111 git reset --hard initial &&
112 git merge topic
115 test_done