diff options
author | Junio C Hamano <gitster@pobox.com> | 2009-02-11 01:40:12 -0800 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2009-02-11 01:40:12 -0800 |
commit | 92798702cf6d201f80e257a07d0a0c40565c79fe (patch) | |
tree | dd283f28f9f630b5c5ff76456cb46368ebbacc2e /t/t5307-pack-missing-commit.sh | |
parent | GIT 1.5.5.6 (diff) | |
parent | revision traversal and pack: notice and die on missing commit (diff) | |
download | tgif-92798702cf6d201f80e257a07d0a0c40565c79fe.tar.xz |
Merge branch 'maint-1.5.4' into maint-1.5.5
* maint-1.5.4:
revision traversal and pack: notice and die on missing commit
Diffstat (limited to 't/t5307-pack-missing-commit.sh')
-rwxr-xr-x | t/t5307-pack-missing-commit.sh | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/t/t5307-pack-missing-commit.sh b/t/t5307-pack-missing-commit.sh new file mode 100755 index 0000000000..ae52a1882d --- /dev/null +++ b/t/t5307-pack-missing-commit.sh @@ -0,0 +1,39 @@ +#!/bin/sh + +test_description='pack should notice missing commit objects' + +. ./test-lib.sh + +test_expect_success setup ' + for i in 1 2 3 4 5 + do + echo "$i" >"file$i" && + git add "file$i" && + test_tick && + git commit -m "$i" && + git tag "tag$i" + done && + obj=$(git rev-parse --verify tag3) && + fanout=$(expr "$obj" : "\(..\)") && + remainder=$(expr "$obj" : "..\(.*\)") && + rm -f ".git/objects/$fanout/$remainder" +' + +test_expect_success 'check corruption' ' + test_must_fail git fsck +' + +test_expect_success 'rev-list notices corruption (1)' ' + test_must_fail git rev-list HEAD +' + +test_expect_success 'rev-list notices corruption (2)' ' + test_must_fail git rev-list --objects HEAD +' + +test_expect_success 'pack-objects notices corruption' ' + echo HEAD | + test_must_fail git pack-objects --revs pack +' + +test_done |