Skip to content

Commit

Permalink
Merge branch 'maint'
Browse files Browse the repository at this point in the history
* maint:
  revision traversal and pack: notice and die on missing commit
  • Loading branch information
gitster committed Feb 11, 2009
2 parents 1b53a07 + 268c015 commit aff4e8d
Show file tree
Hide file tree
Showing 2 changed files with 43 additions and 2 deletions.
6 changes: 4 additions & 2 deletions revision.c
Original file line number Diff line number Diff line change
Expand Up @@ -1738,14 +1738,16 @@ static struct commit *get_revision_1(struct rev_info *revs)
(commit->date < revs->max_age))
continue;
if (add_parents_to_list(revs, commit, &revs->commits, NULL) < 0)
return NULL;
die("Failed to traverse parents of commit %s",
sha1_to_hex(commit->object.sha1));
}

switch (simplify_commit(revs, commit)) {
case commit_ignore:
continue;
case commit_error:
return NULL;
die("Failed to simplify parents of commit %s",
sha1_to_hex(commit->object.sha1));
default:
return commit;
}
Expand Down
39 changes: 39 additions & 0 deletions t/t5307-pack-missing-commit.sh
Original file line number Diff line number Diff line change
@@ -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

0 comments on commit aff4e8d

Please sign in to comment.