2008-06-01 06:11:42 +08:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
test_description='git am running'
|
|
|
|
|
|
|
|
. ./test-lib.sh
|
|
|
|
|
2010-07-24 01:03:07 +08:00
|
|
|
test_expect_success 'setup: messages' '
|
|
|
|
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.
|
|
|
|
|
|
|
|
EOF
|
2013-03-23 02:10:03 +08:00
|
|
|
qz_to_tab_space <<-\EOF >>msg &&
|
2010-07-24 01:03:07 +08:00
|
|
|
QDuis autem vel eum iriure dolor in hendrerit in vulputate velit
|
|
|
|
Qesse molestie consequat, vel illum dolore eu feugiat nulla facilisis
|
|
|
|
Qat vero eros et accumsan et iusto odio dignissim qui blandit
|
|
|
|
Qpraesent luptatum zzril delenit augue duis dolore te feugait nulla
|
|
|
|
Qfacilisi.
|
|
|
|
EOF
|
|
|
|
cat >>msg <<-\EOF &&
|
|
|
|
|
|
|
|
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
|
|
|
|
|
|
|
|
signoff="Signed-off-by: $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL>"
|
|
|
|
'
|
2008-06-01 06:11:42 +08:00
|
|
|
|
|
|
|
test_expect_success setup '
|
|
|
|
echo hello >file &&
|
|
|
|
git add file &&
|
|
|
|
test_tick &&
|
|
|
|
git commit -m first &&
|
|
|
|
git tag first &&
|
2010-07-24 01:03:07 +08:00
|
|
|
|
2008-06-01 06:11:42 +08:00
|
|
|
echo world >>file &&
|
|
|
|
git add file &&
|
|
|
|
test_tick &&
|
|
|
|
git commit -s -F msg &&
|
|
|
|
git tag second &&
|
2010-07-24 01:03:07 +08:00
|
|
|
|
2008-06-01 06:11:42 +08:00
|
|
|
git format-patch --stdout first >patch1 &&
|
2009-08-07 09:08:12 +08:00
|
|
|
{
|
2014-11-25 22:00:56 +08:00
|
|
|
echo "Message-Id: <1226501681-24923-1-git-send-email-bda@mnsspb.ru>" &&
|
2009-08-07 09:08:12 +08:00
|
|
|
echo "X-Fake-Field: Line One" &&
|
|
|
|
echo "X-Fake-Field: Line Two" &&
|
|
|
|
echo "X-Fake-Field: Line Three" &&
|
|
|
|
git format-patch --stdout first | sed -e "1d"
|
|
|
|
} > patch1.eml &&
|
2010-01-26 08:33:59 +08:00
|
|
|
{
|
|
|
|
echo "X-Fake-Field: Line One" &&
|
|
|
|
echo "X-Fake-Field: Line Two" &&
|
|
|
|
echo "X-Fake-Field: Line Three" &&
|
|
|
|
git format-patch --stdout first | sed -e "1d"
|
|
|
|
} | append_cr >patch1-crlf.eml &&
|
2011-08-08 10:49:04 +08:00
|
|
|
{
|
|
|
|
printf "%255s\\n" ""
|
|
|
|
echo "X-Fake-Field: Line One" &&
|
|
|
|
echo "X-Fake-Field: Line Two" &&
|
|
|
|
echo "X-Fake-Field: Line Three" &&
|
|
|
|
git format-patch --stdout first | sed -e "1d"
|
|
|
|
} > patch1-ws.eml &&
|
2010-07-24 01:03:07 +08:00
|
|
|
|
2008-06-01 06:11:42 +08:00
|
|
|
sed -n -e "3,\$p" msg >file &&
|
|
|
|
git add file &&
|
|
|
|
test_tick &&
|
|
|
|
git commit -m third &&
|
2010-07-24 01:03:07 +08:00
|
|
|
|
2008-06-01 06:11:42 +08:00
|
|
|
git format-patch --stdout first >patch2 &&
|
2010-07-24 01:03:07 +08:00
|
|
|
|
2008-06-01 06:11:42 +08:00
|
|
|
git checkout -b lorem &&
|
|
|
|
sed -n -e "11,\$p" msg >file &&
|
|
|
|
head -n 9 msg >>file &&
|
|
|
|
test_tick &&
|
|
|
|
git commit -a -m "moved stuff" &&
|
2010-07-24 01:03:07 +08:00
|
|
|
|
2008-06-01 06:11:42 +08:00
|
|
|
echo goodbye >another &&
|
|
|
|
git add another &&
|
|
|
|
test_tick &&
|
|
|
|
git commit -m "added another file" &&
|
|
|
|
|
2010-07-24 01:03:07 +08:00
|
|
|
git format-patch --stdout master >lorem-move.patch &&
|
2012-02-27 15:00:47 +08:00
|
|
|
git format-patch --no-prefix --stdout master >lorem-zero.patch &&
|
2008-11-11 07:49:03 +08:00
|
|
|
|
|
|
|
git checkout -b rename &&
|
|
|
|
git mv file renamed &&
|
|
|
|
git commit -m "renamed a file" &&
|
|
|
|
|
|
|
|
git format-patch -M --stdout lorem >rename.patch &&
|
|
|
|
|
|
|
|
git reset --soft lorem^ &&
|
|
|
|
git commit -m "renamed a file and added another" &&
|
|
|
|
|
|
|
|
git format-patch -M --stdout lorem^ >rename-add.patch &&
|
|
|
|
|
2010-07-24 01:03:07 +08:00
|
|
|
# reset time
|
2012-02-12 09:05:12 +08:00
|
|
|
sane_unset test_tick &&
|
2010-07-24 01:03:07 +08:00
|
|
|
test_tick
|
|
|
|
'
|
2008-06-01 06:11:42 +08:00
|
|
|
|
|
|
|
test_expect_success 'am applies patch correctly' '
|
2010-07-24 01:04:01 +08:00
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
2008-06-01 06:11:42 +08:00
|
|
|
git checkout first &&
|
|
|
|
test_tick &&
|
|
|
|
git am <patch1 &&
|
2013-06-15 20:43:12 +08:00
|
|
|
test_path_is_missing .git/rebase-apply &&
|
2010-07-24 01:03:07 +08:00
|
|
|
git diff --exit-code second &&
|
2008-06-01 06:11:42 +08:00
|
|
|
test "$(git rev-parse second)" = "$(git rev-parse HEAD)" &&
|
|
|
|
test "$(git rev-parse second^)" = "$(git rev-parse HEAD^)"
|
2009-08-07 09:08:12 +08:00
|
|
|
'
|
|
|
|
|
2015-07-19 23:49:08 +08:00
|
|
|
test_expect_success 'am fails if index is dirty' '
|
|
|
|
test_when_finished "rm -f dirtyfile" &&
|
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
|
|
|
git checkout first &&
|
|
|
|
echo dirtyfile >dirtyfile &&
|
|
|
|
git add dirtyfile &&
|
|
|
|
test_must_fail git am patch1 &&
|
|
|
|
test_path_is_dir .git/rebase-apply &&
|
|
|
|
test_cmp_rev first HEAD
|
|
|
|
'
|
|
|
|
|
2009-08-07 09:08:12 +08:00
|
|
|
test_expect_success 'am applies patch e-mail not in a mbox' '
|
2010-07-24 01:04:01 +08:00
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
2009-08-07 09:08:12 +08:00
|
|
|
git checkout first &&
|
|
|
|
git am patch1.eml &&
|
2013-06-15 20:43:12 +08:00
|
|
|
test_path_is_missing .git/rebase-apply &&
|
2010-07-24 01:03:07 +08:00
|
|
|
git diff --exit-code second &&
|
2009-08-07 09:08:12 +08:00
|
|
|
test "$(git rev-parse second)" = "$(git rev-parse HEAD)" &&
|
|
|
|
test "$(git rev-parse second^)" = "$(git rev-parse HEAD^)"
|
2010-01-26 08:33:59 +08:00
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'am applies patch e-mail not in a mbox with CRLF' '
|
2010-07-24 01:04:01 +08:00
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
2010-01-26 08:33:59 +08:00
|
|
|
git checkout first &&
|
|
|
|
git am patch1-crlf.eml &&
|
2013-06-15 20:43:12 +08:00
|
|
|
test_path_is_missing .git/rebase-apply &&
|
2010-07-24 01:03:07 +08:00
|
|
|
git diff --exit-code second &&
|
2010-01-26 08:33:59 +08:00
|
|
|
test "$(git rev-parse second)" = "$(git rev-parse HEAD)" &&
|
|
|
|
test "$(git rev-parse second^)" = "$(git rev-parse HEAD^)"
|
2008-06-01 06:11:42 +08:00
|
|
|
'
|
|
|
|
|
2011-08-08 10:49:04 +08:00
|
|
|
test_expect_success 'am applies patch e-mail with preceding whitespace' '
|
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
|
|
|
git checkout first &&
|
|
|
|
git am patch1-ws.eml &&
|
2013-06-15 20:43:12 +08:00
|
|
|
test_path_is_missing .git/rebase-apply &&
|
2011-08-08 10:49:04 +08:00
|
|
|
git diff --exit-code second &&
|
|
|
|
test "$(git rev-parse second)" = "$(git rev-parse HEAD)" &&
|
|
|
|
test "$(git rev-parse second^)" = "$(git rev-parse HEAD^)"
|
|
|
|
'
|
|
|
|
|
2015-07-19 23:49:13 +08:00
|
|
|
test_expect_success 'am with applypatch-msg hook' '
|
|
|
|
test_when_finished "rm -f .git/hooks/applypatch-msg" &&
|
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
|
|
|
git checkout first &&
|
|
|
|
mkdir -p .git/hooks &&
|
|
|
|
write_script .git/hooks/applypatch-msg <<-\EOF &&
|
|
|
|
cat "$1" >actual-msg &&
|
|
|
|
echo hook-message >"$1"
|
|
|
|
EOF
|
|
|
|
git am patch1 &&
|
|
|
|
test_path_is_missing .git/rebase-apply &&
|
|
|
|
git diff --exit-code second &&
|
|
|
|
echo hook-message >expected &&
|
|
|
|
git log -1 --format=format:%B >actual &&
|
|
|
|
test_cmp expected actual &&
|
|
|
|
git log -1 --format=format:%B second >expected &&
|
|
|
|
test_cmp expected actual-msg
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'am with failing applypatch-msg hook' '
|
|
|
|
test_when_finished "rm -f .git/hooks/applypatch-msg" &&
|
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
|
|
|
git checkout first &&
|
|
|
|
mkdir -p .git/hooks &&
|
|
|
|
write_script .git/hooks/applypatch-msg <<-\EOF &&
|
|
|
|
exit 1
|
|
|
|
EOF
|
|
|
|
test_must_fail git am patch1 &&
|
|
|
|
test_path_is_dir .git/rebase-apply &&
|
|
|
|
git diff --exit-code first &&
|
|
|
|
test_cmp_rev first HEAD
|
|
|
|
'
|
|
|
|
|
2015-07-19 23:49:14 +08:00
|
|
|
test_expect_success 'am with pre-applypatch hook' '
|
|
|
|
test_when_finished "rm -f .git/hooks/pre-applypatch" &&
|
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
|
|
|
git checkout first &&
|
|
|
|
mkdir -p .git/hooks &&
|
|
|
|
write_script .git/hooks/pre-applypatch <<-\EOF &&
|
|
|
|
git diff first >diff.actual
|
|
|
|
exit 0
|
|
|
|
EOF
|
|
|
|
git am patch1 &&
|
|
|
|
test_path_is_missing .git/rebase-apply &&
|
|
|
|
git diff --exit-code second &&
|
|
|
|
test_cmp_rev second HEAD &&
|
|
|
|
git diff first..second >diff.expected &&
|
|
|
|
test_cmp diff.expected diff.actual
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'am with failing pre-applypatch hook' '
|
|
|
|
test_when_finished "rm -f .git/hooks/pre-applypatch" &&
|
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
|
|
|
git checkout first &&
|
|
|
|
mkdir -p .git/hooks &&
|
|
|
|
write_script .git/hooks/pre-applypatch <<-\EOF &&
|
|
|
|
exit 1
|
|
|
|
EOF
|
|
|
|
test_must_fail git am patch1 &&
|
|
|
|
test_path_is_dir .git/rebase-apply &&
|
|
|
|
git diff --exit-code second &&
|
|
|
|
test_cmp_rev first HEAD
|
|
|
|
'
|
|
|
|
|
2015-07-19 23:49:15 +08:00
|
|
|
test_expect_success 'am with post-applypatch hook' '
|
|
|
|
test_when_finished "rm -f .git/hooks/post-applypatch" &&
|
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
|
|
|
git checkout first &&
|
|
|
|
mkdir -p .git/hooks &&
|
|
|
|
write_script .git/hooks/post-applypatch <<-\EOF &&
|
|
|
|
git rev-parse HEAD >head.actual
|
|
|
|
git diff second >diff.actual
|
|
|
|
exit 0
|
|
|
|
EOF
|
|
|
|
git am patch1 &&
|
|
|
|
test_path_is_missing .git/rebase-apply &&
|
|
|
|
test_cmp_rev second HEAD &&
|
|
|
|
git rev-parse second >head.expected &&
|
|
|
|
test_cmp head.expected head.actual &&
|
|
|
|
git diff second >diff.expected &&
|
|
|
|
test_cmp diff.expected diff.actual
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'am with failing post-applypatch hook' '
|
|
|
|
test_when_finished "rm -f .git/hooks/post-applypatch" &&
|
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
|
|
|
git checkout first &&
|
|
|
|
mkdir -p .git/hooks &&
|
|
|
|
write_script .git/hooks/post-applypatch <<-\EOF &&
|
|
|
|
git rev-parse HEAD >head.actual
|
|
|
|
exit 1
|
|
|
|
EOF
|
|
|
|
git am patch1 &&
|
|
|
|
test_path_is_missing .git/rebase-apply &&
|
|
|
|
git diff --exit-code second &&
|
|
|
|
test_cmp_rev second HEAD &&
|
|
|
|
git rev-parse second >head.expected &&
|
|
|
|
test_cmp head.expected head.actual
|
|
|
|
'
|
|
|
|
|
2010-07-24 01:03:07 +08:00
|
|
|
test_expect_success 'setup: new author and committer' '
|
|
|
|
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
|
|
|
|
'
|
2008-06-01 06:11:42 +08:00
|
|
|
|
|
|
|
compare () {
|
2010-07-24 01:03:07 +08:00
|
|
|
a=$(git cat-file commit "$2" | grep "^$1 ") &&
|
|
|
|
b=$(git cat-file commit "$3" | grep "^$1 ") &&
|
|
|
|
test "$a" = "$b"
|
2008-06-01 06:11:42 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
test_expect_success 'am changes committer and keeps author' '
|
|
|
|
test_tick &&
|
2010-07-24 01:04:01 +08:00
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
2008-06-01 06:11:42 +08:00
|
|
|
git checkout first &&
|
|
|
|
git am patch2 &&
|
2013-06-15 20:43:12 +08:00
|
|
|
test_path_is_missing .git/rebase-apply &&
|
2008-06-01 06:11:42 +08:00
|
|
|
test "$(git rev-parse master^^)" = "$(git rev-parse HEAD^^)" &&
|
2010-07-24 01:03:07 +08:00
|
|
|
git diff --exit-code master..HEAD &&
|
|
|
|
git diff --exit-code master^..HEAD^ &&
|
2008-06-01 06:11:42 +08:00
|
|
|
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' '
|
2010-07-24 01:04:01 +08:00
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
2008-06-01 06:11:42 +08:00
|
|
|
git checkout -b master2 first &&
|
|
|
|
git am --signoff <patch2 &&
|
2010-07-24 01:03:07 +08:00
|
|
|
printf "%s\n" "$signoff" >expected &&
|
2008-06-01 06:11:42 +08:00
|
|
|
echo "Signed-off-by: $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL>" >>expected &&
|
|
|
|
git cat-file commit HEAD^ | grep "Signed-off-by:" >actual &&
|
2010-07-24 01:03:07 +08:00
|
|
|
test_cmp expected actual &&
|
2008-06-01 06:11:42 +08:00
|
|
|
echo "Signed-off-by: $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL>" >expected &&
|
|
|
|
git cat-file commit HEAD | grep "Signed-off-by:" >actual &&
|
2010-07-24 01:03:07 +08:00
|
|
|
test_cmp expected actual
|
2008-06-01 06:11:42 +08:00
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'am stays in branch' '
|
2010-07-24 01:03:07 +08:00
|
|
|
echo refs/heads/master2 >expected &&
|
|
|
|
git symbolic-ref HEAD >actual &&
|
|
|
|
test_cmp expected actual
|
2008-06-01 06:11:42 +08:00
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'am --signoff does not add Signed-off-by: line if already there' '
|
|
|
|
git format-patch --stdout HEAD^ >patch3 &&
|
2012-01-16 18:53:00 +08:00
|
|
|
sed -e "/^Subject/ s,\[PATCH,Re: Re: Re: & 1/5 v2] [foo," patch3 >patch4 &&
|
2010-07-24 01:04:01 +08:00
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
2008-06-01 06:11:42 +08:00
|
|
|
git checkout HEAD^ &&
|
|
|
|
git am --signoff patch4 &&
|
2010-07-24 01:03:07 +08:00
|
|
|
git cat-file commit HEAD >actual &&
|
|
|
|
test $(grep -c "^Signed-off-by:" actual) -eq 1
|
2008-06-01 06:11:42 +08:00
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'am without --keep removes Re: and [PATCH] stuff' '
|
2010-07-24 01:03:07 +08:00
|
|
|
git rev-parse HEAD >expected &&
|
|
|
|
git rev-parse master2 >actual &&
|
|
|
|
test_cmp expected actual
|
2008-06-01 06:11:42 +08:00
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'am --keep really keeps the subject' '
|
2010-07-24 01:04:01 +08:00
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
2008-06-01 06:11:42 +08:00
|
|
|
git checkout HEAD^ &&
|
|
|
|
git am --keep patch4 &&
|
2013-06-15 20:43:12 +08:00
|
|
|
test_path_is_missing .git/rebase-apply &&
|
2010-07-24 01:03:07 +08:00
|
|
|
git cat-file commit HEAD >actual &&
|
2012-01-16 18:53:00 +08:00
|
|
|
grep "Re: Re: Re: \[PATCH 1/5 v2\] \[foo\] third" actual
|
|
|
|
'
|
|
|
|
|
2012-01-16 18:53:01 +08:00
|
|
|
test_expect_success 'am --keep-non-patch really keeps the non-patch part' '
|
2012-01-16 18:53:00 +08:00
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
|
|
|
git checkout HEAD^ &&
|
|
|
|
git am --keep-non-patch patch4 &&
|
2013-06-15 20:43:12 +08:00
|
|
|
test_path_is_missing .git/rebase-apply &&
|
2012-01-16 18:53:00 +08:00
|
|
|
git cat-file commit HEAD >actual &&
|
|
|
|
grep "^\[foo\] third" actual
|
2008-06-01 06:11:42 +08:00
|
|
|
'
|
|
|
|
|
2015-06-04 23:04:54 +08:00
|
|
|
test_expect_success 'setup am -3' '
|
2010-07-24 01:04:01 +08:00
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
2015-06-04 23:04:54 +08:00
|
|
|
git checkout -b base3way master2 &&
|
2008-06-01 06:11:42 +08:00
|
|
|
sed -n -e "3,\$p" msg >file &&
|
|
|
|
head -n 9 msg >>file &&
|
|
|
|
git add file &&
|
|
|
|
test_tick &&
|
2015-06-04 23:04:54 +08:00
|
|
|
git commit -m "copied stuff"
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'am -3 falls back to 3-way merge' '
|
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
|
|
|
git checkout -b lorem2 base3way &&
|
2008-06-01 06:11:42 +08:00
|
|
|
git am -3 lorem-move.patch &&
|
2013-06-15 20:43:12 +08:00
|
|
|
test_path_is_missing .git/rebase-apply &&
|
2010-07-24 01:03:07 +08:00
|
|
|
git diff --exit-code lorem
|
2008-06-01 06:11:42 +08:00
|
|
|
'
|
|
|
|
|
2012-02-27 15:00:47 +08:00
|
|
|
test_expect_success 'am -3 -p0 can read --no-prefix patch' '
|
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
2015-06-04 23:04:54 +08:00
|
|
|
git checkout -b lorem3 base3way &&
|
2012-02-27 15:00:47 +08:00
|
|
|
git am -3 -p0 lorem-zero.patch &&
|
2013-06-15 20:43:12 +08:00
|
|
|
test_path_is_missing .git/rebase-apply &&
|
2012-02-27 15:00:47 +08:00
|
|
|
git diff --exit-code lorem
|
|
|
|
'
|
|
|
|
|
2015-06-04 23:04:55 +08:00
|
|
|
test_expect_success 'am with config am.threeWay falls back to 3-way merge' '
|
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
|
|
|
git checkout -b lorem4 base3way &&
|
|
|
|
test_config am.threeWay 1 &&
|
|
|
|
git am lorem-move.patch &&
|
|
|
|
test_path_is_missing .git/rebase-apply &&
|
|
|
|
git diff --exit-code lorem
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'am with config am.threeWay overridden by --no-3way' '
|
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
|
|
|
git checkout -b lorem5 base3way &&
|
|
|
|
test_config am.threeWay 1 &&
|
|
|
|
test_must_fail git am --no-3way lorem-move.patch &&
|
|
|
|
test_path_is_dir .git/rebase-apply
|
|
|
|
'
|
|
|
|
|
2008-11-11 07:49:03 +08:00
|
|
|
test_expect_success 'am can rename a file' '
|
|
|
|
grep "^rename from" rename.patch &&
|
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
|
|
|
git checkout lorem^0 &&
|
|
|
|
git am rename.patch &&
|
2013-06-15 20:43:12 +08:00
|
|
|
test_path_is_missing .git/rebase-apply &&
|
2008-11-11 07:49:03 +08:00
|
|
|
git update-index --refresh &&
|
|
|
|
git diff --exit-code rename
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'am -3 can rename a file' '
|
|
|
|
grep "^rename from" rename.patch &&
|
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
|
|
|
git checkout lorem^0 &&
|
|
|
|
git am -3 rename.patch &&
|
2013-06-15 20:43:12 +08:00
|
|
|
test_path_is_missing .git/rebase-apply &&
|
2008-11-11 07:49:03 +08:00
|
|
|
git update-index --refresh &&
|
|
|
|
git diff --exit-code rename
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'am -3 can rename a file after falling back to 3-way merge' '
|
|
|
|
grep "^rename from" rename-add.patch &&
|
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
|
|
|
git checkout lorem^0 &&
|
|
|
|
git am -3 rename-add.patch &&
|
2013-06-15 20:43:12 +08:00
|
|
|
test_path_is_missing .git/rebase-apply &&
|
2008-11-11 07:49:03 +08:00
|
|
|
git update-index --refresh &&
|
|
|
|
git diff --exit-code rename
|
|
|
|
'
|
|
|
|
|
2009-06-17 06:33:01 +08:00
|
|
|
test_expect_success 'am -3 -q is quiet' '
|
2010-07-24 01:04:01 +08:00
|
|
|
rm -fr .git/rebase-apply &&
|
2008-11-11 07:49:03 +08:00
|
|
|
git checkout -f lorem2 &&
|
2015-06-04 23:04:54 +08:00
|
|
|
git reset base3way --hard &&
|
2010-07-24 01:03:07 +08:00
|
|
|
git am -3 -q lorem-move.patch >output.out 2>&1 &&
|
2009-06-17 06:33:01 +08:00
|
|
|
! test -s output.out
|
|
|
|
'
|
|
|
|
|
2008-06-01 06:11:42 +08:00
|
|
|
test_expect_success 'am pauses on conflict' '
|
2010-07-24 01:04:01 +08:00
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
2008-06-01 06:11:42 +08:00
|
|
|
git checkout lorem2^^ &&
|
2008-07-12 23:47:52 +08:00
|
|
|
test_must_fail git am lorem-move.patch &&
|
2008-07-21 18:51:02 +08:00
|
|
|
test -d .git/rebase-apply
|
2008-06-01 06:11:42 +08:00
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'am --skip works' '
|
2010-07-24 01:03:07 +08:00
|
|
|
echo goodbye >expected &&
|
2008-06-01 06:11:42 +08:00
|
|
|
git am --skip &&
|
2013-06-15 20:43:12 +08:00
|
|
|
test_path_is_missing .git/rebase-apply &&
|
2010-07-24 01:03:07 +08:00
|
|
|
git diff --exit-code lorem2^^ -- file &&
|
|
|
|
test_cmp expected another
|
2008-06-01 06:11:42 +08:00
|
|
|
'
|
|
|
|
|
2013-06-15 20:43:11 +08:00
|
|
|
test_expect_success 'am --abort removes a stray directory' '
|
|
|
|
mkdir .git/rebase-apply &&
|
|
|
|
git am --abort &&
|
|
|
|
test_path_is_missing .git/rebase-apply
|
|
|
|
'
|
|
|
|
|
2015-07-19 23:49:10 +08:00
|
|
|
test_expect_success 'am refuses patches when paused' '
|
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
|
|
|
git checkout lorem2^^ &&
|
|
|
|
|
|
|
|
test_must_fail git am lorem-move.patch &&
|
|
|
|
test_path_is_dir .git/rebase-apply &&
|
|
|
|
test_cmp_rev lorem2^^ HEAD &&
|
|
|
|
|
|
|
|
test_must_fail git am <lorem-move.patch &&
|
|
|
|
test_path_is_dir .git/rebase-apply &&
|
|
|
|
test_cmp_rev lorem2^^ HEAD
|
|
|
|
'
|
|
|
|
|
2008-06-01 06:11:42 +08:00
|
|
|
test_expect_success 'am --resolved works' '
|
2010-07-24 01:03:07 +08:00
|
|
|
echo goodbye >expected &&
|
2010-07-24 01:04:01 +08:00
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
2008-06-01 06:11:42 +08:00
|
|
|
git checkout lorem2^^ &&
|
2008-07-12 23:47:52 +08:00
|
|
|
test_must_fail git am lorem-move.patch &&
|
2008-07-21 18:51:02 +08:00
|
|
|
test -d .git/rebase-apply &&
|
2008-06-01 06:11:42 +08:00
|
|
|
echo resolved >>file &&
|
|
|
|
git add file &&
|
|
|
|
git am --resolved &&
|
2013-06-15 20:43:12 +08:00
|
|
|
test_path_is_missing .git/rebase-apply &&
|
2010-07-24 01:03:07 +08:00
|
|
|
test_cmp expected another
|
2008-06-01 06:11:42 +08:00
|
|
|
'
|
|
|
|
|
2015-07-19 23:49:11 +08:00
|
|
|
test_expect_success 'am --resolved fails if index has no changes' '
|
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
|
|
|
git checkout lorem2^^ &&
|
|
|
|
test_must_fail git am lorem-move.patch &&
|
|
|
|
test_path_is_dir .git/rebase-apply &&
|
|
|
|
test_cmp_rev lorem2^^ HEAD &&
|
|
|
|
test_must_fail git am --resolved &&
|
|
|
|
test_path_is_dir .git/rebase-apply &&
|
|
|
|
test_cmp_rev lorem2^^ HEAD
|
|
|
|
'
|
|
|
|
|
2015-07-19 23:49:12 +08:00
|
|
|
test_expect_success 'am --resolved fails if index has unmerged entries' '
|
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
|
|
|
git checkout second &&
|
|
|
|
test_must_fail git am -3 lorem-move.patch &&
|
|
|
|
test_path_is_dir .git/rebase-apply &&
|
|
|
|
test_cmp_rev second HEAD &&
|
|
|
|
test_must_fail git am --resolved >err &&
|
|
|
|
test_path_is_dir .git/rebase-apply &&
|
|
|
|
test_cmp_rev second HEAD &&
|
|
|
|
test_i18ngrep "still have unmerged paths" err
|
|
|
|
'
|
|
|
|
|
2008-06-01 06:11:42 +08:00
|
|
|
test_expect_success 'am takes patches from a Pine mailbox' '
|
2010-07-24 01:04:01 +08:00
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
2008-06-01 06:11:42 +08:00
|
|
|
git checkout first &&
|
|
|
|
cat pine patch1 | git am &&
|
2013-06-15 20:43:12 +08:00
|
|
|
test_path_is_missing .git/rebase-apply &&
|
2010-07-24 01:03:07 +08:00
|
|
|
git diff --exit-code master^..HEAD
|
2008-06-01 06:11:42 +08:00
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'am fails on mail without patch' '
|
2010-07-24 01:04:01 +08:00
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
2008-07-12 23:47:52 +08:00
|
|
|
test_must_fail git am <failmail &&
|
2010-07-24 01:04:01 +08:00
|
|
|
git am --abort &&
|
2013-06-15 20:43:12 +08:00
|
|
|
test_path_is_missing .git/rebase-apply
|
2008-06-01 06:11:42 +08:00
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'am fails on empty patch' '
|
2010-07-24 01:04:01 +08:00
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
2008-06-01 06:11:42 +08:00
|
|
|
echo "---" >>failmail &&
|
2008-07-12 23:47:52 +08:00
|
|
|
test_must_fail git am <failmail &&
|
2008-06-01 06:11:42 +08:00
|
|
|
git am --skip &&
|
2013-06-15 20:43:12 +08:00
|
|
|
test_path_is_missing .git/rebase-apply
|
2008-06-01 06:11:42 +08:00
|
|
|
'
|
|
|
|
|
2008-06-01 06:11:43 +08:00
|
|
|
test_expect_success 'am works from stdin in subdirectory' '
|
|
|
|
rm -fr subdir &&
|
2010-07-24 01:04:01 +08:00
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
2008-06-01 06:11:43 +08:00
|
|
|
git checkout first &&
|
|
|
|
(
|
|
|
|
mkdir -p subdir &&
|
|
|
|
cd subdir &&
|
|
|
|
git am <../patch1
|
|
|
|
) &&
|
2010-07-24 01:03:07 +08:00
|
|
|
git diff --exit-code second
|
2008-06-01 06:11:43 +08:00
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'am works from file (relative path given) in subdirectory' '
|
|
|
|
rm -fr subdir &&
|
2010-07-24 01:04:01 +08:00
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
2008-06-01 06:11:43 +08:00
|
|
|
git checkout first &&
|
|
|
|
(
|
|
|
|
mkdir -p subdir &&
|
|
|
|
cd subdir &&
|
|
|
|
git am ../patch1
|
|
|
|
) &&
|
2010-07-24 01:03:07 +08:00
|
|
|
git diff --exit-code second
|
2008-06-01 06:11:43 +08:00
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'am works from file (absolute path given) in subdirectory' '
|
|
|
|
rm -fr subdir &&
|
2010-07-24 01:04:01 +08:00
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
2008-06-01 06:11:43 +08:00
|
|
|
git checkout first &&
|
|
|
|
P=$(pwd) &&
|
|
|
|
(
|
|
|
|
mkdir -p subdir &&
|
|
|
|
cd subdir &&
|
|
|
|
git am "$P/patch1"
|
|
|
|
) &&
|
2010-07-24 01:03:07 +08:00
|
|
|
git diff --exit-code second
|
2008-06-01 06:11:43 +08:00
|
|
|
'
|
|
|
|
|
2009-01-23 08:14:58 +08:00
|
|
|
test_expect_success 'am --committer-date-is-author-date' '
|
2010-07-24 01:04:01 +08:00
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
2009-01-23 08:14:58 +08:00
|
|
|
git checkout first &&
|
|
|
|
test_tick &&
|
|
|
|
git am --committer-date-is-author-date patch1 &&
|
2010-01-27 07:08:31 +08:00
|
|
|
git cat-file commit HEAD | sed -e "/^\$/q" >head1 &&
|
2010-07-24 01:03:07 +08:00
|
|
|
sed -ne "/^author /s/.*> //p" head1 >at &&
|
|
|
|
sed -ne "/^committer /s/.*> //p" head1 >ct &&
|
|
|
|
test_cmp at ct
|
2009-01-23 08:14:58 +08:00
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'am without --committer-date-is-author-date' '
|
2010-07-24 01:04:01 +08:00
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
2009-01-23 08:14:58 +08:00
|
|
|
git checkout first &&
|
|
|
|
test_tick &&
|
|
|
|
git am patch1 &&
|
2010-01-27 07:08:31 +08:00
|
|
|
git cat-file commit HEAD | sed -e "/^\$/q" >head1 &&
|
2010-07-24 01:03:07 +08:00
|
|
|
sed -ne "/^author /s/.*> //p" head1 >at &&
|
|
|
|
sed -ne "/^committer /s/.*> //p" head1 >ct &&
|
|
|
|
! test_cmp at ct
|
2009-01-23 08:14:58 +08:00
|
|
|
'
|
|
|
|
|
2009-01-24 09:18:02 +08:00
|
|
|
# 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' '
|
2010-07-24 01:04:01 +08:00
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
2009-01-24 09:18:02 +08:00
|
|
|
git checkout first &&
|
|
|
|
test_tick &&
|
|
|
|
git am --ignore-date patch1 &&
|
2010-01-27 07:08:31 +08:00
|
|
|
git cat-file commit HEAD | sed -e "/^\$/q" >head1 &&
|
2010-07-24 01:03:07 +08:00
|
|
|
sed -ne "/^author /s/.*> //p" head1 >at &&
|
|
|
|
grep "+0000" at
|
2009-01-24 09:18:02 +08:00
|
|
|
'
|
|
|
|
|
2009-04-10 08:34:42 +08:00
|
|
|
test_expect_success 'am into an unborn branch' '
|
2010-07-24 01:03:07 +08:00
|
|
|
git rev-parse first^{tree} >expected &&
|
2010-07-24 01:04:01 +08:00
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
2009-04-10 08:34:42 +08:00
|
|
|
rm -fr subdir &&
|
2010-07-24 01:03:07 +08:00
|
|
|
mkdir subdir &&
|
2009-04-10 08:34:42 +08:00
|
|
|
git format-patch --numbered-files -o subdir -1 first &&
|
|
|
|
(
|
|
|
|
cd subdir &&
|
|
|
|
git init &&
|
|
|
|
git am 1
|
|
|
|
) &&
|
2010-07-24 01:03:07 +08:00
|
|
|
(
|
|
|
|
cd subdir &&
|
|
|
|
git rev-parse HEAD^{tree} >../actual
|
2009-04-10 08:34:42 +08:00
|
|
|
) &&
|
2010-07-24 01:03:07 +08:00
|
|
|
test_cmp expected actual
|
2009-04-10 08:34:42 +08:00
|
|
|
'
|
|
|
|
|
2009-06-17 06:32:57 +08:00
|
|
|
test_expect_success 'am newline in subject' '
|
2010-07-24 01:04:01 +08:00
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
2009-06-17 06:32:57 +08:00
|
|
|
git checkout first &&
|
|
|
|
test_tick &&
|
2010-07-24 01:03:07 +08:00
|
|
|
sed -e "s/second/second \\\n foo/" patch1 >patchnl &&
|
|
|
|
git am <patchnl >output.out 2>&1 &&
|
2011-05-22 02:43:52 +08:00
|
|
|
test_i18ngrep "^Applying: second \\\n foo$" output.out
|
2009-06-17 06:32:57 +08:00
|
|
|
'
|
|
|
|
|
2009-06-17 06:33:01 +08:00
|
|
|
test_expect_success 'am -q is quiet' '
|
2010-07-24 01:04:01 +08:00
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
2009-06-17 06:33:01 +08:00
|
|
|
git checkout first &&
|
|
|
|
test_tick &&
|
2010-07-24 01:03:07 +08:00
|
|
|
git am -q <patch1 >output.out 2>&1 &&
|
2009-06-17 06:33:01 +08:00
|
|
|
! test -s output.out
|
|
|
|
'
|
|
|
|
|
2012-02-26 01:34:26 +08:00
|
|
|
test_expect_success 'am empty-file does not infloop' '
|
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
|
|
|
touch empty-file &&
|
|
|
|
test_tick &&
|
2012-04-14 12:48:13 +08:00
|
|
|
test_must_fail git am empty-file 2>actual &&
|
2012-02-26 01:34:26 +08:00
|
|
|
echo Patch format detection failed. >expected &&
|
2012-04-14 12:46:18 +08:00
|
|
|
test_i18ncmp expected actual
|
2012-02-26 01:34:26 +08:00
|
|
|
'
|
|
|
|
|
2014-11-25 22:00:56 +08:00
|
|
|
test_expect_success 'am --message-id really adds the message id' '
|
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
|
|
|
git checkout HEAD^ &&
|
|
|
|
git am --message-id patch1.eml &&
|
|
|
|
test_path_is_missing .git/rebase-apply &&
|
|
|
|
git cat-file commit HEAD | tail -n1 >actual &&
|
|
|
|
grep Message-Id patch1.eml >expected &&
|
|
|
|
test_cmp expected actual
|
|
|
|
'
|
|
|
|
|
2015-07-07 22:08:23 +08:00
|
|
|
test_expect_success 'am.messageid really adds the message id' '
|
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
|
|
|
git checkout HEAD^ &&
|
|
|
|
test_config am.messageid true &&
|
|
|
|
git am patch1.eml &&
|
|
|
|
test_path_is_missing .git/rebase-apply &&
|
|
|
|
git cat-file commit HEAD | tail -n1 >actual &&
|
|
|
|
grep Message-Id patch1.eml >expected &&
|
|
|
|
test_cmp expected actual
|
|
|
|
'
|
|
|
|
|
2014-11-25 22:00:56 +08:00
|
|
|
test_expect_success 'am --message-id -s signs off after the message id' '
|
|
|
|
rm -fr .git/rebase-apply &&
|
|
|
|
git reset --hard &&
|
|
|
|
git checkout HEAD^ &&
|
|
|
|
git am -s --message-id patch1.eml &&
|
|
|
|
test_path_is_missing .git/rebase-apply &&
|
|
|
|
git cat-file commit HEAD | tail -n2 | head -n1 >actual &&
|
|
|
|
grep Message-Id patch1.eml >expected &&
|
|
|
|
test_cmp expected actual
|
|
|
|
'
|
|
|
|
|
2008-06-01 06:11:42 +08:00
|
|
|
test_done
|