Merge branch 'lf/echo-n-is-not-portable'
[git/git-svn.git] / t / t3010-ls-files-killed-modified.sh
blobf611d799b690457e306571adf16813b238a27dc9
1 #!/bin/sh
3 # Copyright (c) 2005 Junio C Hamano
6 test_description='git ls-files -k and -m flags test.
8 This test prepares the following in the cache:
10 path0 - a file
11 path1 - a symlink
12 path2/file2 - a file in a directory
13 path3/file3 - a file in a directory
14 submod1/ - a submodule
15 submod2/ - another submodule
17 and the following on the filesystem:
19 path0/file0 - a file in a directory
20 path1/file1 - a file in a directory
21 path2 - a file
22 path3 - a symlink
23 path4 - a file
24 path5 - a symlink
25 path6/file6 - a file in a directory
26 submod1/ - a submodule (modified from the cache)
27 submod2/ - a submodule (matches the cache)
29 git ls-files -k should report that existing filesystem objects
30 path0/*, path1/*, path2 and path3 to be killed.
32 Also for modification test, the cache and working tree have:
34 path7 - an empty file, modified to a non-empty file.
35 path8 - a non-empty file, modified to an empty file.
36 path9 - an empty file, cache dirtied.
37 path10 - a non-empty file, cache dirtied.
39 We should report path0, path1, path2/file2, path3/file3, path7 and path8
40 modified without reporting path9 and path10. submod1 is also modified.
42 . ./test-lib.sh
44 test_expect_success 'git update-index --add to add various paths.' '
45 date >path0 &&
46 test_ln_s_add xyzzy path1 &&
47 mkdir path2 path3 &&
48 date >path2/file2 &&
49 date >path3/file3 &&
50 : >path7 &&
51 date >path8 &&
52 : >path9 &&
53 date >path10 &&
54 git update-index --add -- path0 path?/file? path7 path8 path9 path10 &&
55 for i in 1 2
57 git init submod$i &&
59 cd submod$i && git commit --allow-empty -m "empty $i"
60 ) || break
61 done &&
62 git update-index --add submod[12]
64 cd submod1 &&
65 git commit --allow-empty -m "empty 1 (updated)"
66 ) &&
67 rm -fr path? # leave path10 alone
70 test_expect_success 'git ls-files -k to show killed files.' '
71 date >path2 &&
72 if test_have_prereq SYMLINKS
73 then
74 ln -s frotz path3 &&
75 ln -s nitfol path5
76 else
77 date >path3 &&
78 date >path5
79 fi &&
80 mkdir path0 path1 path6 &&
81 date >path0/file0 &&
82 date >path1/file1 &&
83 date >path6/file6 &&
84 date >path7 &&
85 : >path8 &&
86 : >path9 &&
87 touch path10 &&
88 git ls-files -k >.output
91 test_expect_success 'validate git ls-files -k output.' '
92 cat >.expected <<-\EOF &&
93 path0/file0
94 path1/file1
95 path2
96 path3
97 EOF
98 test_cmp .expected .output
101 test_expect_success 'git ls-files -m to show modified files.' '
102 git ls-files -m >.output
105 test_expect_success 'validate git ls-files -m output.' '
106 cat >.expected <<-\EOF &&
107 path0
108 path1
109 path2/file2
110 path3/file3
111 path7
112 path8
113 submod1
115 test_cmp .expected .output
118 test_done