Merge branch 'jk/common-main'
[git/git-svn.git] / t / t0050-filesystem.sh
blobb29d749bb7b33406b2d433d96c35d252e305eed0
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" '
37 test_must_fail git config --bool core.ignorecase >/dev/null ||
38 test $(git config --bool core.ignorecase) = false
43 if test_have_prereq SYMLINKS
44 then
45 test_expect_success "detection of filesystem w/o symlink support during repo init" '
47 test_must_fail git config --bool core.symlinks ||
48 test "$(git config --bool core.symlinks)" = true
51 else
52 test_expect_success "detection of filesystem w/o symlink support during repo init" '
53 v=$(git config --bool core.symlinks) &&
54 test "$v" = false
58 test_expect_success "setup case tests" '
59 git config core.ignorecase true &&
60 touch camelcase &&
61 git add camelcase &&
62 git commit -m "initial" &&
63 git tag initial &&
64 git checkout -b topic &&
65 git mv camelcase tmp &&
66 git mv tmp CamelCase &&
67 git commit -m "rename" &&
68 git checkout -f master
71 test_expect_success 'rename (case change)' '
72 git mv camelcase CamelCase &&
73 git commit -m "rename"
76 test_expect_success 'merge (case change)' '
77 rm -f CamelCase &&
78 rm -f camelcase &&
79 git reset --hard initial &&
80 git merge topic
85 test_expect_failure CASE_INSENSITIVE_FS 'add (with different case)' '
86 git reset --hard initial &&
87 rm camelcase &&
88 echo 1 >CamelCase &&
89 git add CamelCase &&
90 camel=$(git ls-files | grep -i camelcase) &&
91 test $(echo "$camel" | wc -l) = 1 &&
92 test "z$(git cat-file blob :$camel)" = z1
95 test_expect_success "setup unicode normalization tests" '
96 test_create_repo unicode &&
97 cd unicode &&
98 git config core.precomposeunicode false &&
99 touch "$aumlcdiar" &&
100 git add "$aumlcdiar" &&
101 git commit -m initial &&
102 git tag initial &&
103 git checkout -b topic &&
104 git mv $aumlcdiar tmp &&
105 git mv tmp "$auml" &&
106 git commit -m rename &&
107 git checkout -f master
110 $test_unicode 'rename (silent unicode normalization)' '
111 git mv "$aumlcdiar" "$auml" &&
112 git commit -m rename
115 $test_unicode 'merge (silent unicode normalization)' '
116 git reset --hard initial &&
117 git merge topic
120 test_done