3e3b9321ca
Mark those remaining tests that pass when run under SANITIZE=leak with TEST_PASSES_SANITIZE_LEAK=true, these were either omitted inf346fcb62a
(Merge branch 'ab/mark-leak-free-tests-even-more', 2021-12-15) and5a4f8381b6
(Merge branch 'ab/mark-leak-free-tests', 2021-10-25), or have had their memory leaks fixed since then. With this change there's now a a one-to-one mapping between those tests that we have opted-in via "TEST_PASSES_SANITIZE_LEAK=true", and those that pass with the new "check" mode: GIT_TEST_PASSING_SANITIZE_LEAK=check \ GIT_TEST_SANITIZE_LEAK_LOG=true \ make test SANITIZE=leak Note that the "GIT_TEST_SANITIZE_LEAK_LOG=true" is needed due to the edge cases noted in a preceding commit, i.e. in some cases we'd pass the test itself, but still have outstanding leaks due to ignored exit codes. The "GIT_TEST_SANITIZE_LEAK_LOG=true" corrects for that, we're only marking those tests as passing that really don't have any leaks, whether that was reflected in their exit code or not. Note that the change here to "t9100-git-svn-basic.sh" is marking that test as passing under SANITIZE=leak, we're removing a "TEST_FAILS_SANITIZE_LEAK=true" line, not "TEST_PASSES_SANITIZE_LEAK=true". See7a98d9ab00
(revisions API: have release_revisions() release "cmdline", 2022-04-13) for the introduction of that t/lib-git-svn.sh-specific variable. Signed-off-by: Ævar Arnfjörð Bjarmason <avarab@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
160 lines
3.5 KiB
Bash
Executable File
160 lines
3.5 KiB
Bash
Executable File
#!/bin/sh
|
|
|
|
test_description='Various filesystem issues'
|
|
|
|
GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME=main
|
|
export GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME
|
|
|
|
TEST_PASSES_SANITIZE_LEAK=true
|
|
. ./test-lib.sh
|
|
|
|
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
|
|
fi
|
|
|
|
test_have_prereq SYMLINKS ||
|
|
say "will test on a filesystem lacking symbolic links"
|
|
|
|
if test_have_prereq CASE_INSENSITIVE_FS
|
|
then
|
|
test_expect_success "detection of case insensitive filesystem during repo init" '
|
|
test $(git config --bool core.ignorecase) = true
|
|
'
|
|
else
|
|
test_expect_success "detection of case insensitive filesystem during repo init" '
|
|
{
|
|
test_must_fail git config --bool core.ignorecase >/dev/null ||
|
|
test $(git config --bool core.ignorecase) = false
|
|
}
|
|
'
|
|
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 &&
|
|
touch camelcase &&
|
|
git add camelcase &&
|
|
git commit -m "initial" &&
|
|
git tag initial &&
|
|
git checkout -b topic &&
|
|
git mv camelcase tmp &&
|
|
git mv tmp CamelCase &&
|
|
git commit -m "rename" &&
|
|
git checkout -f main
|
|
'
|
|
|
|
test_expect_success 'rename (case change)' '
|
|
git mv camelcase CamelCase &&
|
|
git commit -m "rename"
|
|
'
|
|
|
|
test_expect_success 'merge (case change)' '
|
|
rm -f CamelCase &&
|
|
rm -f camelcase &&
|
|
git reset --hard initial &&
|
|
git merge topic
|
|
'
|
|
|
|
test_expect_success CASE_INSENSITIVE_FS 'add directory (with different case)' '
|
|
git reset --hard initial &&
|
|
mkdir -p dir1/dir2 &&
|
|
echo >dir1/dir2/a &&
|
|
echo >dir1/dir2/b &&
|
|
git add dir1/dir2/a &&
|
|
git add dir1/DIR2/b &&
|
|
git ls-files >actual &&
|
|
cat >expected <<-\EOF &&
|
|
camelcase
|
|
dir1/dir2/a
|
|
dir1/dir2/b
|
|
EOF
|
|
test_cmp expected actual
|
|
'
|
|
|
|
test_expect_failure CASE_INSENSITIVE_FS 'add (with different case)' '
|
|
git reset --hard initial &&
|
|
rm camelcase &&
|
|
echo 1 >CamelCase &&
|
|
git add CamelCase &&
|
|
git ls-files >tmp &&
|
|
camel=$(grep -i camelcase tmp) &&
|
|
test $(echo "$camel" | wc -l) = 1 &&
|
|
test "z$(git cat-file blob :$camel)" = z1
|
|
'
|
|
|
|
test_expect_success "setup unicode normalization tests" '
|
|
test_create_repo unicode &&
|
|
cd unicode &&
|
|
git config core.precomposeunicode false &&
|
|
touch "$aumlcdiar" &&
|
|
git add "$aumlcdiar" &&
|
|
git commit -m initial &&
|
|
git tag initial &&
|
|
git checkout -b topic &&
|
|
git mv $aumlcdiar tmp &&
|
|
git mv tmp "$auml" &&
|
|
git commit -m rename &&
|
|
git checkout -f main
|
|
'
|
|
|
|
$test_unicode 'rename (silent unicode normalization)' '
|
|
git mv "$aumlcdiar" "$auml" &&
|
|
git commit -m rename
|
|
'
|
|
|
|
$test_unicode 'merge (silent unicode normalization)' '
|
|
git reset --hard initial &&
|
|
git merge topic
|
|
'
|
|
|
|
test_expect_success CASE_INSENSITIVE_FS 'checkout with no pathspec and a case insensitive fs' '
|
|
git init repo &&
|
|
(
|
|
cd repo &&
|
|
|
|
>Gitweb &&
|
|
git add Gitweb &&
|
|
git commit -m "add Gitweb" &&
|
|
|
|
git checkout --orphan todo &&
|
|
git reset --hard &&
|
|
mkdir -p gitweb/subdir &&
|
|
>gitweb/subdir/file &&
|
|
git add gitweb &&
|
|
git commit -m "add gitweb/subdir/file" &&
|
|
|
|
git checkout main
|
|
)
|
|
'
|
|
|
|
test_done
|