diff options
author | Junio C Hamano <gitster@pobox.com> | 2013-06-02 15:48:24 -0700 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2013-06-02 15:48:25 -0700 |
commit | 843fb919fd68739f3cc8f94e6a0225ead97e1e7e (patch) | |
tree | d434c8476b73714c06d04ebd71ab23c9302afe69 /t | |
parent | Merge branch 'rh/merge-options-doc-fix' (diff) | |
parent | t5004: resurrect original empty tar archive test (diff) | |
download | tgif-843fb919fd68739f3cc8f94e6a0225ead97e1e7e.tar.xz |
Merge branch 'rs/empty-archive'
Fixes tests added in 1.8.2 era that are broken on BSDs.
* rs/empty-archive:
t5004: resurrect original empty tar archive test
t5004: avoid using tar for checking emptiness of archive
Diffstat (limited to 't')
-rwxr-xr-x | t/t5004-archive-corner-cases.sh | 15 | ||||
-rw-r--r-- | t/t5004/empty-with-pax-header.tar | bin | 0 -> 10240 bytes |
2 files changed, 15 insertions, 0 deletions
diff --git a/t/t5004-archive-corner-cases.sh b/t/t5004-archive-corner-cases.sh index 8d1bbd356a..67f3b54bed 100755 --- a/t/t5004-archive-corner-cases.sh +++ b/t/t5004-archive-corner-cases.sh @@ -27,6 +27,21 @@ check_dir() { test_cmp expect actual } + +# bsdtar/libarchive versions before 3.1.3 consider a tar file with a +# global pax header that is not followed by a file record as corrupt. +if "$TAR" tf "$TEST_DIRECTORY"/t5004/empty-with-pax-header.tar >/dev/null 2>&1 +then + test_set_prereq HEADER_ONLY_TAR_OK +fi + +test_expect_success HEADER_ONLY_TAR_OK 'tar archive of commit with empty tree' ' + git archive --format=tar HEAD >empty-with-pax-header.tar && + make_dir extract && + "$TAR" xf empty-with-pax-header.tar -C extract && + check_dir extract +' + test_expect_success 'tar archive of empty tree is empty' ' git archive --format=tar HEAD: >empty.tar && perl -e "print \"\\0\" x 10240" >10knuls.tar && diff --git a/t/t5004/empty-with-pax-header.tar b/t/t5004/empty-with-pax-header.tar Binary files differnew file mode 100644 index 0000000000..da9e39e6cf --- /dev/null +++ b/t/t5004/empty-with-pax-header.tar |