Merge branch 'yk/git-tag-remove-mention-of-old-layout-in-doc' into maint
[git] / t / t3005-ls-files-relative.sh
1 #!/bin/sh
2
3 test_description='ls-files tests with relative paths
4
5 This test runs git ls-files with various relative path arguments.
6 '
7
8 . ./test-lib.sh
9
10 new_line='
11 '
12 sq=\'
13
14 test_expect_success 'prepare' '
15         : >never-mind-me &&
16         git add never-mind-me &&
17         mkdir top &&
18         (
19                 cd top &&
20                 mkdir sub &&
21                 x="x xa xbc xdef xghij xklmno" &&
22                 y=$(echo "$x" | tr x y) &&
23                 touch $x &&
24                 touch $y &&
25                 cd sub &&
26                 git add ../x*
27         )
28 '
29
30 test_expect_success 'ls-files with mixed levels' '
31         (
32                 cd top/sub &&
33                 cat >expect <<-EOF &&
34                 ../../never-mind-me
35                 ../x
36                 EOF
37                 git ls-files $(cat expect) >actual &&
38                 test_cmp expect actual
39         )
40 '
41
42 test_expect_success 'ls-files -c' '
43         (
44                 cd top/sub &&
45                 for f in ../y*
46                 do
47                         echo "error: pathspec $sq$f$sq did not match any file(s) known to git."
48                 done >expect.err &&
49                 echo "Did you forget to ${sq}git add${sq}?" >>expect.err &&
50                 ls ../x* >expect.out &&
51                 test_must_fail git ls-files -c --error-unmatch ../[xy]* >actual.out 2>actual.err &&
52                 test_cmp expect.out actual.out &&
53                 test_cmp expect.err actual.err
54         )
55 '
56
57 test_expect_success 'ls-files -o' '
58         (
59                 cd top/sub &&
60                 for f in ../x*
61                 do
62                         echo "error: pathspec $sq$f$sq did not match any file(s) known to git."
63                 done >expect.err &&
64                 echo "Did you forget to ${sq}git add${sq}?" >>expect.err &&
65                 ls ../y* >expect.out &&
66                 test_must_fail git ls-files -o --error-unmatch ../[xy]* >actual.out 2>actual.err &&
67                 test_cmp expect.out actual.out &&
68                 test_cmp expect.err actual.err
69         )
70 '
71
72 test_done