107 lines
2.5 KiB
Bash
Executable File
107 lines
2.5 KiB
Bash
Executable File
#!/bin/sh
|
|
#
|
|
# Copyright (c) 2007 Carl D. Worth
|
|
#
|
|
|
|
test_description='git ls-files test (--with-tree).
|
|
|
|
This test runs git ls-files --with-tree and in particular in
|
|
a scenario known to trigger a crash with some versions of git.
|
|
'
|
|
|
|
TEST_PASSES_SANITIZE_LEAK=true
|
|
. ./test-lib.sh
|
|
|
|
test_expect_success 'setup' '
|
|
|
|
# The bug we are exercising requires a fair number of entries
|
|
# in a sub-directory so that add_index_entry will trigger a
|
|
# realloc.
|
|
|
|
echo file >expected &&
|
|
mkdir sub &&
|
|
for n in 0 1 2 3 4 5
|
|
do
|
|
for m in 0 1 2 3 4 5 6 7 8 9
|
|
do
|
|
num=00$n$m &&
|
|
>sub/file-$num &&
|
|
echo file-$num >>expected ||
|
|
return 1
|
|
done
|
|
done &&
|
|
git add . &&
|
|
git commit -m "add a bunch of files" &&
|
|
|
|
# We remove them all so that we will have something to add
|
|
# back with --with-tree and so that we will definitely be
|
|
# under the realloc size to trigger the bug.
|
|
rm -rf sub &&
|
|
git commit -a -m "remove them all" &&
|
|
|
|
# The bug also requires some entry before our directory so that
|
|
# prune_index will modify the_repository->index.cache
|
|
|
|
mkdir a_directory_that_sorts_before_sub &&
|
|
>a_directory_that_sorts_before_sub/file &&
|
|
mkdir sub &&
|
|
>sub/file &&
|
|
git add .
|
|
'
|
|
|
|
test_expect_success 'usage' '
|
|
test_expect_code 128 git ls-files --with-tree=HEAD -u &&
|
|
test_expect_code 128 git ls-files --with-tree=HEAD -s &&
|
|
test_expect_code 128 git ls-files --recurse-submodules --with-tree=HEAD
|
|
'
|
|
|
|
test_expect_success 'git ls-files --with-tree should succeed from subdir' '
|
|
# We have to run from a sub-directory to trigger prune_index
|
|
# Then we finally get to run our --with-tree test
|
|
(
|
|
cd sub &&
|
|
git ls-files --with-tree=HEAD~1 >../output
|
|
)
|
|
'
|
|
|
|
test_expect_success 'git ls-files --with-tree should add entries from named tree.' '
|
|
test_cmp expected output
|
|
'
|
|
|
|
test_expect_success 'no duplicates in --with-tree output' '
|
|
git ls-files --with-tree=HEAD >actual &&
|
|
sort -u actual >expected &&
|
|
test_cmp expected actual
|
|
'
|
|
|
|
test_expect_success 'setup: output in a conflict' '
|
|
test_create_repo conflict &&
|
|
test_commit -C conflict BASE file &&
|
|
test_commit -C conflict A file foo &&
|
|
git -C conflict reset --hard BASE &&
|
|
test_commit -C conflict B file bar
|
|
'
|
|
|
|
test_expect_success 'output in a conflict' '
|
|
test_must_fail git -C conflict merge A B &&
|
|
cat >expected <<-\EOF &&
|
|
file
|
|
file
|
|
file
|
|
file
|
|
EOF
|
|
git -C conflict ls-files --with-tree=HEAD >actual &&
|
|
test_cmp expected actual
|
|
'
|
|
|
|
test_expect_success 'output with removed .git/index' '
|
|
cat >expected <<-\EOF &&
|
|
file
|
|
EOF
|
|
rm conflict/.git/index &&
|
|
git -C conflict ls-files --with-tree=HEAD >actual &&
|
|
test_cmp expected actual
|
|
'
|
|
|
|
test_done
|