blob: 5a06732ca730f4a4becff478cc96f20b8931f6fc [file] [log] [blame]
Carl Worth54e1abc2007-10-03 00:03:53 -07001#!/bin/sh
2#
3# Copyright (c) 2007 Carl D. Worth
4#
5
6test_description='git ls-files test (--with-tree).
7
8This test runs git ls-files --with-tree and in particular in
9a scenario known to trigger a crash with some versions of git.
10'
Ævar Arnfjörð Bjarmasonc07ce062022-11-08 19:17:45 +010011
12TEST_PASSES_SANITIZE_LEAK=true
Carl Worth54e1abc2007-10-03 00:03:53 -070013. ./test-lib.sh
14
Li Linchao18337d42022-07-03 15:49:09 +000015test_expect_success 'setup' '
Carl Worth54e1abc2007-10-03 00:03:53 -070016
17 # The bug we are exercising requires a fair number of entries
18 # in a sub-directory so that add_index_entry will trigger a
19 # realloc.
20
21 echo file >expected &&
22 mkdir sub &&
Carl Worth54e1abc2007-10-03 00:03:53 -070023 for n in 0 1 2 3 4 5
24 do
25 for m in 0 1 2 3 4 5 6 7 8 9
26 do
27 num=00$n$m &&
28 >sub/file-$num &&
Jeff Kingc6587bd2015-03-25 01:30:17 -040029 echo file-$num >>expected ||
30 return 1
31 done
32 done &&
Carl Worth54e1abc2007-10-03 00:03:53 -070033 git add . &&
34 git commit -m "add a bunch of files" &&
35
36 # We remove them all so that we will have something to add
37 # back with --with-tree and so that we will definitely be
38 # under the realloc size to trigger the bug.
39 rm -rf sub &&
40 git commit -a -m "remove them all" &&
41
42 # The bug also requires some entry before our directory so that
Andrei Rybak993d7082023-03-31 16:36:03 +020043 # prune_index will modify the_repository->index.cache
Carl Worth54e1abc2007-10-03 00:03:53 -070044
45 mkdir a_directory_that_sorts_before_sub &&
46 >a_directory_that_sorts_before_sub/file &&
47 mkdir sub &&
48 >sub/file &&
49 git add .
50'
51
Ævar Arnfjörð Bjarmason8de78212021-03-20 23:37:45 +010052test_expect_success 'usage' '
53 test_expect_code 128 git ls-files --with-tree=HEAD -u &&
54 test_expect_code 128 git ls-files --with-tree=HEAD -s &&
55 test_expect_code 128 git ls-files --recurse-submodules --with-tree=HEAD
56'
57
Nathan Stocks14c47762019-11-06 04:18:09 +000058test_expect_success 'git ls-files --with-tree should succeed from subdir' '
Andrei Rybak993d7082023-03-31 16:36:03 +020059 # We have to run from a sub-directory to trigger prune_index
Jonathan Nieder18a82692010-09-06 20:42:54 -050060 # Then we finally get to run our --with-tree test
61 (
62 cd sub &&
63 git ls-files --with-tree=HEAD~1 >../output
64 )
Carl Worth54e1abc2007-10-03 00:03:53 -070065'
66
Li Linchao18337d42022-07-03 15:49:09 +000067test_expect_success 'git ls-files --with-tree should add entries from named tree.' '
68 test_cmp expected output
69'
Carl Worth54e1abc2007-10-03 00:03:53 -070070
Ævar Arnfjörð Bjarmason8de78212021-03-20 23:37:45 +010071test_expect_success 'no duplicates in --with-tree output' '
72 git ls-files --with-tree=HEAD >actual &&
73 sort -u actual >expected &&
74 test_cmp expected actual
75'
76
77test_expect_success 'setup: output in a conflict' '
78 test_create_repo conflict &&
79 test_commit -C conflict BASE file &&
80 test_commit -C conflict A file foo &&
81 git -C conflict reset --hard BASE &&
82 test_commit -C conflict B file bar
83'
84
85test_expect_success 'output in a conflict' '
86 test_must_fail git -C conflict merge A B &&
87 cat >expected <<-\EOF &&
88 file
89 file
90 file
91 file
92 EOF
93 git -C conflict ls-files --with-tree=HEAD >actual &&
94 test_cmp expected actual
95'
96
97test_expect_success 'output with removed .git/index' '
98 cat >expected <<-\EOF &&
99 file
100 EOF
101 rm conflict/.git/index &&
102 git -C conflict ls-files --with-tree=HEAD >actual &&
103 test_cmp expected actual
104'
105
Carl Worth54e1abc2007-10-03 00:03:53 -0700106test_done