Browse Source
grep: turn on --cached for files that is marked skip-worktree ls-files: do not check for deleted file that is marked skip-worktree update-index: ignore update request if it's skip-worktree, while still allows removing diff*: skip worktree version Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>maint
Nguyễn Thái Ngọc Duy
16 years ago
committed by
Junio C Hamano
8 changed files with 199 additions and 26 deletions
@ -0,0 +1,163 @@
@@ -0,0 +1,163 @@
|
||||
#!/bin/sh |
||||
# |
||||
# Copyright (c) 2008 Nguyễn Thái Ngọc Duy |
||||
# |
||||
|
||||
test_description='skip-worktree bit test' |
||||
|
||||
. ./test-lib.sh |
||||
|
||||
cat >expect.full <<EOF |
||||
H 1 |
||||
H 2 |
||||
H init.t |
||||
H sub/1 |
||||
H sub/2 |
||||
EOF |
||||
|
||||
cat >expect.skip <<EOF |
||||
S 1 |
||||
H 2 |
||||
H init.t |
||||
S sub/1 |
||||
H sub/2 |
||||
EOF |
||||
|
||||
NULL_SHA1=e69de29bb2d1d6434b8b29ae775ad8c2e48c5391 |
||||
ZERO_SHA0=0000000000000000000000000000000000000000 |
||||
setup_absent() { |
||||
test -f 1 && rm 1 |
||||
git update-index --remove 1 && |
||||
git update-index --add --cacheinfo 100644 $NULL_SHA1 1 && |
||||
git update-index --skip-worktree 1 |
||||
} |
||||
|
||||
test_absent() { |
||||
echo "100644 $NULL_SHA1 0 1" > expected && |
||||
git ls-files --stage 1 > result && |
||||
test_cmp expected result && |
||||
test ! -f 1 |
||||
} |
||||
|
||||
setup_dirty() { |
||||
git update-index --force-remove 1 && |
||||
echo dirty > 1 && |
||||
git update-index --add --cacheinfo 100644 $NULL_SHA1 1 && |
||||
git update-index --skip-worktree 1 |
||||
} |
||||
|
||||
test_dirty() { |
||||
echo "100644 $NULL_SHA1 0 1" > expected && |
||||
git ls-files --stage 1 > result && |
||||
test_cmp expected result && |
||||
echo dirty > expected |
||||
test_cmp expected 1 |
||||
} |
||||
|
||||
test_expect_success 'setup' ' |
||||
test_commit init && |
||||
mkdir sub && |
||||
touch ./1 ./2 sub/1 sub/2 && |
||||
git add 1 2 sub/1 sub/2 && |
||||
git update-index --skip-worktree 1 sub/1 && |
||||
git ls-files -t > result && |
||||
test_cmp expect.skip result |
||||
' |
||||
|
||||
test_expect_success 'update-index' ' |
||||
setup_absent && |
||||
git update-index 1 && |
||||
test_absent |
||||
' |
||||
|
||||
test_expect_success 'update-index' ' |
||||
setup_dirty && |
||||
git update-index 1 && |
||||
test_dirty |
||||
' |
||||
|
||||
test_expect_success 'update-index --remove' ' |
||||
setup_absent && |
||||
git update-index --remove 1 && |
||||
test -z "$(git ls-files 1)" && |
||||
test ! -f 1 |
||||
' |
||||
|
||||
test_expect_success 'update-index --remove' ' |
||||
setup_dirty && |
||||
git update-index --remove 1 && |
||||
test -z "$(git ls-files 1)" && |
||||
echo dirty > expected && |
||||
test_cmp expected 1 |
||||
' |
||||
|
||||
test_expect_success 'ls-files --delete' ' |
||||
setup_absent && |
||||
test -z "$(git ls-files -d)" |
||||
' |
||||
|
||||
test_expect_success 'ls-files --delete' ' |
||||
setup_dirty && |
||||
test -z "$(git ls-files -d)" |
||||
' |
||||
|
||||
test_expect_success 'ls-files --modified' ' |
||||
setup_absent && |
||||
test -z "$(git ls-files -m)" |
||||
' |
||||
|
||||
test_expect_success 'ls-files --modified' ' |
||||
setup_dirty && |
||||
test -z "$(git ls-files -m)" |
||||
' |
||||
|
||||
test_expect_success 'grep with skip-worktree file' ' |
||||
git update-index --no-skip-worktree 1 && |
||||
echo test > 1 && |
||||
git update-index 1 && |
||||
git update-index --skip-worktree 1 && |
||||
rm 1 && |
||||
test "$(git grep --no-ext-grep test)" = "1:test" |
||||
' |
||||
|
||||
echo ":000000 100644 $ZERO_SHA0 $NULL_SHA1 A 1" > expected |
||||
test_expect_success 'diff-index does not examine skip-worktree absent entries' ' |
||||
setup_absent && |
||||
git diff-index HEAD -- 1 > result && |
||||
test_cmp expected result |
||||
' |
||||
|
||||
test_expect_success 'diff-index does not examine skip-worktree dirty entries' ' |
||||
setup_dirty && |
||||
git diff-index HEAD -- 1 > result && |
||||
test_cmp expected result |
||||
' |
||||
|
||||
test_expect_success 'diff-files does not examine skip-worktree absent entries' ' |
||||
setup_absent && |
||||
test -z "$(git diff-files -- one)" |
||||
' |
||||
|
||||
test_expect_success 'diff-files does not examine skip-worktree dirty entries' ' |
||||
setup_dirty && |
||||
test -z "$(git diff-files -- one)" |
||||
' |
||||
|
||||
test_expect_success 'git-rm succeeds on skip-worktree absent entries' ' |
||||
setup_absent && |
||||
git rm 1 |
||||
' |
||||
|
||||
test_expect_failure 'commit on skip-worktree absent entries' ' |
||||
git reset && |
||||
setup_absent && |
||||
test_must_fail git commit -m null 1 |
||||
' |
||||
|
||||
test_expect_failure 'commit on skip-worktree dirty entries' ' |
||||
git reset && |
||||
setup_dirty && |
||||
test_must_fail git commit -m null 1 |
||||
' |
||||
|
||||
test_done |
Loading…
Reference in new issue