mirror of
https://github.com/git/git.git
synced 2024-10-31 22:37:54 +01:00
Merge branch 'jc/t9001-modernise'
* jc/t9001-modernise: t9001: style modernisation phase #5 t9001: style modernisation phase #4 t9001: style modernisation phase #3 t9001: style modernisation phase #2 t9001: style modernisation phase #1
This commit is contained in:
commit
4395b21424
1 changed files with 282 additions and 289 deletions
|
@ -6,35 +6,37 @@ test_description='git send-email'
|
|||
# May be altered later in the test
|
||||
PREREQ="PERL"
|
||||
|
||||
test_expect_success $PREREQ \
|
||||
'prepare reference tree' \
|
||||
'echo "1A quick brown fox jumps over the" >file &&
|
||||
echo "lazy dog" >>file &&
|
||||
git add file &&
|
||||
GIT_AUTHOR_NAME="A" git commit -a -m "Initial."'
|
||||
test_expect_success $PREREQ 'prepare reference tree' '
|
||||
echo "1A quick brown fox jumps over the" >file &&
|
||||
echo "lazy dog" >>file &&
|
||||
git add file &&
|
||||
GIT_AUTHOR_NAME="A" git commit -a -m "Initial."
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ \
|
||||
'Setup helper tool' \
|
||||
'(echo "#!$SHELL_PATH"
|
||||
echo shift
|
||||
echo output=1
|
||||
echo "while test -f commandline\$output; do output=\$((\$output+1)); done"
|
||||
echo for a
|
||||
echo do
|
||||
echo " echo \"!\$a!\""
|
||||
echo "done >commandline\$output"
|
||||
echo "cat > msgtxt\$output"
|
||||
) >fake.sendmail &&
|
||||
chmod +x ./fake.sendmail &&
|
||||
git add fake.sendmail &&
|
||||
GIT_AUTHOR_NAME="A" git commit -a -m "Second."'
|
||||
test_expect_success $PREREQ 'Setup helper tool' '
|
||||
write_script fake.sendmail <<-\EOF &&
|
||||
shift
|
||||
output=1
|
||||
while test -f commandline$output
|
||||
do
|
||||
output=$(($output+1))
|
||||
done
|
||||
for a
|
||||
do
|
||||
echo "!$a!"
|
||||
done >commandline$output
|
||||
cat >"msgtxt$output"
|
||||
EOF
|
||||
git add fake.sendmail &&
|
||||
GIT_AUTHOR_NAME="A" git commit -a -m "Second."
|
||||
'
|
||||
|
||||
clean_fake_sendmail() {
|
||||
clean_fake_sendmail () {
|
||||
rm -f commandline* msgtxt*
|
||||
}
|
||||
|
||||
test_expect_success $PREREQ 'Extract patches' '
|
||||
patches=`git format-patch -s --cc="One <one@example.com>" --cc=two@example.com -n HEAD^1`
|
||||
patches=`git format-patch -s --cc="One <one@example.com>" --cc=two@example.com -n HEAD^1`
|
||||
'
|
||||
|
||||
# Test no confirm early to ensure remaining tests will not hang
|
||||
|
@ -47,9 +49,9 @@ test_no_confirm () {
|
|||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
$@ \
|
||||
$patches > stdout &&
|
||||
$patches >stdout &&
|
||||
test_must_fail grep "Send this email" stdout &&
|
||||
> no_confirm_okay
|
||||
>no_confirm_okay
|
||||
}
|
||||
|
||||
# Exit immediately to prevent hang if a no-confirm test fails
|
||||
|
@ -82,61 +84,61 @@ test_expect_success $PREREQ 'No confirm with sendemail.confirm=never' '
|
|||
'
|
||||
|
||||
test_expect_success $PREREQ 'Send patches' '
|
||||
git send-email --suppress-cc=sob --from="Example <nobody@example.com>" --to=nobody@example.com --smtp-server="$(pwd)/fake.sendmail" $patches 2>errors
|
||||
git send-email --suppress-cc=sob --from="Example <nobody@example.com>" --to=nobody@example.com --smtp-server="$(pwd)/fake.sendmail" $patches 2>errors
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ 'setup expect' '
|
||||
cat >expected <<\EOF
|
||||
!nobody@example.com!
|
||||
!author@example.com!
|
||||
!one@example.com!
|
||||
!two@example.com!
|
||||
EOF
|
||||
cat >expected <<-\EOF
|
||||
!nobody@example.com!
|
||||
!author@example.com!
|
||||
!one@example.com!
|
||||
!two@example.com!
|
||||
EOF
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ \
|
||||
'Verify commandline' \
|
||||
'test_cmp expected commandline1'
|
||||
test_expect_success $PREREQ 'Verify commandline' '
|
||||
test_cmp expected commandline1
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ 'Send patches with --envelope-sender' '
|
||||
clean_fake_sendmail &&
|
||||
git send-email --envelope-sender="Patch Contributor <patch@example.com>" --suppress-cc=sob --from="Example <nobody@example.com>" --to=nobody@example.com --smtp-server="$(pwd)/fake.sendmail" $patches 2>errors
|
||||
clean_fake_sendmail &&
|
||||
git send-email --envelope-sender="Patch Contributor <patch@example.com>" --suppress-cc=sob --from="Example <nobody@example.com>" --to=nobody@example.com --smtp-server="$(pwd)/fake.sendmail" $patches 2>errors
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ 'setup expect' '
|
||||
cat >expected <<\EOF
|
||||
!patch@example.com!
|
||||
!-i!
|
||||
!nobody@example.com!
|
||||
!author@example.com!
|
||||
!one@example.com!
|
||||
!two@example.com!
|
||||
EOF
|
||||
cat >expected <<-\EOF
|
||||
!patch@example.com!
|
||||
!-i!
|
||||
!nobody@example.com!
|
||||
!author@example.com!
|
||||
!one@example.com!
|
||||
!two@example.com!
|
||||
EOF
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ \
|
||||
'Verify commandline' \
|
||||
'test_cmp expected commandline1'
|
||||
test_expect_success $PREREQ 'Verify commandline' '
|
||||
test_cmp expected commandline1
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ 'Send patches with --envelope-sender=auto' '
|
||||
clean_fake_sendmail &&
|
||||
git send-email --envelope-sender=auto --suppress-cc=sob --from="Example <nobody@example.com>" --to=nobody@example.com --smtp-server="$(pwd)/fake.sendmail" $patches 2>errors
|
||||
clean_fake_sendmail &&
|
||||
git send-email --envelope-sender=auto --suppress-cc=sob --from="Example <nobody@example.com>" --to=nobody@example.com --smtp-server="$(pwd)/fake.sendmail" $patches 2>errors
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ 'setup expect' '
|
||||
cat >expected <<\EOF
|
||||
!nobody@example.com!
|
||||
!-i!
|
||||
!nobody@example.com!
|
||||
!author@example.com!
|
||||
!one@example.com!
|
||||
!two@example.com!
|
||||
EOF
|
||||
cat >expected <<-\EOF
|
||||
!nobody@example.com!
|
||||
!-i!
|
||||
!nobody@example.com!
|
||||
!author@example.com!
|
||||
!one@example.com!
|
||||
!two@example.com!
|
||||
EOF
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ \
|
||||
'Verify commandline' \
|
||||
'test_cmp expected commandline1'
|
||||
test_expect_success $PREREQ 'Verify commandline' '
|
||||
test_cmp expected commandline1
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ 'setup expect' "
|
||||
cat >expected-show-all-headers <<\EOF
|
||||
|
@ -307,11 +309,9 @@ test_expect_success $PREREQ 'tocmd works' '
|
|||
clean_fake_sendmail &&
|
||||
cp $patches tocmd.patch &&
|
||||
echo tocmd--tocmd@example.com >>tocmd.patch &&
|
||||
{
|
||||
echo "#!$SHELL_PATH"
|
||||
echo sed -n -e s/^tocmd--//p \"\$1\"
|
||||
} > tocmd-sed &&
|
||||
chmod +x tocmd-sed &&
|
||||
write_script tocmd-sed <<-\EOF &&
|
||||
sed -n -e "s/^tocmd--//p" "$1"
|
||||
EOF
|
||||
git send-email \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to-cmd=./tocmd-sed \
|
||||
|
@ -325,11 +325,9 @@ test_expect_success $PREREQ 'cccmd works' '
|
|||
clean_fake_sendmail &&
|
||||
cp $patches cccmd.patch &&
|
||||
echo "cccmd-- cccmd@example.com" >>cccmd.patch &&
|
||||
{
|
||||
echo "#!$SHELL_PATH"
|
||||
echo sed -n -e s/^cccmd--//p \"\$1\"
|
||||
} > cccmd-sed &&
|
||||
chmod +x cccmd-sed &&
|
||||
write_script cccmd-sed <<-\EOF &&
|
||||
sed -n -e "s/^cccmd--//p" "$1"
|
||||
EOF
|
||||
git send-email \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
|
@ -367,7 +365,7 @@ test_expect_success $PREREQ 'Author From: in message body' '
|
|||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
$patches &&
|
||||
sed "1,/^\$/d" < msgtxt1 > msgbody1 &&
|
||||
sed "1,/^\$/d" <msgtxt1 >msgbody1 &&
|
||||
grep "From: A <author@example.com>" msgbody1
|
||||
'
|
||||
|
||||
|
@ -378,7 +376,7 @@ test_expect_success $PREREQ 'Author From: not in message body' '
|
|||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
$patches &&
|
||||
sed "1,/^\$/d" < msgtxt1 > msgbody1 &&
|
||||
sed "1,/^\$/d" <msgtxt1 >msgbody1 &&
|
||||
! grep "From: A <author@example.com>" msgbody1
|
||||
'
|
||||
|
||||
|
@ -459,10 +457,9 @@ test_expect_success $PREREQ 'In-Reply-To with --chain-reply-to' '
|
|||
'
|
||||
|
||||
test_expect_success $PREREQ 'setup fake editor' '
|
||||
(echo "#!$SHELL_PATH" &&
|
||||
echo "echo fake edit >>\"\$1\""
|
||||
) >fake-editor &&
|
||||
chmod +x fake-editor
|
||||
write_script fake-editor <<-\EOF
|
||||
echo fake edit >>"$1"
|
||||
EOF
|
||||
'
|
||||
|
||||
test_set_editor "$(pwd)/fake-editor"
|
||||
|
@ -598,8 +595,9 @@ EOF
|
|||
"
|
||||
|
||||
test_expect_success $PREREQ 'sendemail.cccmd' '
|
||||
echo echo cc-cmd@example.com > cccmd &&
|
||||
chmod +x cccmd &&
|
||||
write_script cccmd <<-\EOF &&
|
||||
echo cc-cmd@example.com
|
||||
EOF
|
||||
git config sendemail.cccmd ./cccmd &&
|
||||
test_suppression cccmd
|
||||
'
|
||||
|
@ -792,7 +790,7 @@ test_confirm () {
|
|||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
$@ $patches > stdout &&
|
||||
$@ $patches >stdout &&
|
||||
grep "Send this email" stdout
|
||||
}
|
||||
|
||||
|
@ -840,7 +838,7 @@ test_expect_success $PREREQ 'confirm detects EOF (inform assumes y)' '
|
|||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
outdir/*.patch < /dev/null
|
||||
outdir/*.patch </dev/null
|
||||
ret="$?"
|
||||
git config sendemail.confirm ${CONFIRM:-never}
|
||||
test $ret = "0"
|
||||
|
@ -855,7 +853,7 @@ test_expect_success $PREREQ 'confirm detects EOF (auto causes failure)' '
|
|||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
$patches < /dev/null
|
||||
$patches </dev/null
|
||||
ret="$?"
|
||||
git config sendemail.confirm ${CONFIRM:-never}
|
||||
test $ret = "0"
|
||||
|
@ -891,39 +889,39 @@ test_expect_success $PREREQ 'utf8 Cc is rfc2047 encoded' '
|
|||
|
||||
test_expect_success $PREREQ '--compose adds MIME for utf8 body' '
|
||||
clean_fake_sendmail &&
|
||||
(echo "#!$SHELL_PATH" &&
|
||||
echo "echo utf8 body: àéìöú >>\"\$1\""
|
||||
) >fake-editor-utf8 &&
|
||||
chmod +x fake-editor-utf8 &&
|
||||
GIT_EDITOR="\"$(pwd)/fake-editor-utf8\"" \
|
||||
git send-email \
|
||||
--compose --subject foo \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
$patches &&
|
||||
write_script fake-editor-utf8 <<-\EOF &&
|
||||
echo "utf8 body: àéìöú" >>"$1"
|
||||
EOF
|
||||
GIT_EDITOR="\"$(pwd)/fake-editor-utf8\"" \
|
||||
git send-email \
|
||||
--compose --subject foo \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
$patches &&
|
||||
grep "^utf8 body" msgtxt1 &&
|
||||
grep "^Content-Type: text/plain; charset=UTF-8" msgtxt1
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ '--compose respects user mime type' '
|
||||
clean_fake_sendmail &&
|
||||
(echo "#!$SHELL_PATH" &&
|
||||
echo "(echo MIME-Version: 1.0"
|
||||
echo " echo Content-Type: text/plain\\; charset=iso-8859-1"
|
||||
echo " echo Content-Transfer-Encoding: 8bit"
|
||||
echo " echo Subject: foo"
|
||||
echo " echo "
|
||||
echo " echo utf8 body: àéìöú) >\"\$1\""
|
||||
) >fake-editor-utf8-mime &&
|
||||
chmod +x fake-editor-utf8-mime &&
|
||||
GIT_EDITOR="\"$(pwd)/fake-editor-utf8-mime\"" \
|
||||
git send-email \
|
||||
--compose --subject foo \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
$patches &&
|
||||
write_script fake-editor-utf8-mime <<-\EOF &&
|
||||
cat >"$1" <<-\EOM
|
||||
MIME-Version: 1.0
|
||||
Content-Type: text/plain; charset=iso-8859-1
|
||||
Content-Transfer-Encoding: 8bit
|
||||
Subject: foo
|
||||
|
||||
utf8 body: àéìöú
|
||||
EOM
|
||||
EOF
|
||||
GIT_EDITOR="\"$(pwd)/fake-editor-utf8-mime\"" \
|
||||
git send-email \
|
||||
--compose --subject foo \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
$patches &&
|
||||
grep "^utf8 body" msgtxt1 &&
|
||||
grep "^Content-Type: text/plain; charset=iso-8859-1" msgtxt1 &&
|
||||
! grep "^Content-Type: text/plain; charset=UTF-8" msgtxt1
|
||||
|
@ -931,13 +929,13 @@ test_expect_success $PREREQ '--compose respects user mime type' '
|
|||
|
||||
test_expect_success $PREREQ '--compose adds MIME for utf8 subject' '
|
||||
clean_fake_sendmail &&
|
||||
GIT_EDITOR="\"$(pwd)/fake-editor\"" \
|
||||
git send-email \
|
||||
--compose --subject utf8-sübjëct \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
$patches &&
|
||||
GIT_EDITOR="\"$(pwd)/fake-editor\"" \
|
||||
git send-email \
|
||||
--compose --subject utf8-sübjëct \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
$patches &&
|
||||
grep "^fake edit" msgtxt1 &&
|
||||
grep "^Subject: =?UTF-8?q?utf8-s=C3=BCbj=C3=ABct?=" msgtxt1
|
||||
'
|
||||
|
@ -949,9 +947,9 @@ test_expect_success $PREREQ 'utf8 author is correctly passed on' '
|
|||
git commit --amend --author "Füñný Nâmé <odd_?=mail@example.com>" &&
|
||||
git format-patch --stdout -1 >funny_name.patch &&
|
||||
git send-email --from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
funny_name.patch &&
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
funny_name.patch &&
|
||||
grep "^From: Füñný Nâmé <odd_?=mail@example.com>" msgtxt1
|
||||
'
|
||||
|
||||
|
@ -962,9 +960,9 @@ test_expect_success $PREREQ 'utf8 sender is not duplicated' '
|
|||
git commit --amend --author "Füñný Nâmé <odd_?=mail@example.com>" &&
|
||||
git format-patch --stdout -1 >funny_name.patch &&
|
||||
git send-email --from="Füñný Nâmé <odd_?=mail@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
funny_name.patch &&
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
funny_name.patch &&
|
||||
grep "^From: " msgtxt1 >msgfrom &&
|
||||
test_line_count = 1 msgfrom
|
||||
'
|
||||
|
@ -972,35 +970,33 @@ test_expect_success $PREREQ 'utf8 sender is not duplicated' '
|
|||
test_expect_success $PREREQ 'sendemail.composeencoding works' '
|
||||
clean_fake_sendmail &&
|
||||
git config sendemail.composeencoding iso-8859-1 &&
|
||||
(echo "#!$SHELL_PATH" &&
|
||||
echo "echo utf8 body: àéìöú >>\"\$1\""
|
||||
) >fake-editor-utf8 &&
|
||||
chmod +x fake-editor-utf8 &&
|
||||
GIT_EDITOR="\"$(pwd)/fake-editor-utf8\"" \
|
||||
git send-email \
|
||||
--compose --subject foo \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
$patches &&
|
||||
write_script fake-editor-utf8 <<-\EOF &&
|
||||
echo "utf8 body: àéìöú" >>"$1"
|
||||
EOF
|
||||
GIT_EDITOR="\"$(pwd)/fake-editor-utf8\"" \
|
||||
git send-email \
|
||||
--compose --subject foo \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
$patches &&
|
||||
grep "^utf8 body" msgtxt1 &&
|
||||
grep "^Content-Type: text/plain; charset=iso-8859-1" msgtxt1
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ '--compose-encoding works' '
|
||||
clean_fake_sendmail &&
|
||||
(echo "#!$SHELL_PATH" &&
|
||||
echo "echo utf8 body: àéìöú >>\"\$1\""
|
||||
) >fake-editor-utf8 &&
|
||||
chmod +x fake-editor-utf8 &&
|
||||
GIT_EDITOR="\"$(pwd)/fake-editor-utf8\"" \
|
||||
git send-email \
|
||||
--compose-encoding iso-8859-1 \
|
||||
--compose --subject foo \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
$patches &&
|
||||
write_script fake-editor-utf8 <<-\EOF &&
|
||||
echo "utf8 body: àéìöú" >>"$1"
|
||||
EOF
|
||||
GIT_EDITOR="\"$(pwd)/fake-editor-utf8\"" \
|
||||
git send-email \
|
||||
--compose-encoding iso-8859-1 \
|
||||
--compose --subject foo \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
$patches &&
|
||||
grep "^utf8 body" msgtxt1 &&
|
||||
grep "^Content-Type: text/plain; charset=iso-8859-1" msgtxt1
|
||||
'
|
||||
|
@ -1008,38 +1004,37 @@ test_expect_success $PREREQ '--compose-encoding works' '
|
|||
test_expect_success $PREREQ '--compose-encoding overrides sendemail.composeencoding' '
|
||||
clean_fake_sendmail &&
|
||||
git config sendemail.composeencoding iso-8859-1 &&
|
||||
(echo "#!$SHELL_PATH" &&
|
||||
echo "echo utf8 body: àéìöú >>\"\$1\""
|
||||
) >fake-editor-utf8 &&
|
||||
chmod +x fake-editor-utf8 &&
|
||||
GIT_EDITOR="\"$(pwd)/fake-editor-utf8\"" \
|
||||
git send-email \
|
||||
--compose-encoding iso-8859-2 \
|
||||
--compose --subject foo \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
$patches &&
|
||||
write_script fake-editor-utf8 <<-\EOF &&
|
||||
echo "utf8 body: àéìöú" >>"$1"
|
||||
EOF
|
||||
GIT_EDITOR="\"$(pwd)/fake-editor-utf8\"" \
|
||||
git send-email \
|
||||
--compose-encoding iso-8859-2 \
|
||||
--compose --subject foo \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
$patches &&
|
||||
grep "^utf8 body" msgtxt1 &&
|
||||
grep "^Content-Type: text/plain; charset=iso-8859-2" msgtxt1
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ '--compose-encoding adds correct MIME for subject' '
|
||||
clean_fake_sendmail &&
|
||||
GIT_EDITOR="\"$(pwd)/fake-editor\"" \
|
||||
git send-email \
|
||||
--compose-encoding iso-8859-2 \
|
||||
--compose --subject utf8-sübjëct \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
$patches &&
|
||||
GIT_EDITOR="\"$(pwd)/fake-editor\"" \
|
||||
git send-email \
|
||||
--compose-encoding iso-8859-2 \
|
||||
--compose --subject utf8-sübjëct \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
$patches &&
|
||||
grep "^fake edit" msgtxt1 &&
|
||||
grep "^Subject: =?iso-8859-2?q?utf8-s=C3=BCbj=C3=ABct?=" msgtxt1
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ 'detects ambiguous reference/file conflict' '
|
||||
echo master > master &&
|
||||
echo master >master &&
|
||||
git add master &&
|
||||
git commit -m"add master" &&
|
||||
test_must_fail git send-email --dry-run master 2>errors &&
|
||||
|
@ -1050,10 +1045,10 @@ test_expect_success $PREREQ 'feed two files' '
|
|||
rm -fr outdir &&
|
||||
git format-patch -2 -o outdir &&
|
||||
git send-email \
|
||||
--dry-run \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
outdir/000?-*.patch 2>errors >out &&
|
||||
--dry-run \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
outdir/000?-*.patch 2>errors >out &&
|
||||
grep "^Subject: " out >subjects &&
|
||||
test "z$(sed -n -e 1p subjects)" = "zSubject: [PATCH 1/2] Second." &&
|
||||
test "z$(sed -n -e 2p subjects)" = "zSubject: [PATCH 2/2] add master"
|
||||
|
@ -1197,7 +1192,7 @@ test_expect_success $PREREQ 'To headers from files reset each patch' '
|
|||
'
|
||||
|
||||
test_expect_success $PREREQ 'setup expect' '
|
||||
cat >email-using-8bit <<EOF
|
||||
cat >email-using-8bit <<\EOF
|
||||
From fe6ecc66ece37198fe5db91fa2fc41d9f4fe5cc4 Mon Sep 17 00:00:00 2001
|
||||
Message-Id: <bogus-message-id@example.com>
|
||||
From: author@example.com
|
||||
|
@ -1209,9 +1204,7 @@ EOF
|
|||
'
|
||||
|
||||
test_expect_success $PREREQ 'setup expect' '
|
||||
cat >expected <<EOF
|
||||
Subject: subject goes here
|
||||
EOF
|
||||
echo "Subject: subject goes here" >expected
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ 'ASCII subject is not RFC2047 quoted' '
|
||||
|
@ -1226,11 +1219,11 @@ test_expect_success $PREREQ 'ASCII subject is not RFC2047 quoted' '
|
|||
'
|
||||
|
||||
test_expect_success $PREREQ 'setup expect' '
|
||||
cat >content-type-decl <<EOF
|
||||
MIME-Version: 1.0
|
||||
Content-Type: text/plain; charset=UTF-8
|
||||
Content-Transfer-Encoding: 8bit
|
||||
EOF
|
||||
cat >content-type-decl <<-\EOF
|
||||
MIME-Version: 1.0
|
||||
Content-Type: text/plain; charset=UTF-8
|
||||
Content-Transfer-Encoding: 8bit
|
||||
EOF
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ 'asks about and fixes 8bit encodings' '
|
||||
|
@ -1270,21 +1263,21 @@ test_expect_success $PREREQ '--8bit-encoding overrides sendemail.8bitEncoding' '
|
|||
'
|
||||
|
||||
test_expect_success $PREREQ 'setup expect' '
|
||||
cat >email-using-8bit <<EOF
|
||||
From fe6ecc66ece37198fe5db91fa2fc41d9f4fe5cc4 Mon Sep 17 00:00:00 2001
|
||||
Message-Id: <bogus-message-id@example.com>
|
||||
From: author@example.com
|
||||
Date: Sat, 12 Jun 2010 15:53:58 +0200
|
||||
Subject: Dieser Betreff enthält auch einen Umlaut!
|
||||
cat >email-using-8bit <<-\EOF
|
||||
From fe6ecc66ece37198fe5db91fa2fc41d9f4fe5cc4 Mon Sep 17 00:00:00 2001
|
||||
Message-Id: <bogus-message-id@example.com>
|
||||
From: author@example.com
|
||||
Date: Sat, 12 Jun 2010 15:53:58 +0200
|
||||
Subject: Dieser Betreff enthält auch einen Umlaut!
|
||||
|
||||
Nothing to see here.
|
||||
EOF
|
||||
Nothing to see here.
|
||||
EOF
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ 'setup expect' '
|
||||
cat >expected <<EOF
|
||||
Subject: =?UTF-8?q?Dieser=20Betreff=20enth=C3=A4lt=20auch=20einen=20Umlaut!?=
|
||||
EOF
|
||||
cat >expected <<-\EOF
|
||||
Subject: =?UTF-8?q?Dieser=20Betreff=20enth=C3=A4lt=20auch=20einen=20Umlaut!?=
|
||||
EOF
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ '--8bit-encoding also treats subject' '
|
||||
|
@ -1299,26 +1292,26 @@ test_expect_success $PREREQ '--8bit-encoding also treats subject' '
|
|||
'
|
||||
|
||||
test_expect_success $PREREQ 'setup expect' '
|
||||
cat >email-using-8bit <<EOF
|
||||
From fe6ecc66ece37198fe5db91fa2fc41d9f4fe5cc4 Mon Sep 17 00:00:00 2001
|
||||
Message-Id: <bogus-message-id@example.com>
|
||||
From: A U Thor <author@example.com>
|
||||
Date: Sat, 12 Jun 2010 15:53:58 +0200
|
||||
Content-Type: text/plain; charset=UTF-8
|
||||
Subject: Nothing to see here.
|
||||
cat >email-using-8bit <<-\EOF
|
||||
From fe6ecc66ece37198fe5db91fa2fc41d9f4fe5cc4 Mon Sep 17 00:00:00 2001
|
||||
Message-Id: <bogus-message-id@example.com>
|
||||
From: A U Thor <author@example.com>
|
||||
Date: Sat, 12 Jun 2010 15:53:58 +0200
|
||||
Content-Type: text/plain; charset=UTF-8
|
||||
Subject: Nothing to see here.
|
||||
|
||||
Dieser Betreff enthält auch einen Umlaut!
|
||||
EOF
|
||||
Dieser Betreff enthält auch einen Umlaut!
|
||||
EOF
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ 'sendemail.transferencoding=7bit fails on 8bit data' '
|
||||
clean_fake_sendmail &&
|
||||
git config sendemail.transferEncoding 7bit &&
|
||||
test_must_fail git send-email \
|
||||
--transfer-encoding=7bit \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
email-using-8bit \
|
||||
2>errors >out &&
|
||||
--transfer-encoding=7bit \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
email-using-8bit \
|
||||
2>errors >out &&
|
||||
grep "cannot send message as 7bit" errors &&
|
||||
test -z "$(ls msgtxt*)"
|
||||
'
|
||||
|
@ -1327,10 +1320,10 @@ test_expect_success $PREREQ '--transfer-encoding overrides sendemail.transferEnc
|
|||
clean_fake_sendmail &&
|
||||
git config sendemail.transferEncoding 8bit
|
||||
test_must_fail git send-email \
|
||||
--transfer-encoding=7bit \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
email-using-8bit \
|
||||
2>errors >out &&
|
||||
--transfer-encoding=7bit \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
email-using-8bit \
|
||||
2>errors >out &&
|
||||
grep "cannot send message as 7bit" errors &&
|
||||
test -z "$(ls msgtxt*)"
|
||||
'
|
||||
|
@ -1338,77 +1331,77 @@ test_expect_success $PREREQ '--transfer-encoding overrides sendemail.transferEnc
|
|||
test_expect_success $PREREQ 'sendemail.transferencoding=8bit' '
|
||||
clean_fake_sendmail &&
|
||||
git send-email \
|
||||
--transfer-encoding=8bit \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
email-using-8bit \
|
||||
2>errors >out &&
|
||||
--transfer-encoding=8bit \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
email-using-8bit \
|
||||
2>errors >out &&
|
||||
sed '1,/^$/d' msgtxt1 >actual &&
|
||||
sed '1,/^$/d' email-using-8bit >expected &&
|
||||
test_cmp expected actual
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ 'setup expect' '
|
||||
cat >expected <<EOF
|
||||
Dieser Betreff enth=C3=A4lt auch einen Umlaut!
|
||||
EOF
|
||||
cat >expected <<-\EOF
|
||||
Dieser Betreff enth=C3=A4lt auch einen Umlaut!
|
||||
EOF
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ '8-bit and sendemail.transferencoding=quoted-printable' '
|
||||
clean_fake_sendmail &&
|
||||
git send-email \
|
||||
--transfer-encoding=quoted-printable \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
email-using-8bit \
|
||||
2>errors >out &&
|
||||
--transfer-encoding=quoted-printable \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
email-using-8bit \
|
||||
2>errors >out &&
|
||||
sed '1,/^$/d' msgtxt1 >actual &&
|
||||
test_cmp expected actual
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ 'setup expect' '
|
||||
cat >expected <<EOF
|
||||
RGllc2VyIEJldHJlZmYgZW50aMOkbHQgYXVjaCBlaW5lbiBVbWxhdXQhCg==
|
||||
EOF
|
||||
cat >expected <<-\EOF
|
||||
RGllc2VyIEJldHJlZmYgZW50aMOkbHQgYXVjaCBlaW5lbiBVbWxhdXQhCg==
|
||||
EOF
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ '8-bit and sendemail.transferencoding=base64' '
|
||||
clean_fake_sendmail &&
|
||||
git send-email \
|
||||
--transfer-encoding=base64 \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
email-using-8bit \
|
||||
2>errors >out &&
|
||||
--transfer-encoding=base64 \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
email-using-8bit \
|
||||
2>errors >out &&
|
||||
sed '1,/^$/d' msgtxt1 >actual &&
|
||||
test_cmp expected actual
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ 'setup expect' '
|
||||
cat >email-using-qp <<EOF
|
||||
From fe6ecc66ece37198fe5db91fa2fc41d9f4fe5cc4 Mon Sep 17 00:00:00 2001
|
||||
Message-Id: <bogus-message-id@example.com>
|
||||
From: A U Thor <author@example.com>
|
||||
Date: Sat, 12 Jun 2010 15:53:58 +0200
|
||||
MIME-Version: 1.0
|
||||
Content-Transfer-Encoding: quoted-printable
|
||||
Content-Type: text/plain; charset=UTF-8
|
||||
Subject: Nothing to see here.
|
||||
cat >email-using-qp <<-\EOF
|
||||
From fe6ecc66ece37198fe5db91fa2fc41d9f4fe5cc4 Mon Sep 17 00:00:00 2001
|
||||
Message-Id: <bogus-message-id@example.com>
|
||||
From: A U Thor <author@example.com>
|
||||
Date: Sat, 12 Jun 2010 15:53:58 +0200
|
||||
MIME-Version: 1.0
|
||||
Content-Transfer-Encoding: quoted-printable
|
||||
Content-Type: text/plain; charset=UTF-8
|
||||
Subject: Nothing to see here.
|
||||
|
||||
Dieser Betreff enth=C3=A4lt auch einen Umlaut!
|
||||
EOF
|
||||
Dieser Betreff enth=C3=A4lt auch einen Umlaut!
|
||||
EOF
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ 'convert from quoted-printable to base64' '
|
||||
clean_fake_sendmail &&
|
||||
git send-email \
|
||||
--transfer-encoding=base64 \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
email-using-qp \
|
||||
2>errors >out &&
|
||||
--transfer-encoding=base64 \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
email-using-qp \
|
||||
2>errors >out &&
|
||||
sed '1,/^$/d' msgtxt1 >actual &&
|
||||
test_cmp expected actual
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ 'setup expect' "
|
||||
tr -d '\\015' | tr '%' '\\015' > email-using-crlf <<EOF
|
||||
tr -d '\\015' | tr '%' '\\015' >email-using-crlf <<EOF
|
||||
From fe6ecc66ece37198fe5db91fa2fc41d9f4fe5cc4 Mon Sep 17 00:00:00 2001
|
||||
Message-Id: <bogus-message-id@example.com>
|
||||
From: A U Thor <author@example.com>
|
||||
|
@ -1421,35 +1414,35 @@ EOF
|
|||
"
|
||||
|
||||
test_expect_success $PREREQ 'setup expect' '
|
||||
cat >expected <<EOF
|
||||
Look, I have a CRLF and an =3D sign!=0D
|
||||
EOF
|
||||
cat >expected <<-\EOF
|
||||
Look, I have a CRLF and an =3D sign!=0D
|
||||
EOF
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ 'CRLF and sendemail.transferencoding=quoted-printable' '
|
||||
clean_fake_sendmail &&
|
||||
git send-email \
|
||||
--transfer-encoding=quoted-printable \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
email-using-crlf \
|
||||
2>errors >out &&
|
||||
--transfer-encoding=quoted-printable \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
email-using-crlf \
|
||||
2>errors >out &&
|
||||
sed '1,/^$/d' msgtxt1 >actual &&
|
||||
test_cmp expected actual
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ 'setup expect' '
|
||||
cat >expected <<EOF
|
||||
TG9vaywgSSBoYXZlIGEgQ1JMRiBhbmQgYW4gPSBzaWduIQ0K
|
||||
EOF
|
||||
cat >expected <<-\EOF
|
||||
TG9vaywgSSBoYXZlIGEgQ1JMRiBhbmQgYW4gPSBzaWduIQ0K
|
||||
EOF
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ 'CRLF and sendemail.transferencoding=base64' '
|
||||
clean_fake_sendmail &&
|
||||
git send-email \
|
||||
--transfer-encoding=base64 \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
email-using-crlf \
|
||||
2>errors >out &&
|
||||
--transfer-encoding=base64 \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
email-using-crlf \
|
||||
2>errors >out &&
|
||||
sed '1,/^$/d' msgtxt1 >actual &&
|
||||
test_cmp expected actual
|
||||
'
|
||||
|
@ -1463,13 +1456,13 @@ test_expect_success $PREREQ 'refusing to send cover letter template' '
|
|||
rm -fr outdir &&
|
||||
git format-patch --cover-letter -2 -o outdir &&
|
||||
test_must_fail git send-email \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
outdir/0002-*.patch \
|
||||
outdir/0000-*.patch \
|
||||
outdir/0001-*.patch \
|
||||
2>errors >out &&
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
outdir/0002-*.patch \
|
||||
outdir/0000-*.patch \
|
||||
outdir/0001-*.patch \
|
||||
2>errors >out &&
|
||||
grep "SUBJECT HERE" errors &&
|
||||
test -z "$(ls msgtxt*)"
|
||||
'
|
||||
|
@ -1479,14 +1472,14 @@ test_expect_success $PREREQ '--force sends cover letter template anyway' '
|
|||
rm -fr outdir &&
|
||||
git format-patch --cover-letter -2 -o outdir &&
|
||||
git send-email \
|
||||
--force \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
outdir/0002-*.patch \
|
||||
outdir/0000-*.patch \
|
||||
outdir/0001-*.patch \
|
||||
2>errors >out &&
|
||||
--force \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
outdir/0002-*.patch \
|
||||
outdir/0000-*.patch \
|
||||
outdir/0001-*.patch \
|
||||
2>errors >out &&
|
||||
! grep "SUBJECT HERE" errors &&
|
||||
test -n "$(ls msgtxt*)"
|
||||
'
|
||||
|
@ -1501,15 +1494,15 @@ test_cover_addresses () {
|
|||
mv $cover cover-to-edit.patch &&
|
||||
perl -pe "s/^From:/$header: extra\@address.com\nFrom:/" cover-to-edit.patch >"$cover" &&
|
||||
git send-email \
|
||||
--force \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--no-to --no-cc \
|
||||
"$@" \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
outdir/0000-*.patch \
|
||||
outdir/0001-*.patch \
|
||||
outdir/0002-*.patch \
|
||||
2>errors >out &&
|
||||
--force \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--no-to --no-cc \
|
||||
"$@" \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
outdir/0000-*.patch \
|
||||
outdir/0001-*.patch \
|
||||
outdir/0002-*.patch \
|
||||
2>errors >out &&
|
||||
grep "^$header: extra@address.com" msgtxt1 >to1 &&
|
||||
grep "^$header: extra@address.com" msgtxt2 >to2 &&
|
||||
grep "^$header: extra@address.com" msgtxt3 >to3 &&
|
||||
|
@ -1542,11 +1535,11 @@ test_expect_success $PREREQ 'sendemail.aliasfiletype=mailrc' '
|
|||
git config --replace-all sendemail.aliasesfile "$(pwd)/.mailrc" &&
|
||||
git config sendemail.aliasfiletype mailrc &&
|
||||
git send-email \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=sbd \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
outdir/0001-*.patch \
|
||||
2>errors >out &&
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=sbd \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
outdir/0001-*.patch \
|
||||
2>errors >out &&
|
||||
grep "^!somebody@example\.org!$" commandline1
|
||||
'
|
||||
|
||||
|
@ -1556,11 +1549,11 @@ test_expect_success $PREREQ 'sendemail.aliasfile=~/.mailrc' '
|
|||
git config --replace-all sendemail.aliasesfile "~/.mailrc" &&
|
||||
git config sendemail.aliasfiletype mailrc &&
|
||||
git send-email \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=sbd \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
outdir/0001-*.patch \
|
||||
2>errors >out &&
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=sbd \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
outdir/0001-*.patch \
|
||||
2>errors >out &&
|
||||
grep "^!someone@example\.org!$" commandline1
|
||||
'
|
||||
|
||||
|
|
Loading…
Reference in a new issue