summaryrefslogtreecommitdiff
path: root/t
diff options
context:
space:
mode:
authorLibravatar Junio C Hamano <gitster@pobox.com>2009-02-11 01:40:12 -0800
committerLibravatar Junio C Hamano <gitster@pobox.com>2009-02-11 01:40:12 -0800
commit92798702cf6d201f80e257a07d0a0c40565c79fe (patch)
treedd283f28f9f630b5c5ff76456cb46368ebbacc2e /t
parentGIT 1.5.5.6 (diff)
parentrevision traversal and pack: notice and die on missing commit (diff)
downloadtgif-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')
-rwxr-xr-xt/t5307-pack-missing-commit.sh39
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