(CommandList
  children: [
    (Assignment
      keyword: Assign_None
      pairs: [
        (assign_pair
          lhs: (LhsName name:test_description)
          op: Equal
          rhs: {(SQ <"git interpret-trailers">)}
          spids: [13]
        )
      ]
      spids: [13]
    )
    (C {(.)} {(./test-lib.sh)})
    (C {(test_expect_success)} {(SQ <setup>)} 
      {
        (SQ <"\n"> <"\t: >empty &&\n"> <"\tcat >basic_message <<-\\EOF &&\n"> <"\t\tsubject\n"> <"\n"> 
          <"\t\tbody\n"> <"\tEOF\n"> <"\tcat >complex_message_body <<-\\EOF &&\n"> <"\t\tmy subject\n"> <"\n"> 
          <"\t\tmy body which is long\n"> <"\t\tand contains some special\n"> <"\t\tchars like : = ? !\n"> <"\n"> <"\tEOF\n"> 
          <"\tsed -e \"s/ Z\\$/ /\" >complex_message_trailers <<-\\EOF &&\n"> <"\t\tFixes: Z\n"> <"\t\tAcked-by: Z\n"> <"\t\tReviewed-by: Z\n"> <"\t\tSigned-off-by: Z\n"> <"\tEOF\n"> 
          <"\tcat >basic_patch <<-\\EOF\n"> <"\t\t---\n"> <"\t\t foo.txt | 2 +-\n"> <"\t\t 1 file changed, 1 insertion(+), 1 deletion(-)\n"> <"\n"> 
          <"\t\tdiff --git a/foo.txt b/foo.txt\n"> <"\t\tindex 0353767..1d91aa1 100644\n"> <"\t\t--- a/foo.txt\n"> <"\t\t+++ b/foo.txt\n"> 
          <"\t\t@@ -1,3 +1,3 @@\n"> <"\n"> <"\t\t-bar\n"> <"\t\t+baz\n"> <"\n"> <"\t\t--\n"> <"\t\t1.9.rc0.11.ga562ddc\n"> <"\n"> <"\tEOF\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"without config">)} 
      {
        (SQ <"\n"> <"\tsed -e \"s/ Z\\$/ /\" >expected <<-\\EOF &&\n"> <"\n"> <"\t\tack: Peff\n"> 
          <"\t\tReviewed-by: Z\n"> <"\t\tAcked-by: Johan\n"> <"\tEOF\n"> 
          <"\tgit interpret-trailers --trailer \"ack = Peff\" --trailer \"Reviewed-by\" \\\n"> <"\t\t--trailer \"Acked-by: Johan\" empty >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"without config in another order">)} 
      {
        (SQ <"\n"> <"\tsed -e \"s/ Z\\$/ /\" >expected <<-\\EOF &&\n"> <"\n"> <"\t\tAcked-by: Johan\n"> 
          <"\t\tReviewed-by: Z\n"> <"\t\tack: Peff\n"> <"\tEOF\n"> 
          <"\tgit interpret-trailers --trailer \"Acked-by: Johan\" --trailer \"Reviewed-by\" \\\n"> <"\t\t--trailer \"ack = Peff\" empty >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"--trim-empty without config">)} 
      {
        (SQ <"\n"> <"\tcat >expected <<-\\EOF &&\n"> <"\n"> <"\t\tack: Peff\n"> <"\t\tAcked-by: Johan\n"> 
          <"\tEOF\n"> <"\tgit interpret-trailers --trim-empty --trailer ack=Peff \\\n"> 
          <"\t\t--trailer \"Reviewed-by\" --trailer \"Acked-by: Johan\" \\\n"> <"\t\t--trailer \"sob:\" empty >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"with config option on the command line">)} 
      {
        (SQ <"\n"> <"\tcat >expected <<-\\EOF &&\n"> <"\n"> <"\t\tAcked-by: Johan\n"> 
          <"\t\tReviewed-by: Peff\n"> <"\tEOF\n"> <"\t{ echo; echo \"Acked-by: Johan\"; } |\n"> 
          <"\tgit -c \"trailer.Acked-by.ifexists=addifdifferent\" interpret-trailers \\\n"> <"\t\t--trailer \"Reviewed-by: Peff\" --trailer \"Acked-by: Johan\" >actual &&\n"> 
          <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"with only a title in the message">)} 
      {
        (SQ <"\n"> <"\tcat >expected <<-\\EOF &&\n"> <"\t\tarea: change\n"> <"\n"> 
          <"\t\tReviewed-by: Peff\n"> <"\t\tAcked-by: Johan\n"> <"\tEOF\n"> <"\techo \"area: change\" |\n"> 
          <"\tgit interpret-trailers --trailer \"Reviewed-by: Peff\" \\\n"> <"\t\t--trailer \"Acked-by: Johan\" >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"with multiline title in the message">)} 
      {
        (SQ <"\n"> <"\tcat >expected <<-\\EOF &&\n"> <"\t\tplace of\n"> <"\t\tcode: change\n"> <"\n"> 
          <"\t\tReviewed-by: Peff\n"> <"\t\tAcked-by: Johan\n"> <"\tEOF\n"> <"\tprintf \"%s\\n\" \"place of\" \"code: change\" |\n"> 
          <"\tgit interpret-trailers --trailer \"Reviewed-by: Peff\" \\\n"> <"\t\t--trailer \"Acked-by: Johan\" >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"with config setup">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.ack.key \"Acked-by: \" &&\n"> 
          <"\tcat >expected <<-\\EOF &&\n"> <"\n"> <"\t\tAcked-by: Peff\n"> <"\tEOF\n"> 
          <"\tgit interpret-trailers --trim-empty --trailer \"ack = Peff\" empty >actual &&\n"> <"\ttest_cmp expected actual &&\n"> 
          <
"\tgit interpret-trailers --trim-empty --trailer \"Acked-by = Peff\" empty >actual &&\n"
          > <"\ttest_cmp expected actual &&\n"> 
          <"\tgit interpret-trailers --trim-empty --trailer \"Acked-by :Peff\" empty >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"with config setup and \":=\" as separators">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.separators \":=\" &&\n"> 
          <"\tgit config trailer.ack.key \"Acked-by= \" &&\n"> <"\tcat >expected <<-\\EOF &&\n"> <"\n"> <"\t\tAcked-by= Peff\n"> <"\tEOF\n"> 
          <"\tgit interpret-trailers --trim-empty --trailer \"ack = Peff\" empty >actual &&\n"> <"\ttest_cmp expected actual &&\n"> 
          <"\tgit interpret-trailers --trim-empty --trailer \"Acked-by= Peff\" empty >actual &&\n"> <"\ttest_cmp expected actual &&\n"> 
          <
"\tgit interpret-trailers --trim-empty --trailer \"Acked-by : Peff\" empty >actual &&\n"
          > <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"with config setup and \"%\" as separators">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.separators \"%\" &&\n"> <"\tcat >expected <<-\\EOF &&\n"> 
          <"\n"> <"\t\tbug% 42\n"> <"\t\tcount% 10\n"> <"\t\tbug% 422\n"> <"\tEOF\n"> 
          <"\tgit interpret-trailers --trim-empty --trailer \"bug = 42\" \\\n"> <"\t\t--trailer count%10 --trailer \"test: stuff\" \\\n"> 
          <"\t\t--trailer \"bug % 422\" empty >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"with \"%\" as separators and a message with trailers">)} 
      {
        (SQ <"\n"> <"\tcat >special_message <<-\\EOF &&\n"> <"\t\tSpecial Message\n"> <"\n"> 
          <"\t\tbug% 42\n"> <"\t\tcount% 10\n"> <"\t\tbug% 422\n"> <"\tEOF\n"> <"\tcat >expected <<-\\EOF &&\n"> 
          <"\t\tSpecial Message\n"> <"\n"> <"\t\tbug% 42\n"> <"\t\tcount% 10\n"> <"\t\tbug% 422\n"> <"\t\tcount% 100\n"> <"\tEOF\n"> 
          <"\tgit interpret-trailers --trailer count%100 \\\n"> <"\t\tspecial_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"with config setup and \":=#\" as separators">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.separators \":=#\" &&\n"> 
          <"\tgit config trailer.bug.key \"Bug #\" &&\n"> <"\tcat >expected <<-\\EOF &&\n"> <"\n"> <"\t\tBug #42\n"> <"\tEOF\n"> 
          <"\tgit interpret-trailers --trim-empty --trailer \"bug = 42\" empty >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"with commit basic message">)} 
      {
        (SQ <"\n"> <"\tcat basic_message >expected &&\n"> <"\techo >>expected &&\n"> 
          <"\tgit interpret-trailers <basic_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"with basic patch">)} 
      {
        (SQ <"\n"> <"\tcat basic_message >input &&\n"> <"\tcat basic_patch >>input &&\n"> 
          <"\tcat basic_message >expected &&\n"> <"\techo >>expected &&\n"> <"\tcat basic_patch >>expected &&\n"> 
          <"\tgit interpret-trailers <input >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"with commit complex message as argument">)} 
      {
        (SQ <"\n"> <"\tcat complex_message_body complex_message_trailers >complex_message &&\n"> 
          <"\tcat complex_message_body >expected &&\n"> <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> <"\t\tFixes: Z\n"> <"\t\tAcked-by= Z\n"> 
          <"\t\tReviewed-by: Z\n"> <"\t\tSigned-off-by: Z\n"> <"\tEOF\n"> <"\tgit interpret-trailers complex_message >actual &&\n"> 
          <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"with 2 files arguments">)} 
      {
        (SQ <"\n"> <"\tcat basic_message >>expected &&\n"> <"\techo >>expected &&\n"> 
          <"\tcat basic_patch >>expected &&\n"> <"\tgit interpret-trailers complex_message input >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"with message that has comments">)} 
      {
        (SQ <"\n"> <"\tcat basic_message >message_with_comments &&\n"> 
          <"\tsed -e \"s/ Z\\$/ /\" >>message_with_comments <<-\\EOF &&\n"> <"\t\t# comment\n"> <"\n"> <"\t\t# other comment\n"> <"\t\tCc: Z\n"> <"\t\t# yet another comment\n"> 
          <"\t\tReviewed-by: Johan\n"> <"\t\tReviewed-by: Z\n"> <"\t\t# last comment\n"> <"\n"> <"\tEOF\n"> 
          <"\tcat basic_patch >>message_with_comments &&\n"> <"\tcat basic_message >expected &&\n"> <"\tcat >>expected <<-\\EOF &&\n"> <"\t\t# comment\n"> <"\n"> 
          <"\t\tReviewed-by: Johan\n"> <"\t\tCc: Peff\n"> <"\t\t# last comment\n"> <"\n"> <"\tEOF\n"> <"\tcat basic_patch >>expected &&\n"> 
          <
"\tgit interpret-trailers --trim-empty --trailer \"Cc: Peff\" message_with_comments >actual &&\n"
          > <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"with message that has an old style conflict block">)} 
      {
        (SQ <"\n"> <"\tcat basic_message >message_with_comments &&\n"> 
          <"\tsed -e \"s/ Z\\$/ /\" >>message_with_comments <<-\\EOF &&\n"> <"\t\t# comment\n"> <"\n"> <"\t\t# other comment\n"> <"\t\tCc: Z\n"> <"\t\t# yet another comment\n"> 
          <"\t\tReviewed-by: Johan\n"> <"\t\tReviewed-by: Z\n"> <"\t\t# last comment\n"> <"\n"> <"\t\tConflicts:\n"> <"\n"> <"\tEOF\n"> 
          <"\tcat basic_message >expected &&\n"> <"\tcat >>expected <<-\\EOF &&\n"> <"\t\t# comment\n"> <"\n"> <"\t\tReviewed-by: Johan\n"> 
          <"\t\tCc: Peff\n"> <"\t\t# last comment\n"> <"\n"> <"\t\tConflicts:\n"> <"\n"> <"\tEOF\n"> 
          <
"\tgit interpret-trailers --trim-empty --trailer \"Cc: Peff\" message_with_comments >actual &&\n"
          > <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"with commit complex message and trailer args">)} 
      {
        (SQ <"\n"> <"\tcat complex_message_body >expected &&\n"> 
          <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> <"\t\tFixes: Z\n"> <"\t\tAcked-by= Z\n"> <"\t\tReviewed-by: Z\n"> <"\t\tSigned-off-by: Z\n"> 
          <"\t\tAcked-by= Peff\n"> <"\t\tBug #42\n"> <"\tEOF\n"> <"\tgit interpret-trailers --trailer \"ack: Peff\" \\\n"> 
          <"\t\t--trailer \"bug: 42\" <complex_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"with complex patch, args and --trim-empty">)} 
      {
        (SQ <"\n"> <"\tcat complex_message >complex_patch &&\n"> 
          <"\tcat basic_patch >>complex_patch &&\n"> <"\tcat complex_message_body >expected &&\n"> <"\tcat >>expected <<-\\EOF &&\n"> 
          <"\t\tAcked-by= Peff\n"> <"\t\tBug #42\n"> <"\tEOF\n"> <"\tcat basic_patch >>expected &&\n"> 
          <"\tgit interpret-trailers --trim-empty --trailer \"ack: Peff\" \\\n"> <"\t\t--trailer \"bug: 42\" <complex_patch >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"in-place editing with basic patch">)} 
      {
        (SQ <"\n"> <"\tcat basic_message >message &&\n"> <"\tcat basic_patch >>message &&\n"> 
          <"\tcat basic_message >expected &&\n"> <"\techo >>expected &&\n"> <"\tcat basic_patch >>expected &&\n"> 
          <"\tgit interpret-trailers --in-place message &&\n"> <"\ttest_cmp expected message\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"in-place editing with additional trailer">)} 
      {
        (SQ <"\n"> <"\tcat basic_message >message &&\n"> <"\tcat basic_patch >>message &&\n"> 
          <"\tcat basic_message >expected &&\n"> <"\techo >>expected &&\n"> <"\tcat >>expected <<-\\EOF &&\n"> <"\t\tReviewed-by: Alice\n"> <"\tEOF\n"> 
          <"\tcat basic_patch >>expected &&\n"> <"\tgit interpret-trailers --trailer \"Reviewed-by: Alice\" --in-place message &&\n"> 
          <"\ttest_cmp expected message\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"in-place editing on stdin disallowed">)} 
      {
        (SQ <"\n"> 
          <
"\ttest_must_fail git interpret-trailers --trailer \"Reviewed-by: Alice\" --in-place < basic_message\n"
          >
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"in-place editing on non-existing file">)} 
      {
        (SQ <"\n"> 
          <
"\ttest_must_fail git interpret-trailers --trailer \"Reviewed-by: Alice\" --in-place nonexisting &&\n"
          > <"\ttest_path_is_missing nonexisting\n">
        )
      }
    )
    (C {(test_expect_success)} {(POSIXPERM) (Lit_Comma ",") (SANITY)} 
      {(DQ ("in-place editing doesn't clobber original file on error"))} 
      {
        (SQ <"\n"> <"\tcat basic_message >message &&\n"> <"\tchmod -r message &&\n"> 
          <
"\ttest_must_fail git interpret-trailers --trailer \"Reviewed-by: Alice\" --in-place message &&\n"
          > <"\tchmod +r message &&\n"> <"\ttest_cmp message basic_message\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"using \"where = before\"">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.bug.where \"before\" &&\n"> 
          <"\tcat complex_message_body >expected &&\n"> <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> <"\t\tBug #42\n"> <"\t\tFixes: Z\n"> 
          <"\t\tAcked-by= Z\n"> <"\t\tReviewed-by: Z\n"> <"\t\tSigned-off-by: Z\n"> <"\t\tAcked-by= Peff\n"> <"\tEOF\n"> 
          <"\tgit interpret-trailers --trailer \"ack: Peff\" \\\n"> <"\t\t--trailer \"bug: 42\" complex_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"using \"where = after\"">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.ack.where \"after\" &&\n"> 
          <"\tcat complex_message_body >expected &&\n"> <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> <"\t\tBug #42\n"> <"\t\tFixes: Z\n"> 
          <"\t\tAcked-by= Z\n"> <"\t\tAcked-by= Peff\n"> <"\t\tReviewed-by: Z\n"> <"\t\tSigned-off-by: Z\n"> <"\tEOF\n"> 
          <"\tgit interpret-trailers --trailer \"ack: Peff\" \\\n"> <"\t\t--trailer \"bug: 42\" complex_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"using \"where = end\"">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.review.key \"Reviewed-by\" &&\n"> 
          <"\tgit config trailer.review.where \"end\" &&\n"> <"\tcat complex_message_body >expected &&\n"> <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> 
          <"\t\tFixes: Z\n"> <"\t\tAcked-by= Z\n"> <"\t\tAcked-by= Peff\n"> <"\t\tReviewed-by: Z\n"> <"\t\tSigned-off-by: Z\n"> 
          <"\t\tReviewed-by: Junio\n"> <"\t\tReviewed-by: Johannes\n"> <"\tEOF\n"> <"\tgit interpret-trailers --trailer \"ack: Peff\" \\\n"> 
          <"\t\t--trailer \"Reviewed-by: Junio\" --trailer \"Reviewed-by: Johannes\" \\\n"> <"\t\tcomplex_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"using \"where = start\"">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.review.key \"Reviewed-by\" &&\n"> 
          <"\tgit config trailer.review.where \"start\" &&\n"> <"\tcat complex_message_body >expected &&\n"> <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> 
          <"\t\tReviewed-by: Johannes\n"> <"\t\tReviewed-by: Junio\n"> <"\t\tFixes: Z\n"> <"\t\tAcked-by= Z\n"> <"\t\tAcked-by= Peff\n"> 
          <"\t\tReviewed-by: Z\n"> <"\t\tSigned-off-by: Z\n"> <"\tEOF\n"> <"\tgit interpret-trailers --trailer \"ack: Peff\" \\\n"> 
          <"\t\t--trailer \"Reviewed-by: Junio\" --trailer \"Reviewed-by: Johannes\" \\\n"> <"\t\tcomplex_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} 
      {(SQ <"using \"where = before\" for a token in the middle of the message">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.review.key \"Reviewed-by:\" &&\n"> 
          <"\tgit config trailer.review.where \"before\" &&\n"> <"\tcat complex_message_body >expected &&\n"> <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> 
          <"\t\tBug #42\n"> <"\t\tFixes: Z\n"> <"\t\tAcked-by= Z\n"> <"\t\tAcked-by= Peff\n"> <"\t\tReviewed-by:Johan\n"> 
          <"\t\tReviewed-by:\n"> <"\t\tSigned-off-by: Z\n"> <"\tEOF\n"> 
          <"\tgit interpret-trailers --trailer \"ack: Peff\" --trailer \"bug: 42\" \\\n"> <"\t\t--trailer \"review: Johan\" <complex_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"using \"where = before\" and --trim-empty">)} 
      {
        (SQ <"\n"> <"\tcat complex_message_body >expected &&\n"> <"\tcat >>expected <<-\\EOF &&\n"> 
          <"\t\tBug #46\n"> <"\t\tBug #42\n"> <"\t\tAcked-by= Peff\n"> <"\t\tReviewed-by:Johan\n"> <"\tEOF\n"> 
          <"\tgit interpret-trailers --trim-empty --trailer \"ack: Peff\" \\\n"> <"\t\t--trailer \"bug: 42\" --trailer \"review: Johan\" \\\n"> 
          <"\t\t--trailer \"Bug: 46\" <complex_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"the default is \"ifExists = addIfDifferentNeighbor\"">)} 
      {
        (SQ <"\n"> <"\tcat complex_message_body >expected &&\n"> 
          <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> <"\t\tBug #42\n"> <"\t\tFixes: Z\n"> <"\t\tAcked-by= Z\n"> <"\t\tAcked-by= Peff\n"> 
          <"\t\tAcked-by= Junio\n"> <"\t\tAcked-by= Peff\n"> <"\t\tReviewed-by:\n"> <"\t\tSigned-off-by: Z\n"> <"\tEOF\n"> 
          <"\tgit interpret-trailers --trailer \"ack: Peff\" --trailer \"review:\" \\\n"> <"\t\t--trailer \"ack: Junio\" --trailer \"bug: 42\" --trailer \"ack: Peff\" \\\n"> 
          <"\t\t--trailer \"ack: Peff\" <complex_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"default \"ifExists\" is now \"addIfDifferent\"">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.ifexists \"addIfDifferent\" &&\n"> 
          <"\tcat complex_message_body >expected &&\n"> <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> <"\t\tBug #42\n"> <"\t\tFixes: Z\n"> 
          <"\t\tAcked-by= Z\n"> <"\t\tAcked-by= Peff\n"> <"\t\tAcked-by= Junio\n"> <"\t\tReviewed-by:\n"> <"\t\tSigned-off-by: Z\n"> 
          <"\tEOF\n"> <"\tgit interpret-trailers --trailer \"ack: Peff\" --trailer \"review:\" \\\n"> 
          <"\t\t--trailer \"ack: Junio\" --trailer \"bug: 42\" --trailer \"ack: Peff\" \\\n"> <"\t\t--trailer \"ack: Peff\" <complex_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"using \"ifExists = addIfDifferent\" with \"where = end\"">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.ack.ifExists \"addIfDifferent\" &&\n"> 
          <"\tgit config trailer.ack.where \"end\" &&\n"> <"\tcat complex_message_body >expected &&\n"> <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> 
          <"\t\tBug #42\n"> <"\t\tFixes: Z\n"> <"\t\tAcked-by= Z\n"> <"\t\tReviewed-by:\n"> <"\t\tSigned-off-by: Z\n"> 
          <"\t\tAcked-by= Peff\n"> <"\tEOF\n"> <"\tgit interpret-trailers --trailer \"ack: Peff\" --trailer \"review:\" \\\n"> 
          <"\t\t--trailer \"bug: 42\" --trailer \"ack: Peff\" \\\n"> <"\t\t<complex_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"using \"ifExists = addIfDifferent\" with \"where = before\"">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.ack.ifExists \"addIfDifferent\" &&\n"> 
          <"\tgit config trailer.ack.where \"before\" &&\n"> <"\tcat complex_message_body >expected &&\n"> <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> 
          <"\t\tBug #42\n"> <"\t\tFixes: Z\n"> <"\t\tAcked-by= Peff\n"> <"\t\tAcked-by= Z\n"> <"\t\tReviewed-by:\n"> 
          <"\t\tSigned-off-by: Z\n"> <"\tEOF\n"> <"\tgit interpret-trailers --trailer \"ack: Peff\" --trailer \"review:\" \\\n"> 
          <"\t\t--trailer \"bug: 42\" --trailer \"ack: Peff\" \\\n"> <"\t\t<complex_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} 
      {(SQ <"using \"ifExists = addIfDifferentNeighbor\" with \"where = end\"">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.ack.ifExists \"addIfDifferentNeighbor\" &&\n"> 
          <"\tgit config trailer.ack.where \"end\" &&\n"> <"\tcat complex_message_body >expected &&\n"> <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> 
          <"\t\tBug #42\n"> <"\t\tFixes: Z\n"> <"\t\tAcked-by= Z\n"> <"\t\tReviewed-by:\n"> <"\t\tSigned-off-by: Z\n"> 
          <"\t\tAcked-by= Peff\n"> <"\t\tAcked-by= Junio\n"> <"\t\tTested-by: Jakub\n"> <"\t\tAcked-by= Junio\n"> <"\t\tAcked-by= Peff\n"> 
          <"\tEOF\n"> <"\tgit interpret-trailers --trailer \"ack: Peff\" --trailer \"review:\" \\\n"> 
          <"\t\t--trailer \"ack: Junio\" --trailer \"bug: 42\" \\\n"> <"\t\t--trailer \"Tested-by: Jakub\" --trailer \"ack: Junio\" \\\n"> 
          <"\t\t--trailer \"ack: Junio\" --trailer \"ack: Peff\" <complex_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} 
      {(SQ <"using \"ifExists = addIfDifferentNeighbor\"  with \"where = after\"">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.ack.ifExists \"addIfDifferentNeighbor\" &&\n"> 
          <"\tgit config trailer.ack.where \"after\" &&\n"> <"\tcat complex_message_body >expected &&\n"> <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> 
          <"\t\tBug #42\n"> <"\t\tFixes: Z\n"> <"\t\tAcked-by= Z\n"> <"\t\tAcked-by= Peff\n"> <"\t\tAcked-by= Junio\n"> 
          <"\t\tAcked-by= Peff\n"> <"\t\tReviewed-by:\n"> <"\t\tSigned-off-by: Z\n"> <"\t\tTested-by: Jakub\n"> <"\tEOF\n"> 
          <"\tgit interpret-trailers --trailer \"ack: Peff\" --trailer \"review:\" \\\n"> <"\t\t--trailer \"ack: Junio\" --trailer \"bug: 42\" \\\n"> 
          <"\t\t--trailer \"Tested-by: Jakub\" --trailer \"ack: Junio\" \\\n"> <"\t\t--trailer \"ack: Junio\" --trailer \"ack: Peff\" <complex_message >actual &&\n"> 
          <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"using \"ifExists = addIfDifferentNeighbor\" and --trim-empty">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.ack.ifExists \"addIfDifferentNeighbor\" &&\n"> 
          <"\tcat complex_message_body >expected &&\n"> <"\tcat >>expected <<-\\EOF &&\n"> <"\t\tBug #42\n"> <"\t\tAcked-by= Peff\n"> <"\t\tAcked-by= Junio\n"> 
          <"\t\tAcked-by= Peff\n"> <"\tEOF\n"> <"\tgit interpret-trailers --trim-empty --trailer \"ack: Peff\" \\\n"> 
          <"\t\t--trailer \"Acked-by= Peff\" --trailer \"review:\" \\\n"> <"\t\t--trailer \"ack: Junio\" --trailer \"bug: 42\" \\\n"> 
          <"\t\t--trailer \"ack: Peff\" <complex_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"using \"ifExists = add\" with \"where = end\"">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.ack.ifExists \"add\" &&\n"> 
          <"\tgit config trailer.ack.where \"end\" &&\n"> <"\tcat complex_message_body >expected &&\n"> <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> 
          <"\t\tBug #42\n"> <"\t\tFixes: Z\n"> <"\t\tAcked-by= Z\n"> <"\t\tReviewed-by:\n"> <"\t\tSigned-off-by: Z\n"> 
          <"\t\tAcked-by= Peff\n"> <"\t\tAcked-by= Peff\n"> <"\t\tTested-by: Jakub\n"> <"\t\tAcked-by= Junio\n"> 
          <"\t\tTested-by: Johannes\n"> <"\t\tAcked-by= Peff\n"> <"\tEOF\n"> <"\tgit interpret-trailers --trailer \"ack: Peff\" \\\n"> 
          <"\t\t--trailer \"Acked-by= Peff\" --trailer \"review:\" \\\n"> <"\t\t--trailer \"Tested-by: Jakub\" --trailer \"ack: Junio\" \\\n"> 
          <"\t\t--trailer \"bug: 42\" --trailer \"Tested-by: Johannes\" \\\n"> <"\t\t--trailer \"ack: Peff\" <complex_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"using \"ifExists = add\" with \"where = after\"">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.ack.ifExists \"add\" &&\n"> 
          <"\tgit config trailer.ack.where \"after\" &&\n"> <"\tcat complex_message_body >expected &&\n"> <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> 
          <"\t\tBug #42\n"> <"\t\tFixes: Z\n"> <"\t\tAcked-by= Z\n"> <"\t\tAcked-by= Peff\n"> <"\t\tAcked-by= Peff\n"> 
          <"\t\tAcked-by= Junio\n"> <"\t\tAcked-by= Peff\n"> <"\t\tReviewed-by:\n"> <"\t\tSigned-off-by: Z\n"> <"\tEOF\n"> 
          <"\tgit interpret-trailers --trailer \"ack: Peff\" \\\n"> <"\t\t--trailer \"Acked-by= Peff\" --trailer \"review:\" \\\n"> 
          <"\t\t--trailer \"ack: Junio\" --trailer \"bug: 42\" \\\n"> <"\t\t--trailer \"ack: Peff\" <complex_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"using \"ifExists = replace\"">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.fix.key \"Fixes: \" &&\n"> 
          <"\tgit config trailer.fix.ifExists \"replace\" &&\n"> <"\tcat complex_message_body >expected &&\n"> <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> 
          <"\t\tBug #42\n"> <"\t\tAcked-by= Z\n"> <"\t\tAcked-by= Junio\n"> <"\t\tAcked-by= Peff\n"> <"\t\tReviewed-by:\n"> 
          <"\t\tSigned-off-by: Z\n"> <"\t\tFixes: 22\n"> <"\tEOF\n"> <"\tgit interpret-trailers --trailer \"review:\" \\\n"> 
          <"\t\t--trailer \"fix=53\" --trailer \"ack: Junio\" --trailer \"fix=22\" \\\n"> <"\t\t--trailer \"bug: 42\" --trailer \"ack: Peff\" \\\n"> <"\t\t<complex_message >actual &&\n"> 
          <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"using \"ifExists = replace\" with \"where = after\"">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.fix.where \"after\" &&\n"> 
          <"\tcat complex_message_body >expected &&\n"> <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> <"\t\tBug #42\n"> <"\t\tFixes: 22\n"> 
          <"\t\tAcked-by= Z\n"> <"\t\tAcked-by= Junio\n"> <"\t\tAcked-by= Peff\n"> <"\t\tReviewed-by:\n"> <"\t\tSigned-off-by: Z\n"> 
          <"\tEOF\n"> <"\tgit interpret-trailers --trailer \"review:\" \\\n"> 
          <"\t\t--trailer \"fix=53\" --trailer \"ack: Junio\" --trailer \"fix=22\" \\\n"> <"\t\t--trailer \"bug: 42\" --trailer \"ack: Peff\" \\\n"> <"\t\t<complex_message >actual &&\n"> 
          <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"using \"ifExists = doNothing\"">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.fix.ifExists \"doNothing\" &&\n"> 
          <"\tcat complex_message_body >expected &&\n"> <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> <"\t\tBug #42\n"> <"\t\tFixes: Z\n"> 
          <"\t\tAcked-by= Z\n"> <"\t\tAcked-by= Junio\n"> <"\t\tAcked-by= Peff\n"> <"\t\tReviewed-by:\n"> <"\t\tSigned-off-by: Z\n"> 
          <"\tEOF\n"> <"\tgit interpret-trailers --trailer \"review:\" --trailer \"fix=53\" \\\n"> 
          <"\t\t--trailer \"ack: Junio\" --trailer \"fix=22\" \\\n"> <"\t\t--trailer \"bug: 42\" --trailer \"ack: Peff\" \\\n"> <"\t\t<complex_message >actual &&\n"> 
          <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"the default is \"ifMissing = add\"">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.cc.key \"Cc: \" &&\n"> 
          <"\tgit config trailer.cc.where \"before\" &&\n"> <"\tcat complex_message_body >expected &&\n"> <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> 
          <"\t\tBug #42\n"> <"\t\tCc: Linus\n"> <"\t\tFixes: Z\n"> <"\t\tAcked-by= Z\n"> <"\t\tAcked-by= Junio\n"> 
          <"\t\tAcked-by= Peff\n"> <"\t\tReviewed-by:\n"> <"\t\tSigned-off-by: Z\n"> <"\tEOF\n"> 
          <"\tgit interpret-trailers --trailer \"review:\" --trailer \"fix=53\" \\\n"> <"\t\t--trailer \"cc=Linus\" --trailer \"ack: Junio\" \\\n"> 
          <"\t\t--trailer \"fix=22\" --trailer \"bug: 42\" --trailer \"ack: Peff\" \\\n"> <"\t\t<complex_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"when default \"ifMissing\" is \"doNothing\"">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.ifmissing \"doNothing\" &&\n"> 
          <"\tcat complex_message_body >expected &&\n"> <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> <"\t\tFixes: Z\n"> <"\t\tAcked-by= Z\n"> 
          <"\t\tAcked-by= Junio\n"> <"\t\tAcked-by= Peff\n"> <"\t\tReviewed-by:\n"> <"\t\tSigned-off-by: Z\n"> <"\tEOF\n"> 
          <"\tgit interpret-trailers --trailer \"review:\" --trailer \"fix=53\" \\\n"> <"\t\t--trailer \"cc=Linus\" --trailer \"ack: Junio\" \\\n"> 
          <"\t\t--trailer \"fix=22\" --trailer \"bug: 42\" --trailer \"ack: Peff\" \\\n"> <"\t\t<complex_message >actual &&\n"> <"\ttest_cmp expected actual &&\n"> 
          <"\tgit config trailer.ifmissing \"add\"\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"using \"ifMissing = add\" with \"where = end\"">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.cc.key \"Cc: \" &&\n"> 
          <"\tgit config trailer.cc.where \"end\" &&\n"> <"\tgit config trailer.cc.ifMissing \"add\" &&\n"> <"\tcat complex_message_body >expected &&\n"> 
          <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> <"\t\tBug #42\n"> <"\t\tFixes: Z\n"> <"\t\tAcked-by= Z\n"> <"\t\tAcked-by= Junio\n"> 
          <"\t\tAcked-by= Peff\n"> <"\t\tReviewed-by:\n"> <"\t\tSigned-off-by: Z\n"> <"\t\tCc: Linus\n"> <"\tEOF\n"> 
          <"\tgit interpret-trailers --trailer \"review:\" --trailer \"fix=53\" \\\n"> <"\t\t--trailer \"ack: Junio\" --trailer \"fix=22\" \\\n"> 
          <"\t\t--trailer \"bug: 42\" --trailer \"cc=Linus\" --trailer \"ack: Peff\" \\\n"> <"\t\t<complex_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"using \"ifMissing = add\" with \"where = before\"">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.cc.key \"Cc: \" &&\n"> 
          <"\tgit config trailer.cc.where \"before\" &&\n"> <"\tgit config trailer.cc.ifMissing \"add\" &&\n"> <"\tcat complex_message_body >expected &&\n"> 
          <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> <"\t\tCc: Linus\n"> <"\t\tBug #42\n"> <"\t\tFixes: Z\n"> <"\t\tAcked-by= Z\n"> <"\t\tAcked-by= Junio\n"> 
          <"\t\tAcked-by= Peff\n"> <"\t\tReviewed-by:\n"> <"\t\tSigned-off-by: Z\n"> <"\tEOF\n"> 
          <"\tgit interpret-trailers --trailer \"review:\" --trailer \"fix=53\" \\\n"> <"\t\t--trailer \"ack: Junio\" --trailer \"fix=22\" \\\n"> 
          <"\t\t--trailer \"bug: 42\" --trailer \"cc=Linus\" --trailer \"ack: Peff\" \\\n"> <"\t\t<complex_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"using \"ifMissing = doNothing\"">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.cc.ifMissing \"doNothing\" &&\n"> 
          <"\tcat complex_message_body >expected &&\n"> <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> <"\t\tBug #42\n"> <"\t\tFixes: Z\n"> 
          <"\t\tAcked-by= Z\n"> <"\t\tAcked-by= Junio\n"> <"\t\tAcked-by= Peff\n"> <"\t\tReviewed-by:\n"> <"\t\tSigned-off-by: Z\n"> 
          <"\tEOF\n"> <"\tgit interpret-trailers --trailer \"review:\" --trailer \"fix=53\" \\\n"> 
          <"\t\t--trailer \"cc=Linus\" --trailer \"ack: Junio\" \\\n"> <"\t\t--trailer \"fix=22\" --trailer \"bug: 42\" --trailer \"ack: Peff\" \\\n"> 
          <"\t\t<complex_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"default \"where\" is now \"after\"">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.where \"after\" &&\n"> 
          <"\tgit config --unset trailer.ack.where &&\n"> <"\tcat complex_message_body >expected &&\n"> <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> 
          <"\t\tBug #42\n"> <"\t\tFixes: Z\n"> <"\t\tAcked-by= Z\n"> <"\t\tAcked-by= Peff\n"> <"\t\tAcked-by= Peff\n"> 
          <"\t\tAcked-by= Junio\n"> <"\t\tAcked-by= Peff\n"> <"\t\tReviewed-by:\n"> <"\t\tSigned-off-by: Z\n"> <"\t\tTested-by: Jakub\n"> 
          <"\t\tTested-by: Johannes\n"> <"\tEOF\n"> <"\tgit interpret-trailers --trailer \"ack: Peff\" \\\n"> 
          <"\t\t--trailer \"Acked-by= Peff\" --trailer \"review:\" \\\n"> <"\t\t--trailer \"Tested-by: Jakub\" --trailer \"ack: Junio\" \\\n"> 
          <"\t\t--trailer \"bug: 42\" --trailer \"Tested-by: Johannes\" \\\n"> <"\t\t--trailer \"ack: Peff\" <complex_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"with simple command">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.sign.key \"Signed-off-by: \" &&\n"> 
          <"\tgit config trailer.sign.where \"after\" &&\n"> <"\tgit config trailer.sign.ifExists \"addIfDifferentNeighbor\" &&\n"> 
          <"\tgit config trailer.sign.command \"echo \\\"A U Thor <author@example.com>\\\"\" &&\n"> <"\tcat complex_message_body >expected &&\n"> <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> 
          <"\t\tFixes: Z\n"> <"\t\tAcked-by= Z\n"> <"\t\tReviewed-by:\n"> <"\t\tSigned-off-by: Z\n"> 
          <"\t\tSigned-off-by: A U Thor <author@example.com>\n"> <"\tEOF\n"> <"\tgit interpret-trailers --trailer \"review:\" --trailer \"fix=22\" \\\n"> 
          <"\t\t<complex_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"with command using commiter information">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.sign.ifExists \"addIfDifferent\" &&\n"> 
          <
"\tgit config trailer.sign.command \"echo \\\"\\$GIT_COMMITTER_NAME <\\$GIT_COMMITTER_EMAIL>\\\"\" &&\n"
          > <"\tcat complex_message_body >expected &&\n"> <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> 
          <"\t\tFixes: Z\n"> <"\t\tAcked-by= Z\n"> <"\t\tReviewed-by:\n"> <"\t\tSigned-off-by: Z\n"> 
          <"\t\tSigned-off-by: C O Mitter <committer@example.com>\n"> <"\tEOF\n"> <"\tgit interpret-trailers --trailer \"review:\" --trailer \"fix=22\" \\\n"> 
          <"\t\t<complex_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"with command using author information">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.sign.key \"Signed-off-by: \" &&\n"> 
          <"\tgit config trailer.sign.where \"after\" &&\n"> <"\tgit config trailer.sign.ifExists \"addIfDifferentNeighbor\" &&\n"> 
          <
"\tgit config trailer.sign.command \"echo \\\"\\$GIT_AUTHOR_NAME <\\$GIT_AUTHOR_EMAIL>\\\"\" &&\n"
          > <"\tcat complex_message_body >expected &&\n"> <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-\\EOF &&\n"> 
          <"\t\tFixes: Z\n"> <"\t\tAcked-by= Z\n"> <"\t\tReviewed-by:\n"> <"\t\tSigned-off-by: Z\n"> 
          <"\t\tSigned-off-by: A U Thor <author@example.com>\n"> <"\tEOF\n"> <"\tgit interpret-trailers --trailer \"review:\" --trailer \"fix=22\" \\\n"> 
          <"\t\t<complex_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"setup a commit">)} 
      {
        (SQ <"\n"> <"\techo \"Content of the first commit.\" > a.txt &&\n"> <"\tgit add a.txt &&\n"> 
          <"\tgit commit -m \"Add file a.txt\"\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"with command using $ARG">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.fix.ifExists \"replace\" &&\n"> 
          <
"\tgit config trailer.fix.command \"git log -1 --oneline --format=\\\"%h (%s)\\\" --abbrev-commit --abbrev=14 \\$ARG\" &&\n"
          > <"\tFIXED=$(git log -1 --oneline --format=\"%h (%s)\" --abbrev-commit --abbrev=14 HEAD) &&\n"> 
          <"\tcat complex_message_body >expected &&\n"> <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-EOF &&\n"> <"\t\tFixes: $FIXED\n"> <"\t\tAcked-by= Z\n"> 
          <"\t\tReviewed-by:\n"> <"\t\tSigned-off-by: Z\n"> <"\t\tSigned-off-by: A U Thor <author@example.com>\n"> <"\tEOF\n"> 
          <"\tgit interpret-trailers --trailer \"review:\" --trailer \"fix=HEAD\" \\\n"> <"\t\t<complex_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"with failing command using $ARG">)} 
      {
        (SQ <"\n"> <"\tgit config trailer.fix.ifExists \"replace\" &&\n"> 
          <"\tgit config trailer.fix.command \"false \\$ARG\" &&\n"> <"\tcat complex_message_body >expected &&\n"> <"\tsed -e \"s/ Z\\$/ /\" >>expected <<-EOF &&\n"> 
          <"\t\tFixes: Z\n"> <"\t\tAcked-by= Z\n"> <"\t\tReviewed-by:\n"> <"\t\tSigned-off-by: Z\n"> 
          <"\t\tSigned-off-by: A U Thor <author@example.com>\n"> <"\tEOF\n"> <"\tgit interpret-trailers --trailer \"review:\" --trailer \"fix=HEAD\" \\\n"> 
          <"\t\t<complex_message >actual &&\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"with empty tokens">)} 
      {
        (SQ <"\n"> <"\tgit config --unset trailer.fix.command &&\n"> <"\tcat >expected <<-EOF &&\n"> 
          <"\n"> <"\t\tSigned-off-by: A U Thor <author@example.com>\n"> <"\tEOF\n"> 
          <"\tgit interpret-trailers --trailer \":\" --trailer \":test\" >actual <<-EOF &&\n"> <"\tEOF\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"with command but no key">)} 
      {
        (SQ <"\n"> <"\tgit config --unset trailer.sign.key &&\n"> <"\tcat >expected <<-EOF &&\n"> <"\n"> 
          <"\t\tsign: A U Thor <author@example.com>\n"> <"\tEOF\n"> <"\tgit interpret-trailers >actual <<-EOF &&\n"> <"\tEOF\n"> 
          <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"with no command and no key">)} 
      {
        (SQ <"\n"> <"\tgit config --unset trailer.review.key &&\n"> <"\tcat >expected <<-EOF &&\n"> 
          <"\n"> <"\t\treview: Junio\n"> <"\t\tsign: A U Thor <author@example.com>\n"> <"\tEOF\n"> 
          <"\tgit interpret-trailers --trailer \"review:Junio\" >actual <<-EOF &&\n"> <"\tEOF\n"> <"\ttest_cmp expected actual\n">
        )
      }
    )
    (C {(test_done)})
  ]
)