You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
334 lines
9.2 KiB
334 lines
9.2 KiB
#!/bin/sh |
|
|
|
test_description='git am running' |
|
|
|
. ./test-lib.sh |
|
|
|
cat >msg <<EOF |
|
second |
|
|
|
Lorem ipsum dolor sit amet, consectetuer sadipscing elitr, sed diam nonumy |
|
eirmod tempor invidunt ut labore et dolore magna aliquyam erat, sed diam |
|
voluptua. At vero eos et accusam et justo duo dolores et ea rebum. Stet clita |
|
kasd gubergren, no sea takimata sanctus est Lorem ipsum dolor sit amet. Lorem |
|
ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod |
|
tempor invidunt ut labore et dolore magna aliquyam erat, sed diam voluptua. At |
|
vero eos et accusam et justo duo dolores et ea rebum. |
|
|
|
Duis autem vel eum iriure dolor in hendrerit in vulputate velit |
|
esse molestie consequat, vel illum dolore eu feugiat nulla facilisis |
|
at vero eros et accumsan et iusto odio dignissim qui blandit |
|
praesent luptatum zzril delenit augue duis dolore te feugait nulla |
|
facilisi. |
|
|
|
|
|
Lorem ipsum dolor sit amet, |
|
consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut |
|
laoreet dolore magna aliquam erat volutpat. |
|
|
|
git |
|
--- |
|
+++ |
|
|
|
Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit |
|
lobortis nisl ut aliquip ex ea commodo consequat. Duis autem vel eum iriure |
|
dolor in hendrerit in vulputate velit esse molestie consequat, vel illum |
|
dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio |
|
dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te |
|
feugait nulla facilisi. |
|
EOF |
|
|
|
cat >failmail <<EOF |
|
From foo@example.com Fri May 23 10:43:49 2008 |
|
From: foo@example.com |
|
To: bar@example.com |
|
Subject: Re: [RFC/PATCH] git-foo.sh |
|
Date: Fri, 23 May 2008 05:23:42 +0200 |
|
|
|
Sometimes we have to find out that there's nothing left. |
|
|
|
EOF |
|
|
|
cat >pine <<EOF |
|
From MAILER-DAEMON Fri May 23 10:43:49 2008 |
|
Date: 23 May 2008 05:23:42 +0200 |
|
From: Mail System Internal Data <MAILER-DAEMON@example.com> |
|
Subject: DON'T DELETE THIS MESSAGE -- FOLDER INTERNAL DATA |
|
Message-ID: <foo-0001@example.com> |
|
|
|
This text is part of the internal format of your mail folder, and is not |
|
a real message. It is created automatically by the mail system software. |
|
If deleted, important folder data will be lost, and it will be re-created |
|
with the data reset to initial values. |
|
|
|
EOF |
|
|
|
echo "Signed-off-by: $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL>" >expected |
|
|
|
test_expect_success setup ' |
|
echo hello >file && |
|
git add file && |
|
test_tick && |
|
git commit -m first && |
|
git tag first && |
|
echo world >>file && |
|
git add file && |
|
test_tick && |
|
git commit -s -F msg && |
|
git tag second && |
|
git format-patch --stdout first >patch1 && |
|
sed -n -e "3,\$p" msg >file && |
|
git add file && |
|
test_tick && |
|
git commit -m third && |
|
git format-patch --stdout first >patch2 && |
|
git checkout -b lorem && |
|
sed -n -e "11,\$p" msg >file && |
|
head -n 9 msg >>file && |
|
test_tick && |
|
git commit -a -m "moved stuff" && |
|
echo goodbye >another && |
|
git add another && |
|
test_tick && |
|
git commit -m "added another file" && |
|
git format-patch --stdout master >lorem-move.patch |
|
' |
|
|
|
# reset time |
|
unset test_tick |
|
test_tick |
|
|
|
test_expect_success 'am applies patch correctly' ' |
|
git checkout first && |
|
test_tick && |
|
git am <patch1 && |
|
! test -d .git/rebase-apply && |
|
test -z "$(git diff second)" && |
|
test "$(git rev-parse second)" = "$(git rev-parse HEAD)" && |
|
test "$(git rev-parse second^)" = "$(git rev-parse HEAD^)" |
|
' |
|
|
|
GIT_AUTHOR_NAME="Another Thor" |
|
GIT_AUTHOR_EMAIL="a.thor@example.com" |
|
GIT_COMMITTER_NAME="Co M Miter" |
|
GIT_COMMITTER_EMAIL="c.miter@example.com" |
|
export GIT_AUTHOR_NAME GIT_AUTHOR_EMAIL GIT_COMMITTER_NAME GIT_COMMITTER_EMAIL |
|
|
|
compare () { |
|
test "$(git cat-file commit "$2" | grep "^$1 ")" = \ |
|
"$(git cat-file commit "$3" | grep "^$1 ")" |
|
} |
|
|
|
test_expect_success 'am changes committer and keeps author' ' |
|
test_tick && |
|
git checkout first && |
|
git am patch2 && |
|
! test -d .git/rebase-apply && |
|
test "$(git rev-parse master^^)" = "$(git rev-parse HEAD^^)" && |
|
test -z "$(git diff master..HEAD)" && |
|
test -z "$(git diff master^..HEAD^)" && |
|
compare author master HEAD && |
|
compare author master^ HEAD^ && |
|
test "$GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL>" = \ |
|
"$(git log -1 --pretty=format:"%cn <%ce>" HEAD)" |
|
' |
|
|
|
test_expect_success 'am --signoff adds Signed-off-by: line' ' |
|
git checkout -b master2 first && |
|
git am --signoff <patch2 && |
|
echo "Signed-off-by: $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL>" >>expected && |
|
git cat-file commit HEAD^ | grep "Signed-off-by:" >actual && |
|
test_cmp actual expected && |
|
echo "Signed-off-by: $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL>" >expected && |
|
git cat-file commit HEAD | grep "Signed-off-by:" >actual && |
|
test_cmp actual expected |
|
' |
|
|
|
test_expect_success 'am stays in branch' ' |
|
test "refs/heads/master2" = "$(git symbolic-ref HEAD)" |
|
' |
|
|
|
test_expect_success 'am --signoff does not add Signed-off-by: line if already there' ' |
|
git format-patch --stdout HEAD^ >patch3 && |
|
sed -e "/^Subject/ s,\[PATCH,Re: Re: Re: & 1/5 v2," patch3 >patch4 |
|
git checkout HEAD^ && |
|
git am --signoff patch4 && |
|
test "$(git cat-file commit HEAD | grep -c "^Signed-off-by:")" -eq 1 |
|
' |
|
|
|
test_expect_success 'am without --keep removes Re: and [PATCH] stuff' ' |
|
test "$(git rev-parse HEAD)" = "$(git rev-parse master2)" |
|
' |
|
|
|
test_expect_success 'am --keep really keeps the subject' ' |
|
git checkout HEAD^ && |
|
git am --keep patch4 && |
|
! test -d .git/rebase-apply && |
|
git cat-file commit HEAD | |
|
fgrep "Re: Re: Re: [PATCH 1/5 v2] third" |
|
' |
|
|
|
test_expect_success 'am -3 falls back to 3-way merge' ' |
|
git checkout -b lorem2 master2 && |
|
sed -n -e "3,\$p" msg >file && |
|
head -n 9 msg >>file && |
|
git add file && |
|
test_tick && |
|
git commit -m "copied stuff" && |
|
git am -3 lorem-move.patch && |
|
! test -d .git/rebase-apply && |
|
test -z "$(git diff lorem)" |
|
' |
|
|
|
test_expect_success 'am -3 -q is quiet' ' |
|
git reset master2 --hard && |
|
sed -n -e "3,\$p" msg >file && |
|
head -n 9 msg >>file && |
|
git add file && |
|
test_tick && |
|
git commit -m "copied stuff" && |
|
git am -3 -q lorem-move.patch > output.out 2>&1 && |
|
! test -s output.out |
|
' |
|
|
|
test_expect_success 'am pauses on conflict' ' |
|
git checkout lorem2^^ && |
|
test_must_fail git am lorem-move.patch && |
|
test -d .git/rebase-apply |
|
' |
|
|
|
test_expect_success 'am --skip works' ' |
|
git am --skip && |
|
! test -d .git/rebase-apply && |
|
test -z "$(git diff lorem2^^ -- file)" && |
|
test goodbye = "$(cat another)" |
|
' |
|
|
|
test_expect_success 'am --resolved works' ' |
|
git checkout lorem2^^ && |
|
test_must_fail git am lorem-move.patch && |
|
test -d .git/rebase-apply && |
|
echo resolved >>file && |
|
git add file && |
|
git am --resolved && |
|
! test -d .git/rebase-apply && |
|
test goodbye = "$(cat another)" |
|
' |
|
|
|
test_expect_success 'am takes patches from a Pine mailbox' ' |
|
git checkout first && |
|
cat pine patch1 | git am && |
|
! test -d .git/rebase-apply && |
|
test -z "$(git diff master^..HEAD)" |
|
' |
|
|
|
test_expect_success 'am fails on mail without patch' ' |
|
test_must_fail git am <failmail && |
|
rm -r .git/rebase-apply/ |
|
' |
|
|
|
test_expect_success 'am fails on empty patch' ' |
|
echo "---" >>failmail && |
|
test_must_fail git am <failmail && |
|
git am --skip && |
|
! test -d .git/rebase-apply |
|
' |
|
|
|
test_expect_success 'am works from stdin in subdirectory' ' |
|
rm -fr subdir && |
|
git checkout first && |
|
( |
|
mkdir -p subdir && |
|
cd subdir && |
|
git am <../patch1 |
|
) && |
|
test -z "$(git diff second)" |
|
' |
|
|
|
test_expect_success 'am works from file (relative path given) in subdirectory' ' |
|
rm -fr subdir && |
|
git checkout first && |
|
( |
|
mkdir -p subdir && |
|
cd subdir && |
|
git am ../patch1 |
|
) && |
|
test -z "$(git diff second)" |
|
' |
|
|
|
test_expect_success 'am works from file (absolute path given) in subdirectory' ' |
|
rm -fr subdir && |
|
git checkout first && |
|
P=$(pwd) && |
|
( |
|
mkdir -p subdir && |
|
cd subdir && |
|
git am "$P/patch1" |
|
) && |
|
test -z "$(git diff second)" |
|
' |
|
|
|
test_expect_success 'am --committer-date-is-author-date' ' |
|
git checkout first && |
|
test_tick && |
|
git am --committer-date-is-author-date patch1 && |
|
git cat-file commit HEAD | sed -e "/^$/q" >head1 && |
|
at=$(sed -ne "/^author /s/.*> //p" head1) && |
|
ct=$(sed -ne "/^committer /s/.*> //p" head1) && |
|
test "$at" = "$ct" |
|
' |
|
|
|
test_expect_success 'am without --committer-date-is-author-date' ' |
|
git checkout first && |
|
test_tick && |
|
git am patch1 && |
|
git cat-file commit HEAD | sed -e "/^$/q" >head1 && |
|
at=$(sed -ne "/^author /s/.*> //p" head1) && |
|
ct=$(sed -ne "/^committer /s/.*> //p" head1) && |
|
test "$at" != "$ct" |
|
' |
|
|
|
# This checks for +0000 because TZ is set to UTC and that should |
|
# show up when the current time is used. The date in message is set |
|
# by test_tick that uses -0700 timezone; if this feature does not |
|
# work, we will see that instead of +0000. |
|
test_expect_success 'am --ignore-date' ' |
|
git checkout first && |
|
test_tick && |
|
git am --ignore-date patch1 && |
|
git cat-file commit HEAD | sed -e "/^$/q" >head1 && |
|
at=$(sed -ne "/^author /s/.*> //p" head1) && |
|
echo "$at" | grep "+0000" |
|
' |
|
|
|
test_expect_success 'am into an unborn branch' ' |
|
rm -fr subdir && |
|
mkdir -p subdir && |
|
git format-patch --numbered-files -o subdir -1 first && |
|
( |
|
cd subdir && |
|
git init && |
|
git am 1 |
|
) && |
|
result=$( |
|
cd subdir && git rev-parse HEAD^{tree} |
|
) && |
|
test "z$result" = "z$(git rev-parse first^{tree})" |
|
' |
|
|
|
test_expect_success 'am newline in subject' ' |
|
git checkout first && |
|
test_tick && |
|
sed -e "s/second/second \\\n foo/" patch1 > patchnl && |
|
git am < patchnl > output.out 2>&1 && |
|
grep "^Applying: second \\\n foo$" output.out |
|
' |
|
|
|
test_expect_success 'am -q is quiet' ' |
|
git checkout first && |
|
test_tick && |
|
git am -q < patch1 > output.out 2>&1 && |
|
! test -s output.out |
|
' |
|
|
|
test_done
|
|
|