d5f4b8260f
`git add` refrains from adding or updating index entries that are outside the current sparse checkout, but `git rm` doesn't follow the same restriction. This is somewhat counter-intuitive and inconsistent. So make `rm` honor the sparsity rules and advise on how to remove SKIP_WORKTREE entries just like `add` does. Also add some tests for the new behavior. Suggested-by: Elijah Newren <newren@gmail.com> Signed-off-by: Matheus Tavares <matheus.bernardino@usp.br> Signed-off-by: Junio C Hamano <gitster@pobox.com>
148 lines
2.9 KiB
Bash
Executable File
148 lines
2.9 KiB
Bash
Executable File
#!/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
|
|
|
|
setup_absent() {
|
|
test -f 1 && rm 1
|
|
git update-index --remove 1 &&
|
|
git update-index --add --cacheinfo 100644 $EMPTY_BLOB 1 &&
|
|
git update-index --skip-worktree 1
|
|
}
|
|
|
|
test_absent() {
|
|
echo "100644 $EMPTY_BLOB 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 $EMPTY_BLOB 1 &&
|
|
git update-index --skip-worktree 1
|
|
}
|
|
|
|
test_dirty() {
|
|
echo "100644 $EMPTY_BLOB 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 --deleted' '
|
|
setup_absent &&
|
|
test -z "$(git ls-files -d)"
|
|
'
|
|
|
|
test_expect_success 'ls-files --deleted' '
|
|
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)"
|
|
'
|
|
|
|
echo ":000000 100644 $ZERO_OID $EMPTY_BLOB 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 'commit on skip-worktree absent entries' '
|
|
git reset &&
|
|
setup_absent &&
|
|
test_must_fail git commit -m null 1
|
|
'
|
|
|
|
test_expect_success 'commit on skip-worktree dirty entries' '
|
|
git reset &&
|
|
setup_dirty &&
|
|
test_must_fail git commit -m null 1
|
|
'
|
|
|
|
test_done
|