revision: fix leaking parents when simplifying commits
[git/gitster.git] / t / t6011-rev-list-with-bad-commit.sh
blobb2e422cf0f7eaa43411fdb6f2bb769ee7294a322
1 #!/bin/sh
3 test_description='git rev-list should notice bad commits'
5 TEST_PASSES_SANITIZE_LEAK=true
6 . ./test-lib.sh
8 # Note:
9 # - compression level is set to zero to make "corruptions" easier to perform
10 # - reflog is disabled to avoid extra references which would twart the test
12 test_expect_success 'setup' \
14 git init &&
15 git config core.compression 0 &&
16 git config core.logallrefupdates false &&
17 echo "foo" > foo &&
18 git add foo &&
19 git commit -m "first commit" &&
20 echo "bar" > bar &&
21 git add bar &&
22 git commit -m "second commit" &&
23 echo "baz" > baz &&
24 git add baz &&
25 git commit -m "third commit" &&
26 echo "foo again" >> foo &&
27 git add foo &&
28 git commit -m "fourth commit" &&
29 git repack -a -f -d
32 test_expect_success 'verify number of revisions' \
34 revs=$(git rev-list --all | wc -l) &&
35 test $revs -eq 4 &&
36 first_commit=$(git rev-parse HEAD~3)
39 test_expect_success 'corrupt second commit object' \
41 perl -i.bak -pe "s/second commit/socond commit/" .git/objects/pack/*.pack &&
42 test_must_fail git fsck --full
45 test_expect_success 'rev-list should fail' '
46 test_must_fail env GIT_TEST_COMMIT_GRAPH=0 git -c core.commitGraph=false rev-list --all > /dev/null
49 test_expect_success 'git repack _MUST_ fail' \
51 test_must_fail git repack -a -f -d
54 test_expect_success 'first commit is still available' \
56 git log $first_commit
59 test_done