#!/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 &&
git commit -m 2nd &&
git notes add -m "Note #2" &&
second=$(git rev-parse HEAD) &&
: > file3 &&
git add file3 &&
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
Date: Thu Apr 7 15:14:13 2005 -0700
2nd
Note #2
commit $first
Date: Thu Apr 7 15:13:13 2005 -0700
1st
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_expect_success 'prune -n lists prunable notes' '
echo $third >expect &&
git notes prune -n > actual &&
test_expect_success 'prune notes' '
git notes prune
test_expect_success 'verify that notes are gone' '
test_must_fail git notes show $third &&
test_expect_success 'prune -v notes' '
echo $second >expect &&
git notes prune -v > actual &&
test_must_fail git notes show $second &&
test_done