my first thought was that this might be a bash versioning issue, since
the commit in question basically refactors the script, and macs ship
with an archaic version of bash, but I have the same problem with bash
4.3.30

On Mon, Nov 10, 2014 at 4:23 PM, Michael Blume <blume.m...@gmail.com> wrote:
> (to be clear: I ran git bisect, and traced the problem to the modernize 
> commit)
>
> On Mon, Nov 10, 2014 at 4:17 PM, Michael Blume <blume.m...@gmail.com> wrote:
>> the commit modernizing test 3301
>> (https://github.com/git/git/commit/fbe4f74865acfd) appears to break it
>> on my mac
>>
>> Verbose output follows:
>>
>> $ ./t3301-notes.sh -v
>> Initialized empty Git repository in
>> /Users/michael.blume/workspace/git/t/trash directory.t3301-notes/.git/
>> expecting success:
>> test_must_fail env MSG=3 git notes add
>>
>> fatal: Failed to resolve 'HEAD' as a valid ref.
>> ok 1 - cannot annotate non-existing HEAD
>>
>> expecting success:
>> test_commit 1st &&
>> test_commit 2nd
>>
>> [master (root-commit) 04ed9a0] 1st
>>  Author: A U Thor <aut...@example.com>
>>  1 file changed, 1 insertion(+)
>>  create mode 100644 1st.t
>> [master 7a4ca6e] 2nd
>>  Author: A U Thor <aut...@example.com>
>>  1 file changed, 1 insertion(+)
>>  create mode 100644 2nd.t
>> ok 2 - setup
>>
>> expecting success:
>> test_must_fail env MSG=1 GIT_NOTES_REF=/ git notes show &&
>> test_must_fail env MSG=2 GIT_NOTES_REF=/ git notes show
>>
>> fatal: Refusing to show notes in / (outside of refs/notes/)
>> fatal: Refusing to show notes in / (outside of refs/notes/)
>> ok 3 - need valid notes ref
>>
>> expecting success:
>> test_must_fail env MSG=1 GIT_NOTES_REF=refs/heads/bogus git notes add
>>
>> fatal: Refusing to add notes in refs/heads/bogus (outside of refs/notes/)
>> ok 4 - refusing to add notes in refs/heads/
>>
>> expecting success:
>> test_must_fail env MSG=1 GIT_NOTES_REF=refs/heads/bogus git notes edit
>>
>> fatal: Refusing to edit notes in refs/heads/bogus (outside of refs/notes/)
>> ok 5 - refusing to edit notes in refs/remotes/
>>
>> expecting success:
>> test_expect_code 1 git notes show
>>
>> error: No note found for object 7a4ca6ee52a974a66cbaa78e33214535dff1d691.
>> ok 6 - handle empty notes gracefully
>>
>> expecting success:
>> test_write_lines A B >expect &&
>> git show -s --format="A%n%NB" >output &&
>> test_cmp expect output
>>
>> ok 7 - show non-existent notes entry with %N
>>
>> expecting success:
>> MSG=b4 git notes add &&
>> test_path_is_missing .git/NOTES_EDITMSG &&
>> test "1" = "$(git ls-tree refs/notes/commits | wc -l)" &&
>> test "b4" = "$(git notes show)" &&
>> git show HEAD^ &&
>> test_must_fail git notes show HEAD^
>>
>> b4
>> not ok 8 - create notes
>> #
>> # MSG=b4 git notes add &&
>> # test_path_is_missing .git/NOTES_EDITMSG &&
>> # test "1" = "$(git ls-tree refs/notes/commits | wc -l)" &&
>> # test "b4" = "$(git notes show)" &&
>> # git show HEAD^ &&
>> # test_must_fail git notes show HEAD^
>> #
>>
>> expecting success:
>> test_write_lines A b4 B >expect &&
>> git show -s --format="A%n%NB" >output &&
>> test_cmp expect output
>>
>> ok 9 - show notes entry with %N
>>
>> expecting success:
>> cat <<-EOF >expect &&
>> a1d8fa6 refs/notes/commits@{0}: notes: Notes added by 'git notes add'
>> EOF
>> git reflog show refs/notes/commits >output &&
>> test_cmp expect output
>>
>> ok 10 - create reflog entry
>>
>> expecting success:
>> MSG=b3 git notes edit &&
>> test_path_is_missing .git/NOTES_EDITMSG &&
>> test "1" = "$(git ls-tree refs/notes/commits | wc -l)" &&
>> test "b3" = "$(git notes show)" &&
>> git show HEAD^ &&
>> test_must_fail git notes show HEAD^
>>
>> b3
>> not ok 11 - edit existing notes
>> #
>> # MSG=b3 git notes edit &&
>> # test_path_is_missing .git/NOTES_EDITMSG &&
>> # test "1" = "$(git ls-tree refs/notes/commits | wc -l)" &&
>> # test "b3" = "$(git notes show)" &&
>> # git show HEAD^ &&
>> # test_must_fail git notes show HEAD^
>> #
>>
>> expecting success:
>> test_must_fail git notes add -m "b2" &&
>> test_path_is_missing .git/NOTES_EDITMSG &&
>> test "1" = "$(git ls-tree refs/notes/commits | wc -l)" &&
>> test "b3" = "$(git notes show)" &&
>> git show HEAD^ &&
>> test_must_fail git notes show HEAD^
>>
>> error: Cannot add notes. Found existing notes for object
>> 7a4ca6ee52a974a66cbaa78e33214535dff1d691. Use '-f' to overwrite
>> existing notes
>> not ok 12 - cannot "git notes add -m" where notes already exists
>> #
>> # test_must_fail git notes add -m "b2" &&
>> # test_path_is_missing .git/NOTES_EDITMSG &&
>> # test "1" = "$(git ls-tree refs/notes/commits | wc -l)" &&
>> # test "b3" = "$(git notes show)" &&
>> # git show HEAD^ &&
>> # test_must_fail git notes show HEAD^
>> #
>>
>> expecting success:
>> git notes add -f -m "b1" &&
>> test_path_is_missing .git/NOTES_EDITMSG &&
>> test "1" = "$(git ls-tree refs/notes/commits | wc -l)" &&
>> test "b1" = "$(git notes show)" &&
>> git show HEAD^ &&
>> test_must_fail git notes show HEAD^
>>
>> Overwriting existing notes for object 
>> 7a4ca6ee52a974a66cbaa78e33214535dff1d691
>> not ok 13 - can overwrite existing note with "git notes add -f -m"
>> #
>> # git notes add -f -m "b1" &&
>> # test_path_is_missing .git/NOTES_EDITMSG &&
>> # test "1" = "$(git ls-tree refs/notes/commits | wc -l)" &&
>> # test "b1" = "$(git notes show)" &&
>> # git show HEAD^ &&
>> # test_must_fail git notes show HEAD^
>> #
>>
>> expecting success:
>> MSG=b2 git notes add &&
>> test_path_is_missing .git/NOTES_EDITMSG &&
>> test "1" = "$(git ls-tree refs/notes/commits | wc -l)" &&
>> test "b2" = "$(git notes show)" &&
>> git show HEAD^ &&
>> test_must_fail git notes show HEAD^
>>
>> b2
>> not ok 14 - add w/no options on existing note morphs into edit
>> #
>> # MSG=b2 git notes add &&
>> # test_path_is_missing .git/NOTES_EDITMSG &&
>> # test "1" = "$(git ls-tree refs/notes/commits | wc -l)" &&
>> # test "b2" = "$(git notes show)" &&
>> # git show HEAD^ &&
>> # test_must_fail git notes show HEAD^
>> #
>>
>> expecting success:
>> MSG=b1 git notes add -f &&
>> test_path_is_missing .git/NOTES_EDITMSG &&
>> test "1" = "$(git ls-tree refs/notes/commits | wc -l)" &&
>> test "b1" = "$(git notes show)" &&
>> git show HEAD^ &&
>> test_must_fail git notes show HEAD^
>>
>> Overwriting existing notes for object 
>> 7a4ca6ee52a974a66cbaa78e33214535dff1d691
>> b1
>> not ok 15 - can overwrite existing note with "git notes add -f"
>> #
>> # MSG=b1 git notes add -f &&
>> # test_path_is_missing .git/NOTES_EDITMSG &&
>> # test "1" = "$(git ls-tree refs/notes/commits | wc -l)" &&
>> # test "b1" = "$(git notes show)" &&
>> # git show HEAD^ &&
>> # test_must_fail git notes show HEAD^
>> #
>>
>> expecting success:
>> cat >expect <<-EOF &&
>> commit 7a4ca6ee52a974a66cbaa78e33214535dff1d691
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:14:13 2005 -0700
>>
>> ${indent}2nd
>>
>> Notes:
>> ${indent}b1
>> EOF
>> ! (git cat-file commit HEAD | grep b1) &&
>> git log -1 >output &&
>> test_cmp expect output
>>
>> ok 16 - show notes
>>
>> expecting success:
>> test_commit 3rd &&
>> MSG="b3${LF}c3c3c3c3${LF}d3d3d3" git notes add &&
>> cat >expect-multiline <<-EOF &&
>> commit d07d62e5208f22eb5695e7eb47667dc8b9860290
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:15:13 2005 -0700
>>
>> ${indent}3rd
>>
>> Notes:
>> ${indent}b3
>> ${indent}c3c3c3c3
>> ${indent}d3d3d3
>>
>> EOF
>> cat expect >>expect-multiline &&
>> git log -2 >output &&
>> test_cmp expect-multiline output
>>
>> [master d07d62e] 3rd
>>  Author: A U Thor <aut...@example.com>
>>  1 file changed, 1 insertion(+)
>>  create mode 100644 3rd.t
>> b3
>> c3c3c3c3
>> d3d3d3
>> ok 17 - show multi-line notes
>>
>> expecting success:
>> test_commit 4th &&
>> echo "xyzzy" >note5 &&
>> git notes add -F note5 &&
>> cat >expect-F <<-EOF &&
>> commit 0f7aa3ec6325aeb88b910453bb3eb37c49d75c11
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:16:13 2005 -0700
>>
>> ${indent}4th
>>
>> Notes:
>> ${indent}xyzzy
>>
>> EOF
>> cat expect-multiline >>expect-F &&
>> git log -3 >output &&
>> test_cmp expect-F output
>>
>> [master 0f7aa3e] 4th
>>  Author: A U Thor <aut...@example.com>
>>  1 file changed, 1 insertion(+)
>>  create mode 100644 4th.t
>> ok 18 - show -F notes
>>
>> expecting success:
>> echo "zyxxy" >note5 &&
>> test_must_fail git notes add -F note5 &&
>> git log -3 >output &&
>> test_cmp expect-F output
>>
>> error: Cannot add notes. Found existing notes for object
>> 0f7aa3ec6325aeb88b910453bb3eb37c49d75c11. Use '-f' to overwrite
>> existing notes
>> ok 19 - Re-adding -F notes without -f fails
>>
>> expecting success:
>> cat >expect <<-EOF &&
>> commit 0f7aa3ec6325aeb88b910453bb3eb37c49d75c11
>> tree 05ac65288c4c4b3b709a020ae94b2ece2f2201ae
>> parent d07d62e5208f22eb5695e7eb47667dc8b9860290
>> author A U Thor <aut...@example.com> 1112912173 -0700
>> committer C O Mitter <commit...@example.com> 1112912173 -0700
>>
>> ${indent}4th
>> EOF
>> git log -1 --pretty=raw >output &&
>> test_cmp expect output
>>
>> ok 20 - git log --pretty=raw does not show notes
>>
>> expecting success:
>> cat >>expect <<-EOF &&
>>
>> Notes:
>> ${indent}xyzzy
>> EOF
>> git log -1 --pretty=raw --show-notes >output &&
>> test_cmp expect output
>>
>> ok 21 - git log --show-notes
>>
>> expecting success:
>> git log -1 --no-notes >output &&
>> ! grep xyzzy output
>>
>> ok 22 - git log --no-notes
>>
>> expecting success:
>> git format-patch -1 --stdout >output &&
>> ! grep xyzzy output
>>
>> ok 23 - git format-patch does not show notes
>>
>> expecting success:
>> git format-patch --show-notes -1 --stdout >output &&
>> grep xyzzy output
>>
>>     xyzzy
>> ok 24 - git format-patch --show-notes does show notes
>>
>> expecting success:
>> git show $p >output &&
>> eval "$negate grep xyzzy output"
>>
>>     xyzzy
>> ok 25 - git show  does show notes
>>
>> expecting success:
>> git show $p >output &&
>> eval "$negate grep xyzzy output"
>>
>> ok 26 - git show --pretty does not show notes
>>
>> expecting success:
>> git show $p >output &&
>> eval "$negate grep xyzzy output"
>>
>> ok 27 - git show --pretty=raw does not show notes
>>
>> expecting success:
>> git show $p >output &&
>> eval "$negate grep xyzzy output"
>>
>> ok 28 - git show --pretty=short does not show notes
>>
>> expecting success:
>> git show $p >output &&
>> eval "$negate grep xyzzy output"
>>
>> ok 29 - git show --pretty=medium does not show notes
>>
>> expecting success:
>> git show $p >output &&
>> eval "$negate grep xyzzy output"
>>
>> ok 30 - git show --pretty=full does not show notes
>>
>> expecting success:
>> git show $p >output &&
>> eval "$negate grep xyzzy output"
>>
>> ok 31 - git show --pretty=fuller does not show notes
>>
>> expecting success:
>> git show $p >output &&
>> eval "$negate grep xyzzy output"
>>
>> ok 32 - git show --pretty=format:%s does not show notes
>>
>> expecting success:
>> git show $p >output &&
>> eval "$negate grep xyzzy output"
>>
>> ok 33 - git show --oneline does not show notes
>>
>> expecting success:
>> git notes --ref=alternate add -m alternate
>>
>> ok 34 - setup alternate notes ref
>>
>> expecting success:
>> git log -1 --notes >output &&
>> grep xyzzy output &&
>> ! grep alternate output
>>
>>     xyzzy
>> ok 35 - git log --notes shows default notes
>>
>> expecting success:
>> git log -1 --notes=alternate >output &&
>> ! grep xyzzy output &&
>> grep alternate output
>>
>> Notes (alternate):
>>     alternate
>> ok 36 - git log --notes=X shows only X
>>
>> expecting success:
>> git log -1 --notes --notes=alternate >output &&
>> grep xyzzy output &&
>> grep alternate output
>>
>>     xyzzy
>> Notes (alternate):
>>     alternate
>> ok 37 - git log --notes --notes=X shows both
>>
>> expecting success:
>> git log -1 --notes --notes=alternate \
>> --no-notes --notes=alternate \
>>>output &&
>> ! grep xyzzy output &&
>> grep alternate output
>>
>> Notes (alternate):
>>     alternate
>> ok 38 - git log --no-notes resets default state
>>
>> expecting success:
>> git log -1 --notes --notes=alternate \
>> --no-notes --notes \
>>>output &&
>> grep xyzzy output &&
>> ! grep alternate output
>>
>>     xyzzy
>> ok 39 - git log --no-notes resets ref list
>>
>> expecting success:
>> test_commit 5th &&
>> git notes add -m spam -m "foo${LF}bar${LF}baz" &&
>> cat >expect-m <<-EOF &&
>> commit 7f9ad8836c775acb134c0a055fc55fb4cd1ba361
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:17:13 2005 -0700
>>
>> ${indent}5th
>>
>> Notes:
>> ${indent}spam
>> ${indent}
>> ${indent}foo
>> ${indent}bar
>> ${indent}baz
>>
>> EOF
>> cat expect-F >>expect-m &&
>> git log -4 >output &&
>> test_cmp expect-m output
>>
>> [master 7f9ad88] 5th
>>  Author: A U Thor <aut...@example.com>
>>  1 file changed, 1 insertion(+)
>>  create mode 100644 5th.t
>> ok 40 - show -m notes
>>
>> expecting success:
>> git notes add -f -F /dev/null &&
>> cat >expect-rm-F <<-EOF &&
>> commit 7f9ad8836c775acb134c0a055fc55fb4cd1ba361
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:17:13 2005 -0700
>>
>> ${indent}5th
>>
>> EOF
>> cat expect-F >>expect-rm-F &&
>> git log -4 >output &&
>> test_cmp expect-rm-F output &&
>> test_must_fail git notes show
>>
>> Overwriting existing notes for object 
>> 7f9ad8836c775acb134c0a055fc55fb4cd1ba361
>> Removing note for object 7f9ad8836c775acb134c0a055fc55fb4cd1ba361
>> error: No note found for object 7f9ad8836c775acb134c0a055fc55fb4cd1ba361.
>> ok 41 - remove note with add -f -F /dev/null
>>
>> expecting success:
>> git notes add -m "" &&
>> git log -4 >output &&
>> test_cmp expect-rm-F output &&
>> test_must_fail git notes show
>>
>> Removing note for object 7f9ad8836c775acb134c0a055fc55fb4cd1ba361
>> error: No note found for object 7f9ad8836c775acb134c0a055fc55fb4cd1ba361.
>> ok 42 - do not create empty note with -m ""
>>
>> expecting success:
>> cat >expect-combine_m_and_F <<-EOF &&
>> foo
>>
>> xyzzy
>>
>> bar
>>
>> zyxxy
>>
>> baz
>> EOF
>> echo "xyzzy" >note_a &&
>> echo "zyxxy" >note_b &&
>> git notes add -m "foo" -F note_a -m "bar" -F note_b -m "baz" &&
>> git notes show >output &&
>> test_cmp expect-combine_m_and_F output
>>
>> ok 43 - create note with combination of -m and -F
>>
>> expecting success:
>> git notes remove HEAD^ &&
>> git notes remove &&
>> cat >expect-rm-remove <<-EOF &&
>> commit 7f9ad8836c775acb134c0a055fc55fb4cd1ba361
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:17:13 2005 -0700
>>
>> ${indent}5th
>>
>> commit 0f7aa3ec6325aeb88b910453bb3eb37c49d75c11
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:16:13 2005 -0700
>>
>> ${indent}4th
>>
>> EOF
>> cat expect-multiline >>expect-rm-remove &&
>> git log -4 >output &&
>> test_cmp expect-rm-remove output &&
>> test_must_fail git notes show HEAD^
>>
>> Removing note for object HEAD^
>> Removing note for object HEAD
>> error: No note found for object 0f7aa3ec6325aeb88b910453bb3eb37c49d75c11.
>> ok 44 - remove note with "git notes remove"
>>
>> expecting success:
>> git rev-parse --verify refs/notes/commits >before_commit &&
>> test_must_fail git notes remove HEAD^ &&
>> git rev-parse --verify refs/notes/commits >after_commit &&
>> test_cmp before_commit after_commit
>>
>> Object HEAD^ has no note
>> ok 45 - removing non-existing note should not create new commit
>>
>> expecting success:
>> before=$(git rev-parse --verify refs/notes/commits) &&
>> test_when_finished "git update-ref refs/notes/commits $before" &&
>>
>> # We have only two -- add another and make sure it stays
>> git notes add -m "extra" &&
>> git notes list HEAD >after-removal-expect &&
>> git notes remove HEAD^^ HEAD^^^ &&
>> git notes list | sed -e "s/ .*//" >actual &&
>> test_cmp after-removal-expect actual
>>
>> Removing note for object HEAD^^
>> Removing note for object HEAD^^^
>> ok 46 - removing more than one
>>
>> expecting success:
>> before=$(git rev-parse --verify refs/notes/commits) &&
>> test_when_finished "git update-ref refs/notes/commits $before" &&
>> test_must_fail git notes remove HEAD^^ HEAD^^^ HEAD^ &&
>> after=$(git rev-parse --verify refs/notes/commits) &&
>> test "$before" = "$after"
>>
>> Removing note for object HEAD^^
>> Removing note for object HEAD^^^
>> Object HEAD^ has no note
>> ok 47 - removing is atomic
>>
>> expecting success:
>> before=$(git rev-parse --verify refs/notes/commits) &&
>> test_when_finished "git update-ref refs/notes/commits $before" &&
>>
>> # We have only two -- add another and make sure it stays
>> git notes add -m "extra" &&
>> git notes list HEAD >after-removal-expect &&
>> git notes remove --ignore-missing HEAD^^ HEAD^^^ HEAD^ &&
>> git notes list | sed -e "s/ .*//" >actual &&
>> test_cmp after-removal-expect actual
>>
>> Removing note for object HEAD^^
>> Removing note for object HEAD^^^
>> Object HEAD^ has no note
>> ok 48 - removing with --ignore-missing
>>
>> expecting success:
>> before=$(git rev-parse --verify refs/notes/commits) &&
>> test_when_finished "git update-ref refs/notes/commits $before" &&
>> test_must_fail git notes remove --ignore-missing HEAD^^ HEAD^^^
>> NO-SUCH-COMMIT &&
>> after=$(git rev-parse --verify refs/notes/commits) &&
>> test "$before" = "$after"
>>
>> Removing note for object HEAD^^
>> Removing note for object HEAD^^^
>> error: Failed to resolve 'NO-SUCH-COMMIT' as a valid ref.
>> ok 49 - removing with --ignore-missing but bogus ref
>>
>> expecting success:
>> before=$(git rev-parse --verify refs/notes/commits) &&
>> test_when_finished "git update-ref refs/notes/commits $before" &&
>>
>> # We have only two -- add another and make sure it stays
>> git notes add -m "extra" &&
>> git notes list HEAD >after-removal-expect &&
>> git rev-parse HEAD^^ HEAD^^^ >input &&
>> git notes remove --stdin <input &&
>> git notes list | sed -e "s/ .*//" >actual &&
>> test_cmp after-removal-expect actual
>>
>> Removing note for object d07d62e5208f22eb5695e7eb47667dc8b9860290
>> Removing note for object 7a4ca6ee52a974a66cbaa78e33214535dff1d691
>> ok 50 - remove reads from --stdin
>>
>> expecting success:
>> before=$(git rev-parse --verify refs/notes/commits) &&
>> test_when_finished "git update-ref refs/notes/commits $before" &&
>> git rev-parse HEAD^^ HEAD^^^ HEAD^ >input &&
>> test_must_fail git notes remove --stdin <input &&
>> after=$(git rev-parse --verify refs/notes/commits) &&
>> test "$before" = "$after"
>>
>> Removing note for object d07d62e5208f22eb5695e7eb47667dc8b9860290
>> Removing note for object 7a4ca6ee52a974a66cbaa78e33214535dff1d691
>> Object 0f7aa3ec6325aeb88b910453bb3eb37c49d75c11 has no note
>> ok 51 - remove --stdin is also atomic
>>
>> expecting success:
>> before=$(git rev-parse --verify refs/notes/commits) &&
>> test_when_finished "git update-ref refs/notes/commits $before" &&
>>
>> # We have only two -- add another and make sure it stays
>> git notes add -m "extra" &&
>> git notes list HEAD >after-removal-expect &&
>> git rev-parse HEAD^^ HEAD^^^ HEAD^ >input &&
>> git notes remove --ignore-missing --stdin <input &&
>> git notes list | sed -e "s/ .*//" >actual &&
>> test_cmp after-removal-expect actual
>>
>> Removing note for object d07d62e5208f22eb5695e7eb47667dc8b9860290
>> Removing note for object 7a4ca6ee52a974a66cbaa78e33214535dff1d691
>> Object 0f7aa3ec6325aeb88b910453bb3eb37c49d75c11 has no note
>> ok 52 - removing with --stdin --ignore-missing
>>
>> expecting success:
>> cat >expect <<-EOF &&
>> c9c6af7f78bc47490dbf3e822cf2f3c24d4b9061
>> 7a4ca6ee52a974a66cbaa78e33214535dff1d691
>> c18dc024e14f08d18d14eea0d747ff692d66d6a3
>> d07d62e5208f22eb5695e7eb47667dc8b9860290
>> EOF
>> git notes list >output &&
>> test_cmp expect output
>>
>> ok 53 - list notes with "git notes list"
>>
>> expecting success:
>> git notes >output &&
>> test_cmp expect output
>>
>> ok 54 - list notes with "git notes"
>>
>> expecting success:
>> cat >expect <<-EOF &&
>> c18dc024e14f08d18d14eea0d747ff692d66d6a3
>> EOF
>> git notes list HEAD^^ >output &&
>> test_cmp expect output
>>
>> ok 55 - list specific note with "git notes list <object>"
>>
>> expecting success:
>> cat >expect <<-EOF &&
>> EOF
>> test_must_fail git notes list HEAD >output &&
>> test_cmp expect output
>>
>> error: No note found for object 7f9ad8836c775acb134c0a055fc55fb4cd1ba361.
>> ok 56 - listing non-existing notes fails
>>
>> expecting success:
>> cat >expect <<-EOF &&
>> Initial set of notes
>>
>> More notes appended with git notes append
>> EOF
>> git notes add -m "Initial set of notes" &&
>> git notes append -m "More notes appended with git notes append" &&
>> git notes show >output &&
>> test_cmp expect output
>>
>> ok 57 - append to existing note with "git notes append"
>>
>> expecting success:
>> cat >expect_list <<-EOF &&
>> c9c6af7f78bc47490dbf3e822cf2f3c24d4b9061
>> 7a4ca6ee52a974a66cbaa78e33214535dff1d691
>> 4b6ad22357cc8a1296720574b8d2fbc22fab0671
>> 7f9ad8836c775acb134c0a055fc55fb4cd1ba361
>> c18dc024e14f08d18d14eea0d747ff692d66d6a3
>> d07d62e5208f22eb5695e7eb47667dc8b9860290
>> EOF
>> git notes list >output &&
>> test_cmp expect_list output
>>
>> ok 58 - "git notes list" does not expand to "git notes list HEAD"
>>
>> expecting success:
>> git notes append -m "" &&
>> git notes show >output &&
>> test_cmp expect output
>>
>> ok 59 - appending empty string does not change existing note
>>
>> expecting success:
>> git notes remove HEAD &&
>> test_must_fail git notes list HEAD &&
>> git notes append -m "Initial set of notes${LF}${LF}More notes appended
>> with git notes append" &&
>> git notes show >output &&
>> test_cmp expect output
>>
>> Removing note for object HEAD
>> error: No note found for object 7f9ad8836c775acb134c0a055fc55fb4cd1ba361.
>> ok 60 - git notes append == add when there is no existing note
>>
>> expecting success:
>> git notes remove HEAD &&
>> test_must_fail git notes list HEAD &&
>> git notes append -m "" &&
>> test_must_fail git notes list HEAD
>>
>> Removing note for object HEAD
>> error: No note found for object 7f9ad8836c775acb134c0a055fc55fb4cd1ba361.
>> Removing note for object 7f9ad8836c775acb134c0a055fc55fb4cd1ba361
>> error: No note found for object 7f9ad8836c775acb134c0a055fc55fb4cd1ba361.
>> ok 61 - appending empty string to non-existing note does not create note
>>
>> expecting success:
>> test_commit 6th &&
>> GIT_NOTES_REF="refs/notes/other" git notes add -m "other note" &&
>> cat >expect-not-other <<-EOF &&
>> commit 2c125331118caba0ff8238b7f4958ac6e93fe39c
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:18:13 2005 -0700
>>
>> ${indent}6th
>> EOF
>> cp expect-not-other expect-other &&
>> cat >>expect-other <<-EOF
>>
>> Notes (other):
>> ${indent}other note
>> EOF
>>
>> [master 2c12533] 6th
>>  Author: A U Thor <aut...@example.com>
>>  1 file changed, 1 insertion(+)
>>  create mode 100644 6th.t
>> ok 62 - create other note on a different notes ref (setup)
>>
>> expecting success:
>> git log -1 >output &&
>> test_cmp expect-not-other output
>>
>> ok 63 - Do not show note on other ref by default
>>
>> expecting success:
>> GIT_NOTES_REF="refs/notes/other" git log -1 >output &&
>> test_cmp expect-other output
>>
>> ok 64 - Do show note when ref is given in GIT_NOTES_REF
>>
>> expecting success:
>> test_config core.notesRef "refs/notes/other" &&
>> git log -1 >output &&
>> test_cmp expect-other output
>>
>> ok 65 - Do show note when ref is given in core.notesRef config
>>
>> expecting success:
>> test_config core.notesRef "refs/notes/other" &&
>> GIT_NOTES_REF="refs/notes/wrong" git log -1 >output &&
>> test_cmp expect-not-other output
>>
>> ok 66 - Do not show note when core.notesRef is overridden
>>
>> expecting success:
>> cat >expect-both <<-EOF &&
>> commit 2c125331118caba0ff8238b7f4958ac6e93fe39c
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:18:13 2005 -0700
>>
>> ${indent}6th
>>
>> Notes:
>> ${indent}order test
>>
>> Notes (other):
>> ${indent}other note
>>
>> commit 7f9ad8836c775acb134c0a055fc55fb4cd1ba361
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:17:13 2005 -0700
>>
>> ${indent}5th
>>
>> Notes:
>> ${indent}replacement for deleted note
>> EOF
>> GIT_NOTES_REF=refs/notes/commits git notes add \
>> -m"replacement for deleted note" HEAD^ &&
>> GIT_NOTES_REF=refs/notes/commits git notes add -m"order test" &&
>> test_unconfig core.notesRef &&
>> test_config notes.displayRef "refs/notes/*" &&
>> git log -2 >output &&
>> test_cmp expect-both output
>>
>> ok 67 - Show all notes when notes.displayRef=refs/notes/*
>>
>> expecting success:
>> test_config core.notesRef refs/notes/commits &&
>> test_config notes.displayRef refs/notes/other &&
>> git log -2 >output &&
>> test_cmp expect-both output
>>
>> ok 68 - core.notesRef is implicitly in notes.displayRef
>>
>> expecting success:
>> test_unconfig core.notesRef &&
>> test_config notes.displayRef refs/notes/commits &&
>> git config --add notes.displayRef refs/notes/other &&
>> git log -2 >output &&
>> test_cmp expect-both output
>>
>> ok 69 - notes.displayRef can be given more than once
>>
>> expecting success:
>> cat >expect-both-reversed <<-EOF &&
>> commit 2c125331118caba0ff8238b7f4958ac6e93fe39c
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:18:13 2005 -0700
>>
>> ${indent}6th
>>
>> Notes (other):
>> ${indent}other note
>>
>> Notes:
>> ${indent}order test
>> EOF
>> test_config core.notesRef refs/notes/other &&
>> test_config notes.displayRef refs/notes/commits &&
>> git log -1 >output &&
>> test_cmp expect-both-reversed output
>>
>> ok 70 - notes.displayRef respects order
>>
>> expecting success:
>> GIT_NOTES_DISPLAY_REF=refs/notes/commits:refs/notes/other \
>> git log -2 >output &&
>> test_cmp expect-both output
>>
>> ok 71 - GIT_NOTES_DISPLAY_REF works
>>
>> expecting success:
>> cat >expect-none <<-EOF &&
>> commit 2c125331118caba0ff8238b7f4958ac6e93fe39c
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:18:13 2005 -0700
>>
>> ${indent}6th
>>
>> commit 7f9ad8836c775acb134c0a055fc55fb4cd1ba361
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:17:13 2005 -0700
>>
>> ${indent}5th
>> EOF
>> test_config notes.displayRef "refs/notes/*" &&
>> GIT_NOTES_REF= GIT_NOTES_DISPLAY_REF= git log -2 >output &&
>> test_cmp expect-none output
>>
>> ok 72 - GIT_NOTES_DISPLAY_REF overrides config
>>
>> expecting success:
>> GIT_NOTES_REF= GIT_NOTES_DISPLAY_REF= git log --show-notes=* -2 >output &&
>> test_cmp expect-both output
>>
>> ok 73 - --show-notes=* adds to GIT_NOTES_DISPLAY_REF
>>
>> expecting success:
>> cat >expect-commits <<EOF
>> commit 2c125331118caba0ff8238b7f4958ac6e93fe39c
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:18:13 2005 -0700
>>
>> ${indent}6th
>>
>> Notes:
>> ${indent}order test
>> EOF
>> git log --no-standard-notes --show-notes=commits -1 >output &&
>> test_cmp expect-commits output
>>
>> ok 74 - --no-standard-notes
>>
>> expecting success:
>> test_config notes.displayRef "refs/notes/*" &&
>> git log --no-standard-notes --show-notes=commits \
>> --standard-notes -2 >output &&
>> test_cmp expect-both output
>>
>> ok 75 - --standard-notes
>>
>> expecting success:
>> git log --show-notes=other --show-notes=commits \
>> --no-standard-notes -1 >output &&
>> test_cmp expect-both-reversed output
>>
>> ok 76 - --show-notes=ref accumulates
>>
>> expecting success:
>> test_config core.notesRef refs/notes/other &&
>> echo "Note on a tree" >expect &&
>> git notes add -m "Note on a tree" HEAD: &&
>> git notes show HEAD: >actual &&
>> test_cmp expect actual &&
>> echo "Note on a blob" >expect &&
>> filename=$(git ls-tree --name-only HEAD | head -n1) &&
>> git notes add -m "Note on a blob" HEAD:$filename &&
>> git notes show HEAD:$filename >actual &&
>> test_cmp expect actual &&
>> echo "Note on a tag" >expect &&
>> git tag -a -m "This is an annotated tag" foobar HEAD^ &&
>> git notes add -m "Note on a tag" foobar &&
>> git notes show foobar >actual &&
>> test_cmp expect actual
>>
>> ok 77 - Allow notes on non-commits (trees, blobs, tags)
>>
>> expecting success:
>> cat >expect <<-EOF &&
>> commit fb01e0ca8c33b6cc0c6451dde747f97df567cb5c
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:19:13 2005 -0700
>>
>> ${indent}7th
>>
>> Notes:
>> ${indent}order test
>> EOF
>> test_commit 7th &&
>> git notes add -C $(git notes list HEAD^) &&
>> git log -1 >actual &&
>> test_cmp expect actual &&
>> test "$(git notes list HEAD)" = "$(git notes list HEAD^)"
>>
>> [master fb01e0c] 7th
>>  Author: A U Thor <aut...@example.com>
>>  1 file changed, 1 insertion(+)
>>  create mode 100644 7th.t
>> ok 78 - create note from other note with "git notes add -C"
>>
>> expecting success:
>> test_commit 8th &&
>> test_must_fail git notes add -C deadbeef &&
>> test_must_fail git notes list HEAD
>>
>> [master 9a4c31c] 8th
>>  Author: A U Thor <aut...@example.com>
>>  1 file changed, 1 insertion(+)
>>  create mode 100644 8th.t
>> fatal: Failed to resolve 'deadbeef' as a valid ref.
>> error: No note found for object 9a4c31c7f722b5d517e92c64e932dd751e1413bf.
>> ok 79 - create note from non-existing note with "git notes add -C" fails
>>
>> expecting success:
>> commit=$(git rev-parse --verify HEAD) &&
>> tree=$(git rev-parse --verify HEAD:) &&
>> test_must_fail git notes add -C $commit &&
>> test_must_fail git notes add -C $tree &&
>> test_must_fail git notes list HEAD
>>
>> fatal: Cannot read note data from non-blob object
>> '9a4c31c7f722b5d517e92c64e932dd751e1413bf'.
>> fatal: Cannot read note data from non-blob object
>> '37f6454412e4ed89ae47782f956ed0fb573892f6'.
>> error: No note found for object 9a4c31c7f722b5d517e92c64e932dd751e1413bf.
>> ok 80 - create note from non-blob with "git notes add -C" fails
>>
>> expecting success:
>> cat >expect <<-EOF &&
>> commit 9a4c31c7f722b5d517e92c64e932dd751e1413bf
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:20:13 2005 -0700
>>
>> ${indent}8th
>>
>> Notes:
>> ${indent}This is a blob object
>> EOF
>> blob=$(echo "This is a blob object" | git hash-object -w --stdin) &&
>> git notes add -C $blob &&
>> git log -1 >actual &&
>> test_cmp expect actual &&
>> test "$(git notes list HEAD)" = "$blob"
>>
>> ok 81 - create note from blob with "git notes add -C" reuses blob id
>>
>> expecting success:
>> cat >expect <<-EOF &&
>> commit 2e0db4bc649e174d667a1cde19e725cf897a5bd2
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:21:13 2005 -0700
>>
>> ${indent}9th
>>
>> Notes:
>> ${indent}yet another note
>> EOF
>> test_commit 9th &&
>> MSG="yet another note" git notes add -c $(git notes list HEAD^^) &&
>> git log -1 >actual &&
>> test_cmp expect actual
>>
>> [master 2e0db4b] 9th
>>  Author: A U Thor <aut...@example.com>
>>  1 file changed, 1 insertion(+)
>>  create mode 100644 9th.t
>> yet another note
>> ok 82 - create note from other note with "git notes add -c"
>>
>> expecting success:
>> test_commit 10th &&
>> test_must_fail env MSG="yet another note" git notes add -c deadbeef &&
>> test_must_fail git notes list HEAD
>>
>> [master 7c3b87a] 10th
>>  Author: A U Thor <aut...@example.com>
>>  1 file changed, 1 insertion(+)
>>  create mode 100644 10th.t
>> fatal: Failed to resolve 'deadbeef' as a valid ref.
>> error: No note found for object 7c3b87ab368f81e11b1ea87b2ab99a71ccd25406.
>> ok 83 - create note from non-existing note with "git notes add -c" fails
>>
>> expecting success:
>> cat >expect <<-EOF &&
>> commit 2e0db4bc649e174d667a1cde19e725cf897a5bd2
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:21:13 2005 -0700
>>
>> ${indent}9th
>>
>> Notes:
>> ${indent}yet another note
>> ${indent}
>> ${indent}yet another note
>> EOF
>> git notes append -C $(git notes list HEAD^) HEAD^ &&
>> git log -1 HEAD^ >actual &&
>> test_cmp expect actual
>>
>> ok 84 - append to note from other note with "git notes append -C"
>>
>> expecting success:
>> cat >expect <<-EOF &&
>> commit 7c3b87ab368f81e11b1ea87b2ab99a71ccd25406
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:22:13 2005 -0700
>>
>> ${indent}10th
>>
>> Notes:
>> ${indent}other note
>> EOF
>> MSG="other note" git notes append -c $(git notes list HEAD^) &&
>> git log -1 >actual &&
>> test_cmp expect actual
>>
>> other note
>> ok 85 - create note from other note with "git notes append -c"
>>
>> expecting success:
>> cat >expect <<-EOF &&
>> commit 7c3b87ab368f81e11b1ea87b2ab99a71ccd25406
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:22:13 2005 -0700
>>
>> ${indent}10th
>>
>> Notes:
>> ${indent}other note
>> ${indent}
>> ${indent}yet another note
>> EOF
>> MSG="yet another note" git notes append -c $(git notes list HEAD) &&
>> git log -1 >actual &&
>> test_cmp expect actual
>>
>> yet another note
>> ok 86 - append to note from other note with "git notes append -c"
>>
>> expecting success:
>> cat >expect <<-EOF &&
>> commit a446fff8777efdc6eb8f4b7c8a5ff699484df0d5
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:23:13 2005 -0700
>>
>> ${indent}11th
>>
>> Notes:
>> ${indent}other note
>> ${indent}
>> ${indent}yet another note
>> EOF
>> test_commit 11th &&
>> git notes copy HEAD^ HEAD &&
>> git log -1 >actual &&
>> test_cmp expect actual &&
>> test "$(git notes list HEAD)" = "$(git notes list HEAD^)"
>>
>> [master a446fff] 11th
>>  Author: A U Thor <aut...@example.com>
>>  1 file changed, 1 insertion(+)
>>  create mode 100644 11th.t
>> ok 87 - copy note with "git notes copy"
>>
>> expecting success:
>> test_must_fail git notes copy HEAD~2 HEAD &&
>> git log -1 >actual &&
>> test_cmp expect actual &&
>> test "$(git notes list HEAD)" = "$(git notes list HEAD^)"
>>
>> error: Cannot copy notes. Found existing notes for object
>> a446fff8777efdc6eb8f4b7c8a5ff699484df0d5. Use '-f' to overwrite
>> existing notes
>> ok 88 - prevent overwrite with "git notes copy"
>>
>> expecting success:
>> cat >expect <<-EOF &&
>> commit a446fff8777efdc6eb8f4b7c8a5ff699484df0d5
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:23:13 2005 -0700
>>
>> ${indent}11th
>>
>> Notes:
>> ${indent}yet another note
>> ${indent}
>> ${indent}yet another note
>> EOF
>> git notes copy -f HEAD~2 HEAD &&
>> git log -1 >actual &&
>> test_cmp expect actual &&
>> test "$(git notes list HEAD)" = "$(git notes list HEAD~2)"
>>
>> Overwriting existing notes for object 
>> a446fff8777efdc6eb8f4b7c8a5ff699484df0d5
>> ok 89 - allow overwrite with "git notes copy -f"
>>
>> expecting success:
>> test_commit 12th &&
>> test_commit 13th &&
>> test_must_fail git notes copy HEAD^ HEAD
>>
>> [master 65e263d] 12th
>>  Author: A U Thor <aut...@example.com>
>>  1 file changed, 1 insertion(+)
>>  create mode 100644 12th.t
>> [master e871aa6] 13th
>>  Author: A U Thor <aut...@example.com>
>>  1 file changed, 1 insertion(+)
>>  create mode 100644 13th.t
>> error: Missing notes on source object
>> 65e263ded02ae4e8839bc151095113737579dc12. Cannot copy.
>> ok 90 - cannot copy note from object without notes
>>
>> expecting success:
>> cat >expect <<-EOF &&
>> commit e871aa61182b1d95d0a6fb75445d891722863b6b
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:25:13 2005 -0700
>>
>> ${indent}13th
>>
>> Notes:
>> ${indent}yet another note
>> ${indent}
>> ${indent}yet another note
>>
>> commit 65e263ded02ae4e8839bc151095113737579dc12
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:24:13 2005 -0700
>>
>> ${indent}12th
>>
>> Notes:
>> ${indent}other note
>> ${indent}
>> ${indent}yet another note
>> EOF
>> (echo $(git rev-parse HEAD~3) $(git rev-parse HEAD^); \
>> echo $(git rev-parse HEAD~2) $(git rev-parse HEAD)) |
>> git notes copy --stdin &&
>> git log -2 >output &&
>> test_cmp expect output &&
>> test "$(git notes list HEAD)" = "$(git notes list HEAD~2)" &&
>> test "$(git notes list HEAD^)" = "$(git notes list HEAD~3)"
>>
>> ok 91 - git notes copy --stdin
>>
>> expecting success:
>> cat >expect <<-EOF &&
>> commit 4acf42e847e7fffbbf89ee365c20ac7caf40de89
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:27:13 2005 -0700
>>
>> ${indent}15th
>>
>> commit 07c85d77059393ed0154b8c96906547a59dfcddd
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:26:13 2005 -0700
>>
>> ${indent}14th
>> EOF
>> test_commit 14th &&
>> test_commit 15th &&
>> (echo $(git rev-parse HEAD~3) $(git rev-parse HEAD^); \
>> echo $(git rev-parse HEAD~2) $(git rev-parse HEAD)) |
>> git notes copy --for-rewrite=foo &&
>> git log -2 >output &&
>> test_cmp expect output
>>
>> [master 07c85d7] 14th
>>  Author: A U Thor <aut...@example.com>
>>  1 file changed, 1 insertion(+)
>>  create mode 100644 14th.t
>> [master 4acf42e] 15th
>>  Author: A U Thor <aut...@example.com>
>>  1 file changed, 1 insertion(+)
>>  create mode 100644 15th.t
>> ok 92 - git notes copy --for-rewrite (unconfigured)
>>
>> expecting success:
>> cat >expect <<-EOF &&
>> commit 4acf42e847e7fffbbf89ee365c20ac7caf40de89
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:27:13 2005 -0700
>>
>> ${indent}15th
>>
>> Notes:
>> ${indent}yet another note
>> ${indent}
>> ${indent}yet another note
>>
>> commit 07c85d77059393ed0154b8c96906547a59dfcddd
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:26:13 2005 -0700
>>
>> ${indent}14th
>>
>> Notes:
>> ${indent}other note
>> ${indent}
>> ${indent}yet another note
>> EOF
>> test_config notes.rewriteMode overwrite &&
>> test_config notes.rewriteRef "refs/notes/*" &&
>> (echo $(git rev-parse HEAD~3) $(git rev-parse HEAD^); \
>> echo $(git rev-parse HEAD~2) $(git rev-parse HEAD)) |
>> git notes copy --for-rewrite=foo &&
>> git log -2 >output &&
>> test_cmp expect output
>>
>> ok 93 - git notes copy --for-rewrite (enabled)
>>
>> expecting success:
>> test_config notes.rewrite.bar false &&
>> echo $(git rev-parse HEAD~3) $(git rev-parse HEAD) |
>> git notes copy --for-rewrite=bar &&
>> git log -2 >output &&
>> test_cmp expect output
>>
>> ./test-lib.sh: line 536: echo: write error: Broken pipe
>> ok 94 - git notes copy --for-rewrite (disabled)
>>
>> expecting success:
>> cat >expect <<-EOF &&
>> commit 4acf42e847e7fffbbf89ee365c20ac7caf40de89
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:27:13 2005 -0700
>>
>> ${indent}15th
>>
>> Notes:
>> ${indent}a fresh note
>> EOF
>> git notes add -f -m"a fresh note" HEAD^ &&
>> test_config notes.rewriteMode overwrite &&
>> test_config notes.rewriteRef "refs/notes/*" &&
>> echo $(git rev-parse HEAD^) $(git rev-parse HEAD) |
>> git notes copy --for-rewrite=foo &&
>> git log -1 >output &&
>> test_cmp expect output
>>
>> Overwriting existing notes for object 
>> 07c85d77059393ed0154b8c96906547a59dfcddd
>> ok 95 - git notes copy --for-rewrite (overwrite)
>>
>> expecting success:
>> test_config notes.rewriteMode ignore &&
>> test_config notes.rewriteRef "refs/notes/*" &&
>> echo $(git rev-parse HEAD^) $(git rev-parse HEAD) |
>> git notes copy --for-rewrite=foo &&
>> git log -1 >output &&
>> test_cmp expect output
>>
>> ok 96 - git notes copy --for-rewrite (ignore)
>>
>> expecting success:
>> cat >expect <<-EOF &&
>> commit 4acf42e847e7fffbbf89ee365c20ac7caf40de89
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:27:13 2005 -0700
>>
>> ${indent}15th
>>
>> Notes:
>> ${indent}a fresh note
>> ${indent}
>> ${indent}another fresh note
>> EOF
>> git notes add -f -m"another fresh note" HEAD^ &&
>> test_config notes.rewriteMode concatenate &&
>> test_config notes.rewriteRef "refs/notes/*" &&
>> echo $(git rev-parse HEAD^) $(git rev-parse HEAD) |
>> git notes copy --for-rewrite=foo &&
>> git log -1 >output &&
>> test_cmp expect output
>>
>> Overwriting existing notes for object 
>> 07c85d77059393ed0154b8c96906547a59dfcddd
>> ok 97 - git notes copy --for-rewrite (append)
>>
>> expecting success:
>> cat >expect <<-EOF &&
>> commit 4acf42e847e7fffbbf89ee365c20ac7caf40de89
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:27:13 2005 -0700
>>
>> ${indent}15th
>>
>> Notes:
>> ${indent}a fresh note
>> ${indent}
>> ${indent}another fresh note
>> ${indent}
>> ${indent}append 1
>> ${indent}
>> ${indent}append 2
>> EOF
>> git notes add -f -m"append 1" HEAD^ &&
>> git notes add -f -m"append 2" HEAD^^ &&
>> test_config notes.rewriteMode concatenate &&
>> test_config notes.rewriteRef "refs/notes/*" &&
>> (echo $(git rev-parse HEAD^) $(git rev-parse HEAD);
>> echo $(git rev-parse HEAD^^) $(git rev-parse HEAD)) |
>> git notes copy --for-rewrite=foo &&
>> git log -1 >output &&
>> test_cmp expect output
>>
>> Overwriting existing notes for object 
>> 07c85d77059393ed0154b8c96906547a59dfcddd
>> Overwriting existing notes for object 
>> e871aa61182b1d95d0a6fb75445d891722863b6b
>> ok 98 - git notes copy --for-rewrite (append two to one)
>>
>> expecting success:
>> git notes remove HEAD^ &&
>> test_config notes.rewriteMode concatenate &&
>> test_config notes.rewriteRef "refs/notes/*" &&
>> echo $(git rev-parse HEAD^) $(git rev-parse HEAD) |
>> git notes copy --for-rewrite=foo &&
>> git log -1 >output &&
>> test_cmp expect output
>>
>> Removing note for object HEAD^
>> ok 99 - git notes copy --for-rewrite (append empty)
>>
>> expecting success:
>> cat >expect <<-EOF &&
>> commit 4acf42e847e7fffbbf89ee365c20ac7caf40de89
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:27:13 2005 -0700
>>
>> ${indent}15th
>>
>> Notes:
>> ${indent}replacement note 1
>> EOF
>> test_config notes.rewriteMode concatenate &&
>> test_config notes.rewriteRef "refs/notes/*" &&
>> git notes add -f -m"replacement note 1" HEAD^ &&
>> echo $(git rev-parse HEAD^) $(git rev-parse HEAD) |
>> GIT_NOTES_REWRITE_MODE=overwrite git notes copy --for-rewrite=foo &&
>> git log -1 >output &&
>> test_cmp expect output
>>
>> ok 100 - GIT_NOTES_REWRITE_MODE works
>>
>> expecting success:
>> cat >expect <<-EOF &&
>> commit 4acf42e847e7fffbbf89ee365c20ac7caf40de89
>> Author: A U Thor <aut...@example.com>
>> Date:   Thu Apr 7 15:27:13 2005 -0700
>>
>> ${indent}15th
>>
>> Notes:
>> ${indent}replacement note 2
>> EOF
>> git notes add -f -m"replacement note 2" HEAD^ &&
>> test_config notes.rewriteMode overwrite &&
>> test_unconfig notes.rewriteRef &&
>> echo $(git rev-parse HEAD^) $(git rev-parse HEAD) |
>> GIT_NOTES_REWRITE_REF=refs/notes/commits:refs/notes/other \
>> git notes copy --for-rewrite=foo &&
>> git log -1 >output &&
>> test_cmp expect output
>>
>> Overwriting existing notes for object 
>> 07c85d77059393ed0154b8c96906547a59dfcddd
>> ok 101 - GIT_NOTES_REWRITE_REF works
>>
>> expecting success:
>> git notes add -f -m"replacement note 3" HEAD^ &&
>> test_config notes.rewriteMode overwrite &&
>> test_config notes.rewriteRef refs/notes/other &&
>> echo $(git rev-parse HEAD^) $(git rev-parse HEAD) |
>> GIT_NOTES_REWRITE_REF= git notes copy --for-rewrite=foo &&
>> git log -1 >output &&
>> test_cmp expect output
>>
>> Overwriting existing notes for object 
>> 07c85d77059393ed0154b8c96906547a59dfcddd
>> ./test-lib.sh: line 538: echo: write error: Broken pipe
>> ok 102 - GIT_NOTES_REWRITE_REF overrides config
>>
>> expecting success:
>> test_must_fail git notes copy &&
>> test_must_fail git notes copy one two three
>>
>> error: too few parameters
>> usage: git notes copy [<options>] <from-object> <to-object>
>>    or: git notes copy --stdin [<from-object> <to-object>]...
>>
>>     -f, --force           replace existing notes
>>     --stdin               read objects from stdin
>>     --for-rewrite <command>
>>                           load rewriting config for <command> (implies 
>> --stdin)
>>
>> error: too many parameters
>> usage: git notes copy [<options>] <from-object> <to-object>
>>    or: git notes copy --stdin [<from-object> <to-object>]...
>>
>>     -f, --force           replace existing notes
>>     --stdin               read objects from stdin
>>     --for-rewrite <command>
>>                           load rewriting config for <command> (implies 
>> --stdin)
>>
>> ok 103 - git notes copy diagnoses too many or too few parameters
>>
>> expecting success:
>> test_unconfig core.notesRef &&
>> sane_unset GIT_NOTES_REF &&
>> test "$(git notes get-ref)" = "refs/notes/commits"
>>
>> ok 104 - git notes get-ref (no overrides)
>>
>> expecting success:
>> test_config core.notesRef refs/notes/foo &&
>> test "$(git notes get-ref)" = "refs/notes/foo"
>>
>> ok 105 - git notes get-ref (core.notesRef)
>>
>> expecting success:
>> test "$(GIT_NOTES_REF=refs/notes/bar git notes get-ref)" = "refs/notes/bar"
>>
>> ok 106 - git notes get-ref (GIT_NOTES_REF)
>>
>> expecting success:
>> test "$(GIT_NOTES_REF=refs/notes/bar git notes --ref=baz get-ref)" =
>> "refs/notes/baz"
>>
>> ok 107 - git notes get-ref (--ref)
>>
>> expecting success:
>> test_unconfig core.notesRef &&
>> test_commit 16th &&
>> empty_blob=$(git hash-object -w /dev/null) &&
>> echo "$empty_blob" >expect_empty
>>
>> [master 21d0abc] 16th
>>  Author: A U Thor <aut...@example.com>
>>  1 file changed, 1 insertion(+)
>>  create mode 100644 16th.t
>> ok 108 - setup testing of empty notes
>>
>> expecting success:
>> test_might_fail git notes remove HEAD &&
>> MSG= git notes add &&
>> test_must_fail git notes list HEAD
>>
>> Object HEAD has no note
>>
>> Removing note for object 21d0abcd10f591529d5148ae8bc7703fc1f73398
>> error: No note found for object 21d0abcd10f591529d5148ae8bc7703fc1f73398.
>> ok 109 - 'git notes add' removes empty note
>>
>> expecting success:
>> test_might_fail git notes remove HEAD &&
>> MSG= git notes add --allow-empty &&
>> git notes list HEAD >actual &&
>> test_cmp expect_empty actual
>>
>> Object HEAD has no note
>>
>> ok 110 - 'git notes add --allow-empty' stores empty note
>>
>> expecting success:
>> test_might_fail git notes remove HEAD &&
>> MSG= git notes add -F /dev/null &&
>> test_must_fail git notes list HEAD
>>
>> Removing note for object HEAD
>> Removing note for object 21d0abcd10f591529d5148ae8bc7703fc1f73398
>> error: No note found for object 21d0abcd10f591529d5148ae8bc7703fc1f73398.
>> ok 111 - 'git notes add -F /dev/null' removes empty note
>>
>> expecting success:
>> test_might_fail git notes remove HEAD &&
>> MSG= git notes add -F /dev/null --allow-empty &&
>> git notes list HEAD >actual &&
>> test_cmp expect_empty actual
>>
>> Object HEAD has no note
>> ok 112 - 'git notes add -F /dev/null --allow-empty' stores empty note
>>
>> expecting success:
>> test_might_fail git notes remove HEAD &&
>> MSG= git notes add -m "" &&
>> test_must_fail git notes list HEAD
>>
>> Removing note for object HEAD
>> Removing note for object 21d0abcd10f591529d5148ae8bc7703fc1f73398
>> error: No note found for object 21d0abcd10f591529d5148ae8bc7703fc1f73398.
>> ok 113 - 'git notes add -m ""' removes empty note
>>
>> expecting success:
>> test_might_fail git notes remove HEAD &&
>> MSG= git notes add -m "" --allow-empty &&
>> git notes list HEAD >actual &&
>> test_cmp expect_empty actual
>>
>> Object HEAD has no note
>> ok 114 - 'git notes add -m "" --allow-empty' stores empty note
>>
>> expecting success:
>> test_might_fail git notes remove HEAD &&
>> MSG= git notes add -c "$empty_blob" &&
>> test_must_fail git notes list HEAD
>>
>> Removing note for object HEAD
>>
>> Removing note for object 21d0abcd10f591529d5148ae8bc7703fc1f73398
>> error: No note found for object 21d0abcd10f591529d5148ae8bc7703fc1f73398.
>> ok 115 - 'git notes add -c "$empty_blob"' removes empty note
>>
>> expecting success:
>> test_might_fail git notes remove HEAD &&
>> MSG= git notes add -c "$empty_blob" --allow-empty &&
>> git notes list HEAD >actual &&
>> test_cmp expect_empty actual
>>
>> Object HEAD has no note
>>
>> ok 116 - 'git notes add -c "$empty_blob" --allow-empty' stores empty note
>>
>> expecting success:
>> test_might_fail git notes remove HEAD &&
>> MSG= git notes add -C "$empty_blob" &&
>> test_must_fail git notes list HEAD
>>
>> Removing note for object HEAD
>> Removing note for object 21d0abcd10f591529d5148ae8bc7703fc1f73398
>> error: No note found for object 21d0abcd10f591529d5148ae8bc7703fc1f73398.
>> ok 117 - 'git notes add -C "$empty_blob"' removes empty note
>>
>> expecting success:
>> test_might_fail git notes remove HEAD &&
>> MSG= git notes add -C "$empty_blob" --allow-empty &&
>> git notes list HEAD >actual &&
>> test_cmp expect_empty actual
>>
>> Object HEAD has no note
>> ok 118 - 'git notes add -C "$empty_blob" --allow-empty' stores empty note
>>
>> expecting success:
>> test_might_fail git notes remove HEAD &&
>> MSG= git notes append &&
>> test_must_fail git notes list HEAD
>>
>> Removing note for object HEAD
>>
>> Removing note for object 21d0abcd10f591529d5148ae8bc7703fc1f73398
>> error: No note found for object 21d0abcd10f591529d5148ae8bc7703fc1f73398.
>> ok 119 - 'git notes append' removes empty note
>>
>> expecting success:
>> test_might_fail git notes remove HEAD &&
>> MSG= git notes append --allow-empty &&
>> git notes list HEAD >actual &&
>> test_cmp expect_empty actual
>>
>> Object HEAD has no note
>>
>> ok 120 - 'git notes append --allow-empty' stores empty note
>>
>> expecting success:
>> test_might_fail git notes remove HEAD &&
>> MSG= git notes append -F /dev/null &&
>> test_must_fail git notes list HEAD
>>
>> Removing note for object HEAD
>> Removing note for object 21d0abcd10f591529d5148ae8bc7703fc1f73398
>> error: No note found for object 21d0abcd10f591529d5148ae8bc7703fc1f73398.
>> ok 121 - 'git notes append -F /dev/null' removes empty note
>>
>> expecting success:
>> test_might_fail git notes remove HEAD &&
>> MSG= git notes append -F /dev/null --allow-empty &&
>> git notes list HEAD >actual &&
>> test_cmp expect_empty actual
>>
>> Object HEAD has no note
>> ok 122 - 'git notes append -F /dev/null --allow-empty' stores empty note
>>
>> expecting success:
>> test_might_fail git notes remove HEAD &&
>> MSG= git notes append -m "" &&
>> test_must_fail git notes list HEAD
>>
>> Removing note for object HEAD
>> Removing note for object 21d0abcd10f591529d5148ae8bc7703fc1f73398
>> error: No note found for object 21d0abcd10f591529d5148ae8bc7703fc1f73398.
>> ok 123 - 'git notes append -m ""' removes empty note
>>
>> expecting success:
>> test_might_fail git notes remove HEAD &&
>> MSG= git notes append -m "" --allow-empty &&
>> git notes list HEAD >actual &&
>> test_cmp expect_empty actual
>>
>> Object HEAD has no note
>> ok 124 - 'git notes append -m "" --allow-empty' stores empty note
>>
>> expecting success:
>> test_might_fail git notes remove HEAD &&
>> MSG= git notes append -c "$empty_blob" &&
>> test_must_fail git notes list HEAD
>>
>> Removing note for object HEAD
>>
>> Removing note for object 21d0abcd10f591529d5148ae8bc7703fc1f73398
>> error: No note found for object 21d0abcd10f591529d5148ae8bc7703fc1f73398.
>> ok 125 - 'git notes append -c "$empty_blob"' removes empty note
>>
>> expecting success:
>> test_might_fail git notes remove HEAD &&
>> MSG= git notes append -c "$empty_blob" --allow-empty &&
>> git notes list HEAD >actual &&
>> test_cmp expect_empty actual
>>
>> Object HEAD has no note
>>
>> ok 126 - 'git notes append -c "$empty_blob" --allow-empty' stores empty note
>>
>> expecting success:
>> test_might_fail git notes remove HEAD &&
>> MSG= git notes append -C "$empty_blob" &&
>> test_must_fail git notes list HEAD
>>
>> Removing note for object HEAD
>> Removing note for object 21d0abcd10f591529d5148ae8bc7703fc1f73398
>> error: No note found for object 21d0abcd10f591529d5148ae8bc7703fc1f73398.
>> ok 127 - 'git notes append -C "$empty_blob"' removes empty note
>>
>> expecting success:
>> test_might_fail git notes remove HEAD &&
>> MSG= git notes append -C "$empty_blob" --allow-empty &&
>> git notes list HEAD >actual &&
>> test_cmp expect_empty actual
>>
>> Object HEAD has no note
>> ok 128 - 'git notes append -C "$empty_blob" --allow-empty' stores empty note
>>
>> expecting success:
>> test_might_fail git notes remove HEAD &&
>> MSG= git notes edit &&
>> test_must_fail git notes list HEAD
>>
>> Removing note for object HEAD
>>
>> Removing note for object 21d0abcd10f591529d5148ae8bc7703fc1f73398
>> error: No note found for object 21d0abcd10f591529d5148ae8bc7703fc1f73398.
>> ok 129 - 'git notes edit' removes empty note
>>
>> expecting success:
>> test_might_fail git notes remove HEAD &&
>> MSG= git notes edit --allow-empty &&
>> git notes list HEAD >actual &&
>> test_cmp expect_empty actual
>>
>> Object HEAD has no note
>>
>> ok 130 - 'git notes edit --allow-empty' stores empty note
>>
>> expecting success:
>> test_commit 17th &&
>> git log -1 >expect &&
>> cat >>expect <<-EOF &&
>>
>> Notes:
>> EOF
>> git notes add -C "$empty_blob" --allow-empty &&
>> git log -1 >actual &&
>> test_cmp expect actual
>>
>> [master 27a79f3] 17th
>>  Author: A U Thor <aut...@example.com>
>>  1 file changed, 1 insertion(+)
>>  create mode 100644 17th.t
>> ok 131 - empty notes are displayed by git log
>>
>> # failed 6 among 131 test(s)
>> 1..131
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to