e3b02bc953
On systems where the local time and file modification time may be out of sync (e.g. test directory on NFS) t3306 and t5305 can fail because prune compares times such as "now" (client time) with file modification times (server times for remote file systems). I.e., these are spurious test failures. Avoid this by setting the relevant modification times to the local time. Noticed on a system with as little as 2s time skew. Signed-off-by: Michael J Gruber <git@drmicha.warpmail.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
142 lines
2.9 KiB
Bash
Executable File
142 lines
2.9 KiB
Bash
Executable File
#!/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" &&
|
|
: > file2 &&
|
|
git add file2 &&
|
|
test_tick &&
|
|
git commit -m 2nd &&
|
|
git notes add -m "Note #2" &&
|
|
: > file3 &&
|
|
git add file3 &&
|
|
test_tick &&
|
|
git commit -m 3rd &&
|
|
COMMIT_FILE=.git/objects/5e/e1c35e83ea47cd3cc4f8cbee0568915fbbbd29 &&
|
|
test -f $COMMIT_FILE &&
|
|
test-chmtime =+0 $COMMIT_FILE &&
|
|
git notes add -m "Note #3"
|
|
'
|
|
|
|
cat > expect <<END_OF_LOG
|
|
commit 5ee1c35e83ea47cd3cc4f8cbee0568915fbbbd29
|
|
Author: A U Thor <author@example.com>
|
|
Date: Thu Apr 7 15:15:13 2005 -0700
|
|
|
|
3rd
|
|
|
|
Notes:
|
|
Note #3
|
|
|
|
commit 08341ad9e94faa089d60fd3f523affb25c6da189
|
|
Author: A U Thor <author@example.com>
|
|
Date: Thu Apr 7 15:14:13 2005 -0700
|
|
|
|
2nd
|
|
|
|
Notes:
|
|
Note #2
|
|
|
|
commit ab5f302035f2e7aaf04265f08b42034c23256e1f
|
|
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 5ee1c35e83ea47cd3cc4f8cbee0568915fbbbd29 &&
|
|
git cat-file -p 08341ad9e94faa089d60fd3f523affb25c6da189 &&
|
|
git cat-file -p ab5f302035f2e7aaf04265f08b42034c23256e1f
|
|
'
|
|
|
|
test_expect_success 'verify that notes are still present' '
|
|
|
|
git notes show 5ee1c35e83ea47cd3cc4f8cbee0568915fbbbd29 &&
|
|
git notes show 08341ad9e94faa089d60fd3f523affb25c6da189 &&
|
|
git notes show ab5f302035f2e7aaf04265f08b42034c23256e1f
|
|
'
|
|
|
|
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
|
|
'
|
|
|
|
cat > expect <<EOF
|
|
5ee1c35e83ea47cd3cc4f8cbee0568915fbbbd29
|
|
EOF
|
|
|
|
test_expect_success 'prune -n lists prunable notes' '
|
|
|
|
|
|
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 5ee1c35e83ea47cd3cc4f8cbee0568915fbbbd29 &&
|
|
git notes show 08341ad9e94faa089d60fd3f523affb25c6da189 &&
|
|
git notes show ab5f302035f2e7aaf04265f08b42034c23256e1f
|
|
'
|
|
|
|
test_expect_success 'remove some commits' '
|
|
|
|
git reset --hard HEAD~1 &&
|
|
git reflog expire --expire=now HEAD &&
|
|
git gc --prune=now
|
|
'
|
|
|
|
cat > expect <<EOF
|
|
08341ad9e94faa089d60fd3f523affb25c6da189
|
|
EOF
|
|
|
|
test_expect_success 'prune -v notes' '
|
|
|
|
git notes prune -v > actual &&
|
|
test_cmp expect actual
|
|
'
|
|
|
|
test_expect_success 'verify that notes are gone' '
|
|
|
|
test_must_fail git notes show 5ee1c35e83ea47cd3cc4f8cbee0568915fbbbd29 &&
|
|
test_must_fail git notes show 08341ad9e94faa089d60fd3f523affb25c6da189 &&
|
|
git notes show ab5f302035f2e7aaf04265f08b42034c23256e1f
|
|
'
|
|
|
|
test_done
|