(command.CommandList
  children: [
    (command.Assignment
      keyword: Assign_None
      pairs: [
        (assign_pair
          lhs: (lhs_expr.LhsName name:test_description spids:[12])
          op: Equal
          rhs: {(SQ <'git-merge with case-changing rename on case-insensitive file system'>)}
          spids: [12]
        )
      ]
      spids: [12]
    )
    (C {(.)} {(./test-lib.sh)})
    (command.If
      arms: [
        (if_arm
          cond: [
            (command.Pipeline
              children: [(C {(test_have_prereq)} {(CASE_INSENSITIVE_FS)})]
              negated: T
            )
          ]
          action: [
            (command.Assignment
              keyword: Assign_None
              pairs: [
                (assign_pair
                  lhs: (lhs_expr.LhsName name:skip_all spids:[34])
                  op: Equal
                  rhs: {(SQ <'skipping case insensitive tests - case sensitive file system'>)}
                  spids: [34]
                )
              ]
              spids: [34]
            )
            (C {(test_done)})
          ]
          spids: [16777215 31]
        )
      ]
      spids: [16777215 42]
    )
    (C {(test_expect_success)} {(SQ <'merge with case-changing rename'>)} 
      {
        (SQ <'\n'> <'\ttest $(git config core.ignorecase) = true &&\n'> <'\t>TestCase &&\n'> 
          <'\tgit add TestCase &&\n'> <'\tgit commit -m "add TestCase" &&\n'> <'\tgit tag baseline &&\n'> 
          <'\tgit checkout -b with-camel &&\n'> <'\t>foo &&\n'> <'\tgit add foo &&\n'> <'\tgit commit -m "intervening commit" &&\n'> 
          <'\tgit checkout master &&\n'> <'\tgit rm TestCase &&\n'> <'\t>testcase &&\n'> <'\tgit add testcase &&\n'> 
          <'\tgit commit -m "rename to testcase" &&\n'> <'\tgit checkout with-camel &&\n'> <'\tgit merge master -m "merge" &&\n'> 
          <'\ttest_path_is_file testcase\n'>
        )
      }
    )
    (C {(test_expect_success)} {(SQ <'merge with case-changing rename on both sides'>)} 
      {
        (SQ <'\n'> <'\tgit checkout master &&\n'> <'\tgit reset --hard baseline &&\n'> 
          <'\tgit branch -D with-camel &&\n'> <'\tgit checkout -b with-camel &&\n'> <'\tgit mv TestCase testcase &&\n'> 
          <'\tgit commit -m "recase on branch" &&\n'> <'\t>foo &&\n'> <'\tgit add foo &&\n'> <'\tgit commit -m "intervening commit" &&\n'> 
          <'\tgit checkout master &&\n'> <'\tgit rm TestCase &&\n'> <'\t>testcase &&\n'> <'\tgit add testcase &&\n'> 
          <'\tgit commit -m "rename to testcase" &&\n'> <'\tgit checkout with-camel &&\n'> <'\tgit merge master -m "merge" &&\n'> 
          <'\ttest_path_is_file testcase\n'>
        )
      }
    )
    (C {(test_done)})
  ]
)