Merge branch 'jk/show-index'
[git] / t / t3306-notes-prune.sh
1 #!/bin/sh
2
3 test_description='Test git notes prune'
4
5 . ./test-lib.sh
6
7 test_expect_success 'setup: create a few commits with notes' '
8
9         : > file1 &&
10         git add file1 &&
11         test_tick &&
12         git commit -m 1st &&
13         git notes add -m "Note #1" &&
14         : > file2 &&
15         git add file2 &&
16         test_tick &&
17         git commit -m 2nd &&
18         git notes add -m "Note #2" &&
19         : > file3 &&
20         git add file3 &&
21         test_tick &&
22         git commit -m 3rd &&
23         COMMIT_FILE=.git/objects/5e/e1c35e83ea47cd3cc4f8cbee0568915fbbbd29 &&
24         test -f $COMMIT_FILE &&
25         test-tool chmtime =+0 $COMMIT_FILE &&
26         git notes add -m "Note #3"
27 '
28
29 cat > expect <<END_OF_LOG
30 commit 5ee1c35e83ea47cd3cc4f8cbee0568915fbbbd29
31 Author: A U Thor <author@example.com>
32 Date:   Thu Apr 7 15:15:13 2005 -0700
33
34     3rd
35
36 Notes:
37     Note #3
38
39 commit 08341ad9e94faa089d60fd3f523affb25c6da189
40 Author: A U Thor <author@example.com>
41 Date:   Thu Apr 7 15:14:13 2005 -0700
42
43     2nd
44
45 Notes:
46     Note #2
47
48 commit ab5f302035f2e7aaf04265f08b42034c23256e1f
49 Author: A U Thor <author@example.com>
50 Date:   Thu Apr 7 15:13:13 2005 -0700
51
52     1st
53
54 Notes:
55     Note #1
56 END_OF_LOG
57
58 test_expect_success 'verify commits and notes' '
59
60         git log > actual &&
61         test_cmp expect actual
62 '
63
64 test_expect_success 'remove some commits' '
65
66         git reset --hard HEAD~1 &&
67         git reflog expire --expire=now HEAD &&
68         git gc --prune=now
69 '
70
71 test_expect_success 'verify that commits are gone' '
72
73         test_must_fail git cat-file -p 5ee1c35e83ea47cd3cc4f8cbee0568915fbbbd29 &&
74         git cat-file -p 08341ad9e94faa089d60fd3f523affb25c6da189 &&
75         git cat-file -p ab5f302035f2e7aaf04265f08b42034c23256e1f
76 '
77
78 test_expect_success 'verify that notes are still present' '
79
80         git notes show 5ee1c35e83ea47cd3cc4f8cbee0568915fbbbd29 &&
81         git notes show 08341ad9e94faa089d60fd3f523affb25c6da189 &&
82         git notes show ab5f302035f2e7aaf04265f08b42034c23256e1f
83 '
84
85 test_expect_success 'prune -n does not remove notes' '
86
87         git notes list > expect &&
88         git notes prune -n &&
89         git notes list > actual &&
90         test_cmp expect actual
91 '
92
93 cat > expect <<EOF
94 5ee1c35e83ea47cd3cc4f8cbee0568915fbbbd29
95 EOF
96
97 test_expect_success 'prune -n lists prunable notes' '
98
99
100         git notes prune -n > actual &&
101         test_cmp expect actual
102 '
103
104
105 test_expect_success 'prune notes' '
106
107         git notes prune
108 '
109
110 test_expect_success 'verify that notes are gone' '
111
112         test_must_fail git notes show 5ee1c35e83ea47cd3cc4f8cbee0568915fbbbd29 &&
113         git notes show 08341ad9e94faa089d60fd3f523affb25c6da189 &&
114         git notes show ab5f302035f2e7aaf04265f08b42034c23256e1f
115 '
116
117 test_expect_success 'remove some commits' '
118
119         git reset --hard HEAD~1 &&
120         git reflog expire --expire=now HEAD &&
121         git gc --prune=now
122 '
123
124 cat > expect <<EOF
125 08341ad9e94faa089d60fd3f523affb25c6da189
126 EOF
127
128 test_expect_success 'prune -v notes' '
129
130         git notes prune -v > actual &&
131         test_cmp expect actual
132 '
133
134 test_expect_success 'verify that notes are gone' '
135
136         test_must_fail git notes show 5ee1c35e83ea47cd3cc4f8cbee0568915fbbbd29 &&
137         test_must_fail git notes show 08341ad9e94faa089d60fd3f523affb25c6da189 &&
138         git notes show ab5f302035f2e7aaf04265f08b42034c23256e1f
139 '
140
141 test_done