Refactor notes concatenation into a flexible interface for combining notes
[git/mjg.git] / t / t3301-notes.sh
blob18aad5389913f5a2cfe24c7a25b2679c453ceaf8
1 #!/bin/sh
3 # Copyright (c) 2007 Johannes E. Schindelin
6 test_description='Test commit notes'
8 . ./test-lib.sh
10 cat > fake_editor.sh << \EOF
11 echo "$MSG" > "$1"
12 echo "$MSG" >& 2
13 EOF
14 chmod a+x fake_editor.sh
15 VISUAL=./fake_editor.sh
16 export VISUAL
18 test_expect_success 'cannot annotate non-existing HEAD' '
19 (MSG=3 && export MSG && test_must_fail git notes edit)
22 test_expect_success setup '
23 : > a1 &&
24 git add a1 &&
25 test_tick &&
26 git commit -m 1st &&
27 : > a2 &&
28 git add a2 &&
29 test_tick &&
30 git commit -m 2nd
33 test_expect_success 'need valid notes ref' '
34 (MSG=1 GIT_NOTES_REF=/ && export MSG GIT_NOTES_REF &&
35 test_must_fail git notes edit) &&
36 (MSG=2 GIT_NOTES_REF=/ && export MSG GIT_NOTES_REF &&
37 test_must_fail git notes show)
40 test_expect_success 'refusing to edit in refs/heads/' '
41 (MSG=1 GIT_NOTES_REF=refs/heads/bogus &&
42 export MSG GIT_NOTES_REF &&
43 test_must_fail git notes edit)
46 test_expect_success 'refusing to edit in refs/remotes/' '
47 (MSG=1 GIT_NOTES_REF=refs/remotes/bogus &&
48 export MSG GIT_NOTES_REF &&
49 test_must_fail git notes edit)
52 # 1 indicates caught gracefully by die, 128 means git-show barked
53 test_expect_success 'handle empty notes gracefully' '
54 git notes show ; test 1 = $?
57 test_expect_success 'create notes' '
58 git config core.notesRef refs/notes/commits &&
59 MSG=b1 git notes edit &&
60 test ! -f .git/new-notes &&
61 test 1 = $(git ls-tree refs/notes/commits | wc -l) &&
62 test b1 = $(git notes show) &&
63 git show HEAD^ &&
64 test_must_fail git notes show HEAD^
67 cat > expect << EOF
68 commit 268048bfb8a1fb38e703baceb8ab235421bf80c5
69 Author: A U Thor <author@example.com>
70 Date: Thu Apr 7 15:14:13 2005 -0700
72 2nd
74 Notes:
76 EOF
78 test_expect_success 'show notes' '
79 ! (git cat-file commit HEAD | grep b1) &&
80 git log -1 > output &&
81 test_cmp expect output
83 test_expect_success 'create multi-line notes (setup)' '
84 : > a3 &&
85 git add a3 &&
86 test_tick &&
87 git commit -m 3rd &&
88 MSG="b3
89 c3c3c3c3
90 d3d3d3" git notes edit
93 cat > expect-multiline << EOF
94 commit 1584215f1d29c65e99c6c6848626553fdd07fd75
95 Author: A U Thor <author@example.com>
96 Date: Thu Apr 7 15:15:13 2005 -0700
98 3rd
100 Notes:
102 c3c3c3c3
103 d3d3d3
106 printf "\n" >> expect-multiline
107 cat expect >> expect-multiline
109 test_expect_success 'show multi-line notes' '
110 git log -2 > output &&
111 test_cmp expect-multiline output
113 test_expect_success 'create -m and -F notes (setup)' '
114 : > a4 &&
115 git add a4 &&
116 test_tick &&
117 git commit -m 4th &&
118 echo "xyzzy" > note5 &&
119 git notes edit -m spam -F note5 -m "foo
121 baz"
124 whitespace=" "
125 cat > expect-m-and-F << EOF
126 commit 15023535574ded8b1a89052b32673f84cf9582b8
127 Author: A U Thor <author@example.com>
128 Date: Thu Apr 7 15:16:13 2005 -0700
132 Notes:
133 spam
134 $whitespace
135 xyzzy
136 $whitespace
142 printf "\n" >> expect-m-and-F
143 cat expect-multiline >> expect-m-and-F
145 test_expect_success 'show -m and -F notes' '
146 git log -3 > output &&
147 test_cmp expect-m-and-F output
150 cat >expect << EOF
151 commit 15023535574ded8b1a89052b32673f84cf9582b8
152 tree e070e3af51011e47b183c33adf9736736a525709
153 parent 1584215f1d29c65e99c6c6848626553fdd07fd75
154 author A U Thor <author@example.com> 1112912173 -0700
155 committer C O Mitter <committer@example.com> 1112912173 -0700
159 test_expect_success 'git log --pretty=raw does not show notes' '
160 git log -1 --pretty=raw >output &&
161 test_cmp expect output
164 cat >>expect <<EOF
166 Notes:
167 spam
168 $whitespace
169 xyzzy
170 $whitespace
175 test_expect_success 'git log --show-notes' '
176 git log -1 --pretty=raw --show-notes >output &&
177 test_cmp expect output
180 test_expect_success 'git log --no-notes' '
181 git log -1 --no-notes >output &&
182 ! grep spam output
185 test_expect_success 'git format-patch does not show notes' '
186 git format-patch -1 --stdout >output &&
187 ! grep spam output
190 test_expect_success 'git format-patch --show-notes does show notes' '
191 git format-patch --show-notes -1 --stdout >output &&
192 grep spam output
195 for pretty in \
196 "" --pretty --pretty=raw --pretty=short --pretty=medium \
197 --pretty=full --pretty=fuller --pretty=format:%s --oneline
199 case "$pretty" in
200 "") p= not= negate="" ;;
201 ?*) p="$pretty" not=" not" negate="!" ;;
202 esac
203 test_expect_success "git show $pretty does$not show notes" '
204 git show $p >output &&
205 eval "$negate grep spam output"
207 done
209 test_expect_success 'create other note on a different notes ref (setup)' '
210 : > a5 &&
211 git add a5 &&
212 test_tick &&
213 git commit -m 5th &&
214 GIT_NOTES_REF="refs/notes/other" git notes edit -m "other note"
217 cat > expect-other << EOF
218 commit bd1753200303d0a0344be813e504253b3d98e74d
219 Author: A U Thor <author@example.com>
220 Date: Thu Apr 7 15:17:13 2005 -0700
224 Notes:
225 other note
228 cat > expect-not-other << EOF
229 commit bd1753200303d0a0344be813e504253b3d98e74d
230 Author: A U Thor <author@example.com>
231 Date: Thu Apr 7 15:17:13 2005 -0700
236 test_expect_success 'Do not show note on other ref by default' '
237 git log -1 > output &&
238 test_cmp expect-not-other output
241 test_expect_success 'Do show note when ref is given in GIT_NOTES_REF' '
242 GIT_NOTES_REF="refs/notes/other" git log -1 > output &&
243 test_cmp expect-other output
246 test_expect_success 'Do show note when ref is given in core.notesRef config' '
247 git config core.notesRef "refs/notes/other" &&
248 git log -1 > output &&
249 test_cmp expect-other output
252 test_expect_success 'Do not show note when core.notesRef is overridden' '
253 GIT_NOTES_REF="refs/notes/wrong" git log -1 > output &&
254 test_cmp expect-not-other output
257 test_done