t5001: add tests for export-ignore attributes and exclude pathspecs
Demonstrate mishandling of the attribute export-ignore by git archive when used together with pathspecs. Wildcard pathspecs can even cause it to abort. And a directory excluded without a wildcard is still included as an empty folder in the archive. Test-case-by: David Adam <zanchey@ucc.gu.uwa.edu.au> Signed-off-by: Rene Scharfe <l.s.r@web.de> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
4d7268b888
commit
bed69a6e82
@ -7,11 +7,15 @@ test_description='git archive attribute tests'
|
|||||||
SUBSTFORMAT='%H (%h)%n'
|
SUBSTFORMAT='%H (%h)%n'
|
||||||
|
|
||||||
test_expect_exists() {
|
test_expect_exists() {
|
||||||
test_expect_success " $1 exists" "test -e $1"
|
test_expect_${2:-success} " $1 exists" "test -e $1"
|
||||||
}
|
}
|
||||||
|
|
||||||
test_expect_missing() {
|
test_expect_missing() {
|
||||||
test_expect_success " $1 does not exist" "test ! -e $1"
|
test_expect_${2:-success} " $1 does not exist" "test ! -e $1"
|
||||||
|
}
|
||||||
|
|
||||||
|
extract_tar_to_dir () {
|
||||||
|
(mkdir "$1" && cd "$1" && "$TAR" xf -) <"$1.tar"
|
||||||
}
|
}
|
||||||
|
|
||||||
test_expect_success 'setup' '
|
test_expect_success 'setup' '
|
||||||
@ -21,12 +25,19 @@ test_expect_success 'setup' '
|
|||||||
|
|
||||||
echo ignored by tree >ignored-by-tree &&
|
echo ignored by tree >ignored-by-tree &&
|
||||||
echo ignored-by-tree export-ignore >.gitattributes &&
|
echo ignored-by-tree export-ignore >.gitattributes &&
|
||||||
git add ignored-by-tree .gitattributes &&
|
mkdir ignored-by-tree.d &&
|
||||||
|
>ignored-by-tree.d/file &&
|
||||||
|
echo ignored-by-tree.d export-ignore >>.gitattributes &&
|
||||||
|
git add ignored-by-tree ignored-by-tree.d .gitattributes &&
|
||||||
|
|
||||||
echo ignored by worktree >ignored-by-worktree &&
|
echo ignored by worktree >ignored-by-worktree &&
|
||||||
echo ignored-by-worktree export-ignore >.gitattributes &&
|
echo ignored-by-worktree export-ignore >.gitattributes &&
|
||||||
git add ignored-by-worktree &&
|
git add ignored-by-worktree &&
|
||||||
|
|
||||||
|
mkdir excluded-by-pathspec.d &&
|
||||||
|
>excluded-by-pathspec.d/file &&
|
||||||
|
git add excluded-by-pathspec.d &&
|
||||||
|
|
||||||
printf "A\$Format:%s\$O" "$SUBSTFORMAT" >nosubstfile &&
|
printf "A\$Format:%s\$O" "$SUBSTFORMAT" >nosubstfile &&
|
||||||
printf "A\$Format:%s\$O" "$SUBSTFORMAT" >substfile1 &&
|
printf "A\$Format:%s\$O" "$SUBSTFORMAT" >substfile1 &&
|
||||||
printf "A not substituted O" >substfile2 &&
|
printf "A not substituted O" >substfile2 &&
|
||||||
@ -46,7 +57,37 @@ test_expect_success 'git archive' '
|
|||||||
|
|
||||||
test_expect_missing archive/ignored
|
test_expect_missing archive/ignored
|
||||||
test_expect_missing archive/ignored-by-tree
|
test_expect_missing archive/ignored-by-tree
|
||||||
|
test_expect_missing archive/ignored-by-tree.d
|
||||||
|
test_expect_missing archive/ignored-by-tree.d/file
|
||||||
test_expect_exists archive/ignored-by-worktree
|
test_expect_exists archive/ignored-by-worktree
|
||||||
|
test_expect_exists archive/excluded-by-pathspec.d
|
||||||
|
test_expect_exists archive/excluded-by-pathspec.d/file
|
||||||
|
|
||||||
|
test_expect_success 'git archive with pathspec' '
|
||||||
|
git archive HEAD ":!excluded-by-pathspec.d" >archive-pathspec.tar &&
|
||||||
|
extract_tar_to_dir archive-pathspec
|
||||||
|
'
|
||||||
|
|
||||||
|
test_expect_missing archive-pathspec/ignored
|
||||||
|
test_expect_missing archive-pathspec/ignored-by-tree
|
||||||
|
test_expect_missing archive-pathspec/ignored-by-tree.d
|
||||||
|
test_expect_missing archive-pathspec/ignored-by-tree.d/file
|
||||||
|
test_expect_exists archive-pathspec/ignored-by-worktree
|
||||||
|
test_expect_missing archive-pathspec/excluded-by-pathspec.d failure
|
||||||
|
test_expect_missing archive-pathspec/excluded-by-pathspec.d/file
|
||||||
|
|
||||||
|
test_expect_failure 'git archive with wildcard pathspec' '
|
||||||
|
git archive HEAD ":!excluded-by-p*" >archive-pathspec-wildcard.tar &&
|
||||||
|
extract_tar_to_dir archive-pathspec-wildcard
|
||||||
|
'
|
||||||
|
|
||||||
|
test_expect_missing archive-pathspec-wildcard/ignored
|
||||||
|
test_expect_missing archive-pathspec-wildcard/ignored-by-tree
|
||||||
|
test_expect_missing archive-pathspec-wildcard/ignored-by-tree.d
|
||||||
|
test_expect_missing archive-pathspec-wildcard/ignored-by-tree.d/file
|
||||||
|
test_expect_exists archive-pathspec-wildcard/ignored-by-worktree failure
|
||||||
|
test_expect_missing archive-pathspec-wildcard/excluded-by-pathspec.d
|
||||||
|
test_expect_missing archive-pathspec-wildcard/excluded-by-pathspec.d/file
|
||||||
|
|
||||||
test_expect_success 'git archive with worktree attributes' '
|
test_expect_success 'git archive with worktree attributes' '
|
||||||
git archive --worktree-attributes HEAD >worktree.tar &&
|
git archive --worktree-attributes HEAD >worktree.tar &&
|
||||||
|
Loading…
Reference in New Issue
Block a user