Merge branch 'kw/fsmonitor-watchman-fix'
[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         first=$(git rev-parse HEAD) &&
15         : > file2 &&
16         git add file2 &&
17         test_tick &&
18         git commit -m 2nd &&
19         git notes add -m "Note #2" &&
20         second=$(git rev-parse HEAD) &&
21         : > file3 &&
22         git add file3 &&
23         test_tick &&
24         git commit -m 3rd &&
25         third=$(git rev-parse HEAD) &&
26         COMMIT_FILE=$(echo $third | sed "s!^..!.git/objects/&/!") &&
27         test -f $COMMIT_FILE &&
28         test-tool chmtime =+0 $COMMIT_FILE &&
29         git notes add -m "Note #3"
30 '
31
32 cat > expect <<END_OF_LOG
33 commit $third
34 Author: A U Thor <author@example.com>
35 Date:   Thu Apr 7 15:15:13 2005 -0700
36
37     3rd
38
39 Notes:
40     Note #3
41
42 commit $second
43 Author: A U Thor <author@example.com>
44 Date:   Thu Apr 7 15:14:13 2005 -0700
45
46     2nd
47
48 Notes:
49     Note #2
50
51 commit $first
52 Author: A U Thor <author@example.com>
53 Date:   Thu Apr 7 15:13:13 2005 -0700
54
55     1st
56
57 Notes:
58     Note #1
59 END_OF_LOG
60
61 test_expect_success 'verify commits and notes' '
62
63         git log > actual &&
64         test_cmp expect actual
65 '
66
67 test_expect_success 'remove some commits' '
68
69         git reset --hard HEAD~1 &&
70         git reflog expire --expire=now HEAD &&
71         git gc --prune=now
72 '
73
74 test_expect_success 'verify that commits are gone' '
75
76         test_must_fail git cat-file -p $third &&
77         git cat-file -p $second &&
78         git cat-file -p $first
79 '
80
81 test_expect_success 'verify that notes are still present' '
82
83         git notes show $third &&
84         git notes show $second &&
85         git notes show $first
86 '
87
88 test_expect_success 'prune -n does not remove notes' '
89
90         git notes list > expect &&
91         git notes prune -n &&
92         git notes list > actual &&
93         test_cmp expect actual
94 '
95
96
97 test_expect_success 'prune -n lists prunable notes' '
98
99         echo $third >expect &&
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 $third &&
113         git notes show $second &&
114         git notes show $first
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 test_expect_success 'prune -v notes' '
125
126         echo $second >expect &&
127         git notes prune -v > actual &&
128         test_cmp expect actual
129 '
130
131 test_expect_success 'verify that notes are gone' '
132
133         test_must_fail git notes show $third &&
134         test_must_fail git notes show $second &&
135         git notes show $first
136 '
137
138 test_done