Merge branch 'mg/alias-expose-prefix'
[git] / t / t7011-skip-worktree-reading.sh
CommitLineData
b4d1690d
NTND
1#!/bin/sh
2#
3# Copyright (c) 2008 Nguyễn Thái Ngọc Duy
4#
5
6test_description='skip-worktree bit test'
7
8. ./test-lib.sh
9
10cat >expect.full <<EOF
11H 1
12H 2
13H init.t
14H sub/1
15H sub/2
16EOF
17
18cat >expect.skip <<EOF
19S 1
20H 2
21H init.t
22S sub/1
23H sub/2
24EOF
25
26NULL_SHA1=e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
27ZERO_SHA0=0000000000000000000000000000000000000000
28setup_absent() {
29 test -f 1 && rm 1
30 git update-index --remove 1 &&
31 git update-index --add --cacheinfo 100644 $NULL_SHA1 1 &&
32 git update-index --skip-worktree 1
33}
34
35test_absent() {
36 echo "100644 $NULL_SHA1 0 1" > expected &&
37 git ls-files --stage 1 > result &&
38 test_cmp expected result &&
39 test ! -f 1
40}
41
42setup_dirty() {
43 git update-index --force-remove 1 &&
44 echo dirty > 1 &&
45 git update-index --add --cacheinfo 100644 $NULL_SHA1 1 &&
46 git update-index --skip-worktree 1
47}
48
49test_dirty() {
50 echo "100644 $NULL_SHA1 0 1" > expected &&
51 git ls-files --stage 1 > result &&
52 test_cmp expected result &&
53 echo dirty > expected
54 test_cmp expected 1
55}
56
57test_expect_success 'setup' '
58 test_commit init &&
59 mkdir sub &&
60 touch ./1 ./2 sub/1 sub/2 &&
61 git add 1 2 sub/1 sub/2 &&
62 git update-index --skip-worktree 1 sub/1 &&
63 git ls-files -t > result &&
64 test_cmp expect.skip result
65'
66
67test_expect_success 'update-index' '
68 setup_absent &&
69 git update-index 1 &&
70 test_absent
71'
72
73test_expect_success 'update-index' '
74 setup_dirty &&
75 git update-index 1 &&
76 test_dirty
77'
78
79test_expect_success 'update-index --remove' '
80 setup_absent &&
81 git update-index --remove 1 &&
82 test -z "$(git ls-files 1)" &&
83 test ! -f 1
84'
85
86test_expect_success 'update-index --remove' '
87 setup_dirty &&
88 git update-index --remove 1 &&
89 test -z "$(git ls-files 1)" &&
90 echo dirty > expected &&
91 test_cmp expected 1
92'
93
94test_expect_success 'ls-files --delete' '
95 setup_absent &&
96 test -z "$(git ls-files -d)"
97'
98
99test_expect_success 'ls-files --delete' '
100 setup_dirty &&
101 test -z "$(git ls-files -d)"
102'
103
104test_expect_success 'ls-files --modified' '
105 setup_absent &&
106 test -z "$(git ls-files -m)"
107'
108
109test_expect_success 'ls-files --modified' '
110 setup_dirty &&
111 test -z "$(git ls-files -m)"
112'
113
114test_expect_success 'grep with skip-worktree file' '
115 git update-index --no-skip-worktree 1 &&
116 echo test > 1 &&
117 git update-index 1 &&
118 git update-index --skip-worktree 1 &&
119 rm 1 &&
120 test "$(git grep --no-ext-grep test)" = "1:test"
121'
122
123echo ":000000 100644 $ZERO_SHA0 $NULL_SHA1 A 1" > expected
124test_expect_success 'diff-index does not examine skip-worktree absent entries' '
125 setup_absent &&
126 git diff-index HEAD -- 1 > result &&
127 test_cmp expected result
128'
129
130test_expect_success 'diff-index does not examine skip-worktree dirty entries' '
131 setup_dirty &&
132 git diff-index HEAD -- 1 > result &&
133 test_cmp expected result
134'
135
136test_expect_success 'diff-files does not examine skip-worktree absent entries' '
137 setup_absent &&
138 test -z "$(git diff-files -- one)"
139'
140
141test_expect_success 'diff-files does not examine skip-worktree dirty entries' '
142 setup_dirty &&
143 test -z "$(git diff-files -- one)"
144'
145
146test_expect_success 'git-rm succeeds on skip-worktree absent entries' '
147 setup_absent &&
148 git rm 1
149'
150
7fce6e3c 151test_expect_success 'commit on skip-worktree absent entries' '
b4d1690d
NTND
152 git reset &&
153 setup_absent &&
154 test_must_fail git commit -m null 1
155'
156
7fce6e3c 157test_expect_success 'commit on skip-worktree dirty entries' '
b4d1690d
NTND
158 git reset &&
159 setup_dirty &&
160 test_must_fail git commit -m null 1
161'
162
163test_done