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