(CommandList
  children: [
    (Assignment
      keyword: Assign_None
      pairs: [
        (assign_pair
          lhs: (LhsName name:test_description)
          op: Equal
          rhs: {(SQ <'messages from rebase operation'>)}
          spids: [4]
        )
      ]
      spids: [4]
    )
    (C {(.)} {(./test-lib.sh)})
    (C {(test_expect_success)} {(SQ <setup>)} 
      {
        (SQ <'\n'> <'\ttest_commit O fileO &&\n'> <'\ttest_commit X fileX &&\n'> 
          <'\ttest_commit A fileA &&\n'> <'\ttest_commit B fileB &&\n'> <'\ttest_commit Y fileY &&\n'> <'\n'> <'\tgit checkout -b topic O &&\n'> 
          <'\tgit cherry-pick A B &&\n'> <'\ttest_commit Z fileZ &&\n'> <'\tgit tag start\n'>
        )
      }
    )
    (SimpleCommand
      words: [{(cat)}]
      redirects: [
        (Redir op_id:Redir_Great fd:-1 arg_word:{(expect)} spids:[38])
        (HereDoc
          op_id: Redir_DLess
          fd: -1
          body: {('Already applied: 0001 A\n') ('Already applied: 0002 B\n') ('Committed: 0003 Z\n')}
          do_expansion: False
          here_end: EOF
          was_filled: True
          spids: [41]
        )
      ]
    )
    (C {(test_expect_success)} {(SQ <'rebase -m'>)} 
      {
        (SQ <'\n'> <'\tgit rebase -m master >report &&\n'> <'\tsed -n -e "/^Already applied: /p" \\\n'> 
          <'\t\t-e "/^Committed: /p" report >actual &&\n'> <'\ttest_cmp expect actual\n'>
        )
      }
    )
    (C {(test_expect_success)} {(SQ <'rebase against master twice'>)} 
      {
        (SQ <'\n'> <'\tgit rebase master >out &&\n'> 
          <'\ttest_i18ngrep "Current branch topic is up to date" out\n'>
        )
      }
    )
    (C {(test_expect_success)} {(SQ <'rebase against master twice with --force'>)} 
      {
        (SQ <'\n'> <'\tgit rebase --force-rebase master >out &&\n'> 
          <'\ttest_i18ngrep "Current branch topic is up to date, rebase forced" out\n'>
        )
      }
    )
    (C {(test_expect_success)} {(SQ <'rebase against master twice from another branch'>)} 
      {
        (SQ <'\n'> <'\tgit checkout topic^ &&\n'> <'\tgit rebase master topic >out &&\n'> 
          <'\ttest_i18ngrep "Current branch topic is up to date" out\n'>
        )
      }
    )
    (C {(test_expect_success)} {(SQ <'rebase fast-forward to master'>)} 
      {
        (SQ <'\n'> <'\tgit checkout topic^ &&\n'> <'\tgit rebase topic >out &&\n'> 
          <'\ttest_i18ngrep "Fast-forwarded HEAD to topic" out\n'>
        )
      }
    )
    (C {(test_expect_success)} {(SQ <'rebase --stat'>)} 
      {
        (SQ <'\n'> <'\tgit reset --hard start &&\n'> 
          <'        git rebase --stat master >diffstat.txt &&\n'> <'        grep "^ fileX |  *1 +$" diffstat.txt\n'>
        )
      }
    )
    (C {(test_expect_success)} {(SQ <'rebase w/config rebase.stat'>)} 
      {
        (SQ <'\n'> <'\tgit reset --hard start &&\n'> <'        git config rebase.stat true &&\n'> 
          <'        git rebase master >diffstat.txt &&\n'> <'        grep "^ fileX |  *1 +$" diffstat.txt\n'>
        )
      }
    )
    (C {(test_expect_success)} {(SQ <'rebase -n overrides config rebase.stat config'>)} 
      {
        (SQ <'\n'> <'\tgit reset --hard start &&\n'> <'        git config rebase.stat true &&\n'> 
          <'        git rebase -n master >diffstat.txt &&\n'> <'        ! grep "^ fileX |  *1 +$" diffstat.txt\n'>
        )
      }
    )
    (C {(test_expect_success)} {(SQ <'rebase --onto outputs the invalid ref'>)} 
      {
        (SQ <'\n'> <'\ttest_must_fail git rebase --onto invalid-ref HEAD HEAD 2>err &&\n'> 
          <'\ttest_i18ngrep "invalid-ref" err\n'>
        )
      }
    )
    (C {(test_done)})
  ]
)