| #!/bin/sh |
| |
| test_description='Test git notes prune' |
| |
| . ./test-lib.sh |
| |
| test_expect_success 'setup: create a few commits with notes' ' |
| |
| : > file1 && |
| git add file1 && |
| test_tick && |
| git commit -m 1st && |
| git notes add -m "Note #1" && |
| first=$(git rev-parse HEAD) && |
| : > file2 && |
| git add file2 && |
| test_tick && |
| git commit -m 2nd && |
| git notes add -m "Note #2" && |
| second=$(git rev-parse HEAD) && |
| : > file3 && |
| git add file3 && |
| test_tick && |
| git commit -m 3rd && |
| third=$(git rev-parse HEAD) && |
| COMMIT_FILE=$(echo $third | sed "s!^..!.git/objects/&/!") && |
| test -f $COMMIT_FILE && |
| test-tool chmtime =+0 $COMMIT_FILE && |
| git notes add -m "Note #3" |
| ' |
| |
| cat > expect <<END_OF_LOG |
| commit $third |
| Author: A U Thor <author@example.com> |
| Date: Thu Apr 7 15:15:13 2005 -0700 |
| |
| 3rd |
| |
| Notes: |
| Note #3 |
| |
| commit $second |
| Author: A U Thor <author@example.com> |
| Date: Thu Apr 7 15:14:13 2005 -0700 |
| |
| 2nd |
| |
| Notes: |
| Note #2 |
| |
| commit $first |
| Author: A U Thor <author@example.com> |
| Date: Thu Apr 7 15:13:13 2005 -0700 |
| |
| 1st |
| |
| Notes: |
| Note #1 |
| END_OF_LOG |
| |
| test_expect_success 'verify commits and notes' ' |
| |
| git log > actual && |
| test_cmp expect actual |
| ' |
| |
| test_expect_success 'remove some commits' ' |
| |
| git reset --hard HEAD~1 && |
| git reflog expire --expire=now HEAD && |
| git gc --prune=now |
| ' |
| |
| test_expect_success 'verify that commits are gone' ' |
| |
| test_must_fail git cat-file -p $third && |
| git cat-file -p $second && |
| git cat-file -p $first |
| ' |
| |
| test_expect_success 'verify that notes are still present' ' |
| |
| git notes show $third && |
| git notes show $second && |
| git notes show $first |
| ' |
| |
| test_expect_success 'prune -n does not remove notes' ' |
| |
| git notes list > expect && |
| git notes prune -n && |
| git notes list > actual && |
| test_cmp expect actual |
| ' |
| |
| |
| test_expect_success 'prune -n lists prunable notes' ' |
| |
| echo $third >expect && |
| git notes prune -n > actual && |
| test_cmp expect actual |
| ' |
| |
| |
| test_expect_success 'prune notes' ' |
| |
| git notes prune |
| ' |
| |
| test_expect_success 'verify that notes are gone' ' |
| |
| test_must_fail git notes show $third && |
| git notes show $second && |
| git notes show $first |
| ' |
| |
| test_expect_success 'remove some commits' ' |
| |
| git reset --hard HEAD~1 && |
| git reflog expire --expire=now HEAD && |
| git gc --prune=now |
| ' |
| |
| test_expect_success 'prune -v notes' ' |
| |
| echo $second >expect && |
| git notes prune -v > actual && |
| test_cmp expect actual |
| ' |
| |
| test_expect_success 'verify that notes are gone' ' |
| |
| test_must_fail git notes show $third && |
| test_must_fail git notes show $second && |
| git notes show $first |
| ' |
| |
| test_done |