remote-hg: add basic tests
[gitweb.git] / t / t0050-filesystem.sh
index b177174ef53e7689cc8c18b134afdbe90be72744..78816d9d935df478f5cdf93e06fae26cc5488910 100755 (executable)
@@ -4,37 +4,29 @@ test_description='Various filesystem issues'
 
 . ./test-lib.sh
 
-auml=`printf '\xc3\xa4'`
-aumlcdiar=`printf '\x61\xcc\x88'`
-
-case_insensitive=
-test_expect_success 'see if we expect ' '
+auml=$(printf '\303\244')
+aumlcdiar=$(printf '\141\314\210')
 
+if test_have_prereq CASE_INSENSITIVE_FS
+then
+       say "will test on a case insensitive filesystem"
+       test_case=test_expect_failure
+else
        test_case=test_expect_success
+fi
+
+if test_have_prereq UTF8_NFD_TO_NFC
+then
+       say "will test on a unicode corrupting filesystem"
+       test_unicode=test_expect_failure
+else
        test_unicode=test_expect_success
-       mkdir junk &&
-       echo good >junk/CamelCase &&
-       echo bad >junk/camelcase &&
-       if test "$(cat junk/CamelCase)" != good
-       then
-               test_case=test_expect_failure
-               case_insensitive=t
-               say "will test on a case insensitive filesystem"
-       fi &&
-       rm -fr junk &&
-       mkdir junk &&
-       >junk/"$auml" &&
-       case "$(cd junk && echo *)" in
-       "$aumlcdiar")
-               test_unicode=test_expect_failure
-               say "will test on a unicode corrupting filesystem"
-               ;;
-       *)      ;;
-       esac &&
-       rm -fr junk
-'
+fi
+
+test_have_prereq SYMLINKS ||
+       say "will test on a filesystem lacking symbolic links"
 
-if test "$case_insensitive"
+if test_have_prereq CASE_INSENSITIVE_FS
 then
 test_expect_success "detection of case insensitive filesystem during repo init" '
 
@@ -48,6 +40,21 @@ test_expect_success "detection of case insensitive filesystem during repo init"
 '
 fi
 
+if test_have_prereq SYMLINKS
+then
+test_expect_success "detection of filesystem w/o symlink support during repo init" '
+
+       test_must_fail git config --bool core.symlinks ||
+       test "$(git config --bool core.symlinks)" = true
+'
+else
+test_expect_success "detection of filesystem w/o symlink support during repo init" '
+
+       v=$(git config --bool core.symlinks) &&
+       test "$v" = false
+'
+fi
+
 test_expect_success "setup case tests" '
 
        git config core.ignorecase true &&
@@ -79,13 +86,17 @@ $test_case 'merge (case change)' '
 
 '
 
-$test_case 'add (with different case)' '
+
+
+test_expect_failure 'add (with different case)' '
 
        git reset --hard initial &&
        rm camelcase &&
        echo 1 >CamelCase &&
        git add CamelCase &&
-       test $(git-ls-files | grep -i camelcase | wc -l) = 1
+       camel=$(git ls-files | grep -i camelcase) &&
+       test $(echo "$camel" | wc -l) = 1 &&
+       test "z$(git cat-file blob :$camel)" = z1
 
 '
 
@@ -95,7 +106,7 @@ test_expect_success "setup unicode normalization tests" '
   cd unicode &&
   touch "$aumlcdiar" &&
   git add "$aumlcdiar" &&
-  git commit -m initial
+  git commit -m initial &&
   git tag initial &&
   git checkout -b topic &&
   git mv $aumlcdiar tmp &&