3 test_description='git am running'
 
   7 test_expect_success 'setup: messages' '
 
  11         Lorem ipsum dolor sit amet, consectetuer sadipscing elitr, sed diam nonumy
 
  12         eirmod tempor invidunt ut labore et dolore magna aliquyam erat, sed diam
 
  13         voluptua. At vero eos et accusam et justo duo dolores et ea rebum. Stet clita
 
  14         kasd gubergren, no sea takimata sanctus est Lorem ipsum dolor sit amet. Lorem
 
  15         ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod
 
  16         tempor invidunt ut labore et dolore magna aliquyam erat, sed diam voluptua. At
 
  17         vero eos et accusam et justo duo dolores et ea rebum.
 
  20         q_to_tab <<-\EOF >>msg &&
 
  21         QDuis autem vel eum iriure dolor in hendrerit in vulputate velit
 
  22         Qesse molestie consequat, vel illum dolore eu feugiat nulla facilisis
 
  23         Qat vero eros et accumsan et iusto odio dignissim qui blandit
 
  24         Qpraesent luptatum zzril delenit augue duis dolore te feugait nulla
 
  29         Lorem ipsum dolor sit amet,
 
  30         consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut
 
  31         laoreet dolore magna aliquam erat volutpat.
 
  37         Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit
 
  38         lobortis nisl ut aliquip ex ea commodo consequat. Duis autem vel eum iriure
 
  39         dolor in hendrerit in vulputate velit esse molestie consequat, vel illum
 
  40         dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio
 
  41         dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te
 
  42         feugait nulla facilisi.
 
  45         cat >failmail <<-\EOF &&
 
  46         From foo@example.com Fri May 23 10:43:49 2008
 
  49         Subject: Re: [RFC/PATCH] git-foo.sh
 
  50         Date:   Fri, 23 May 2008 05:23:42 +0200
 
  52         Sometimes we have to find out that there'\''s nothing left.
 
  57         From MAILER-DAEMON Fri May 23 10:43:49 2008
 
  58         Date: 23 May 2008 05:23:42 +0200
 
  59         From: Mail System Internal Data <MAILER-DAEMON@example.com>
 
  60         Subject: DON'\''T DELETE THIS MESSAGE -- FOLDER INTERNAL DATA
 
  61         Message-ID: <foo-0001@example.com>
 
  63         This text is part of the internal format of your mail folder, and is not
 
  64         a real message.  It is created automatically by the mail system software.
 
  65         If deleted, important folder data will be lost, and it will be re-created
 
  66         with the data reset to initial values.
 
  70         signoff="Signed-off-by: $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL>"
 
  73 test_expect_success setup '
 
  77         git commit -m first &&
 
  83         git commit -s -F msg &&
 
  86         git format-patch --stdout first >patch1 &&
 
  88                 echo "X-Fake-Field: Line One" &&
 
  89                 echo "X-Fake-Field: Line Two" &&
 
  90                 echo "X-Fake-Field: Line Three" &&
 
  91                 git format-patch --stdout first | sed -e "1d"
 
  94                 echo "X-Fake-Field: Line One" &&
 
  95                 echo "X-Fake-Field: Line Two" &&
 
  96                 echo "X-Fake-Field: Line Three" &&
 
  97                 git format-patch --stdout first | sed -e "1d"
 
  98         } | append_cr >patch1-crlf.eml &&
 
 100         sed -n -e "3,\$p" msg >file &&
 
 103         git commit -m third &&
 
 105         git format-patch --stdout first >patch2 &&
 
 107         git checkout -b lorem &&
 
 108         sed -n -e "11,\$p" msg >file &&
 
 109         head -n 9 msg >>file &&
 
 111         git commit -a -m "moved stuff" &&
 
 113         echo goodbye >another &&
 
 116         git commit -m "added another file" &&
 
 118         git format-patch --stdout master >lorem-move.patch &&
 
 120         git checkout -b rename &&
 
 121         git mv file renamed &&
 
 122         git commit -m "renamed a file" &&
 
 124         git format-patch -M --stdout lorem >rename.patch &&
 
 126         git reset --soft lorem^ &&
 
 127         git commit -m "renamed a file and added another" &&
 
 129         git format-patch -M --stdout lorem^ >rename-add.patch &&
 
 136 test_expect_success 'am applies patch correctly' '
 
 137         rm -fr .git/rebase-apply &&
 
 139         git checkout first &&
 
 142         ! test -d .git/rebase-apply &&
 
 143         git diff --exit-code second &&
 
 144         test "$(git rev-parse second)" = "$(git rev-parse HEAD)" &&
 
 145         test "$(git rev-parse second^)" = "$(git rev-parse HEAD^)"
 
 148 test_expect_success 'am applies patch e-mail not in a mbox' '
 
 149         rm -fr .git/rebase-apply &&
 
 151         git checkout first &&
 
 153         ! test -d .git/rebase-apply &&
 
 154         git diff --exit-code second &&
 
 155         test "$(git rev-parse second)" = "$(git rev-parse HEAD)" &&
 
 156         test "$(git rev-parse second^)" = "$(git rev-parse HEAD^)"
 
 159 test_expect_success 'am applies patch e-mail not in a mbox with CRLF' '
 
 160         rm -fr .git/rebase-apply &&
 
 162         git checkout first &&
 
 163         git am patch1-crlf.eml &&
 
 164         ! test -d .git/rebase-apply &&
 
 165         git diff --exit-code second &&
 
 166         test "$(git rev-parse second)" = "$(git rev-parse HEAD)" &&
 
 167         test "$(git rev-parse second^)" = "$(git rev-parse HEAD^)"
 
 170 test_expect_success 'setup: new author and committer' '
 
 171         GIT_AUTHOR_NAME="Another Thor" &&
 
 172         GIT_AUTHOR_EMAIL="a.thor@example.com" &&
 
 173         GIT_COMMITTER_NAME="Co M Miter" &&
 
 174         GIT_COMMITTER_EMAIL="c.miter@example.com" &&
 
 175         export GIT_AUTHOR_NAME GIT_AUTHOR_EMAIL GIT_COMMITTER_NAME GIT_COMMITTER_EMAIL
 
 179         a=$(git cat-file commit "$2" | grep "^$1 ") &&
 
 180         b=$(git cat-file commit "$3" | grep "^$1 ") &&
 
 184 test_expect_success 'am changes committer and keeps author' '
 
 186         rm -fr .git/rebase-apply &&
 
 188         git checkout first &&
 
 190         ! test -d .git/rebase-apply &&
 
 191         test "$(git rev-parse master^^)" = "$(git rev-parse HEAD^^)" &&
 
 192         git diff --exit-code master..HEAD &&
 
 193         git diff --exit-code master^..HEAD^ &&
 
 194         compare author master HEAD &&
 
 195         compare author master^ HEAD^ &&
 
 196         test "$GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL>" = \
 
 197              "$(git log -1 --pretty=format:"%cn <%ce>" HEAD)"
 
 200 test_expect_success 'am --signoff adds Signed-off-by: line' '
 
 201         rm -fr .git/rebase-apply &&
 
 203         git checkout -b master2 first &&
 
 204         git am --signoff <patch2 &&
 
 205         printf "%s\n" "$signoff" >expected &&
 
 206         echo "Signed-off-by: $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL>" >>expected &&
 
 207         git cat-file commit HEAD^ | grep "Signed-off-by:" >actual &&
 
 208         test_cmp expected actual &&
 
 209         echo "Signed-off-by: $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL>" >expected &&
 
 210         git cat-file commit HEAD | grep "Signed-off-by:" >actual &&
 
 211         test_cmp expected actual
 
 214 test_expect_success 'am stays in branch' '
 
 215         echo refs/heads/master2 >expected &&
 
 216         git symbolic-ref HEAD >actual &&
 
 217         test_cmp expected actual
 
 220 test_expect_success 'am --signoff does not add Signed-off-by: line if already there' '
 
 221         git format-patch --stdout HEAD^ >patch3 &&
 
 222         sed -e "/^Subject/ s,\[PATCH,Re: Re: Re: & 1/5 v2," patch3 >patch4 &&
 
 223         rm -fr .git/rebase-apply &&
 
 225         git checkout HEAD^ &&
 
 226         git am --signoff patch4 &&
 
 227         git cat-file commit HEAD >actual &&
 
 228         test $(grep -c "^Signed-off-by:" actual) -eq 1
 
 231 test_expect_success 'am without --keep removes Re: and [PATCH] stuff' '
 
 232         git rev-parse HEAD >expected &&
 
 233         git rev-parse master2 >actual &&
 
 234         test_cmp expected actual
 
 237 test_expect_success 'am --keep really keeps the subject' '
 
 238         rm -fr .git/rebase-apply &&
 
 240         git checkout HEAD^ &&
 
 241         git am --keep patch4 &&
 
 242         ! test -d .git/rebase-apply &&
 
 243         git cat-file commit HEAD >actual &&
 
 244         grep "Re: Re: Re: \[PATCH 1/5 v2\] third" actual
 
 247 test_expect_success 'am -3 falls back to 3-way merge' '
 
 248         rm -fr .git/rebase-apply &&
 
 250         git checkout -b lorem2 master2 &&
 
 251         sed -n -e "3,\$p" msg >file &&
 
 252         head -n 9 msg >>file &&
 
 255         git commit -m "copied stuff" &&
 
 256         git am -3 lorem-move.patch &&
 
 257         ! test -d .git/rebase-apply &&
 
 258         git diff --exit-code lorem
 
 261 test_expect_success 'am can rename a file' '
 
 262         grep "^rename from" rename.patch &&
 
 263         rm -fr .git/rebase-apply &&
 
 265         git checkout lorem^0 &&
 
 266         git am rename.patch &&
 
 267         ! test -d .git/rebase-apply &&
 
 268         git update-index --refresh &&
 
 269         git diff --exit-code rename
 
 272 test_expect_success 'am -3 can rename a file' '
 
 273         grep "^rename from" rename.patch &&
 
 274         rm -fr .git/rebase-apply &&
 
 276         git checkout lorem^0 &&
 
 277         git am -3 rename.patch &&
 
 278         ! test -d .git/rebase-apply &&
 
 279         git update-index --refresh &&
 
 280         git diff --exit-code rename
 
 283 test_expect_success 'am -3 can rename a file after falling back to 3-way merge' '
 
 284         grep "^rename from" rename-add.patch &&
 
 285         rm -fr .git/rebase-apply &&
 
 287         git checkout lorem^0 &&
 
 288         git am -3 rename-add.patch &&
 
 289         ! test -d .git/rebase-apply &&
 
 290         git update-index --refresh &&
 
 291         git diff --exit-code rename
 
 294 test_expect_success 'am -3 -q is quiet' '
 
 295         rm -fr .git/rebase-apply &&
 
 296         git checkout -f lorem2 &&
 
 297         git reset master2 --hard &&
 
 298         sed -n -e "3,\$p" msg >file &&
 
 299         head -n 9 msg >>file &&
 
 302         git commit -m "copied stuff" &&
 
 303         git am -3 -q lorem-move.patch >output.out 2>&1 &&
 
 307 test_expect_success 'am pauses on conflict' '
 
 308         rm -fr .git/rebase-apply &&
 
 310         git checkout lorem2^^ &&
 
 311         test_must_fail git am lorem-move.patch &&
 
 312         test -d .git/rebase-apply
 
 315 test_expect_success 'am --skip works' '
 
 316         echo goodbye >expected &&
 
 318         ! test -d .git/rebase-apply &&
 
 319         git diff --exit-code lorem2^^ -- file &&
 
 320         test_cmp expected another
 
 323 test_expect_success 'am --resolved works' '
 
 324         echo goodbye >expected &&
 
 325         rm -fr .git/rebase-apply &&
 
 327         git checkout lorem2^^ &&
 
 328         test_must_fail git am lorem-move.patch &&
 
 329         test -d .git/rebase-apply &&
 
 330         echo resolved >>file &&
 
 333         ! test -d .git/rebase-apply &&
 
 334         test_cmp expected another
 
 337 test_expect_success 'am takes patches from a Pine mailbox' '
 
 338         rm -fr .git/rebase-apply &&
 
 340         git checkout first &&
 
 341         cat pine patch1 | git am &&
 
 342         ! test -d .git/rebase-apply &&
 
 343         git diff --exit-code master^..HEAD
 
 346 test_expect_success 'am fails on mail without patch' '
 
 347         rm -fr .git/rebase-apply &&
 
 349         test_must_fail git am <failmail &&
 
 351         ! test -d .git/rebase-apply
 
 354 test_expect_success 'am fails on empty patch' '
 
 355         rm -fr .git/rebase-apply &&
 
 357         echo "---" >>failmail &&
 
 358         test_must_fail git am <failmail &&
 
 360         ! test -d .git/rebase-apply
 
 363 test_expect_success 'am works from stdin in subdirectory' '
 
 365         rm -fr .git/rebase-apply &&
 
 367         git checkout first &&
 
 373         git diff --exit-code second
 
 376 test_expect_success 'am works from file (relative path given) in subdirectory' '
 
 378         rm -fr .git/rebase-apply &&
 
 380         git checkout first &&
 
 386         git diff --exit-code second
 
 389 test_expect_success 'am works from file (absolute path given) in subdirectory' '
 
 391         rm -fr .git/rebase-apply &&
 
 393         git checkout first &&
 
 400         git diff --exit-code second
 
 403 test_expect_success 'am --committer-date-is-author-date' '
 
 404         rm -fr .git/rebase-apply &&
 
 406         git checkout first &&
 
 408         git am --committer-date-is-author-date patch1 &&
 
 409         git cat-file commit HEAD | sed -e "/^\$/q" >head1 &&
 
 410         sed -ne "/^author /s/.*> //p" head1 >at &&
 
 411         sed -ne "/^committer /s/.*> //p" head1 >ct &&
 
 415 test_expect_success 'am without --committer-date-is-author-date' '
 
 416         rm -fr .git/rebase-apply &&
 
 418         git checkout first &&
 
 421         git cat-file commit HEAD | sed -e "/^\$/q" >head1 &&
 
 422         sed -ne "/^author /s/.*> //p" head1 >at &&
 
 423         sed -ne "/^committer /s/.*> //p" head1 >ct &&
 
 427 # This checks for +0000 because TZ is set to UTC and that should
 
 428 # show up when the current time is used. The date in message is set
 
 429 # by test_tick that uses -0700 timezone; if this feature does not
 
 430 # work, we will see that instead of +0000.
 
 431 test_expect_success 'am --ignore-date' '
 
 432         rm -fr .git/rebase-apply &&
 
 434         git checkout first &&
 
 436         git am --ignore-date patch1 &&
 
 437         git cat-file commit HEAD | sed -e "/^\$/q" >head1 &&
 
 438         sed -ne "/^author /s/.*> //p" head1 >at &&
 
 442 test_expect_success 'am into an unborn branch' '
 
 443         git rev-parse first^{tree} >expected &&
 
 444         rm -fr .git/rebase-apply &&
 
 448         git format-patch --numbered-files -o subdir -1 first &&
 
 456                 git rev-parse HEAD^{tree} >../actual
 
 458         test_cmp expected actual
 
 461 test_expect_success 'am newline in subject' '
 
 462         rm -fr .git/rebase-apply &&
 
 464         git checkout first &&
 
 466         sed -e "s/second/second \\\n foo/" patch1 >patchnl &&
 
 467         git am <patchnl >output.out 2>&1 &&
 
 468         grep "^Applying: second \\\n foo$" output.out
 
 471 test_expect_success 'am -q is quiet' '
 
 472         rm -fr .git/rebase-apply &&
 
 474         git checkout first &&
 
 476         git am -q <patch1 >output.out 2>&1 &&