1#!/bin/sh
2
3test_description='git send-email'
4. ./test-lib.sh
5
6# May be altered later in the test
7PREREQ="PERL"
8
9test_expect_success $PREREQ \
10 'prepare reference tree' \
11 'echo "1A quick brown fox jumps over the" >file &&
12 echo "lazy dog" >>file &&
13 git add file &&
14 GIT_AUTHOR_NAME="A" git commit -a -m "Initial."'
15
16test_expect_success $PREREQ \
17 'Setup helper tool' \
18 '(echo "#!$SHELL_PATH"
19 echo shift
20 echo output=1
21 echo "while test -f commandline\$output; do output=\$((\$output+1)); done"
22 echo for a
23 echo do
24 echo " echo \"!\$a!\""
25 echo "done >commandline\$output"
26 test_have_prereq MINGW && echo "dos2unix commandline\$output"
27 echo "cat > msgtxt\$output"
28 ) >fake.sendmail &&
29 chmod +x ./fake.sendmail &&
30 git add fake.sendmail &&
31 GIT_AUTHOR_NAME="A" git commit -a -m "Second."'
32
33clean_fake_sendmail() {
34 rm -f commandline* msgtxt*
35}
36
37test_expect_success $PREREQ 'Extract patches' '
38 patches=`git format-patch -s --cc="One <one@example.com>" --cc=two@example.com -n HEAD^1`
39'
40
41# Test no confirm early to ensure remaining tests will not hang
42test_no_confirm () {
43 rm -f no_confirm_okay
44 echo n | \
45 GIT_SEND_EMAIL_NOTTY=1 \
46 git send-email \
47 --from="Example <from@example.com>" \
48 --to=nobody@example.com \
49 --smtp-server="$(pwd)/fake.sendmail" \
50 $@ \
51 $patches > stdout &&
52 test_must_fail grep "Send this email" stdout &&
53 > no_confirm_okay
54}
55
56# Exit immediately to prevent hang if a no-confirm test fails
57check_no_confirm () {
58 if ! test -f no_confirm_okay
59 then
60 say 'confirm test failed; skipping remaining tests to prevent hanging'
61 PREREQ="$PREREQ,CHECK_NO_CONFIRM"
62 fi
63 return 0
64}
65
66test_expect_success $PREREQ 'No confirm with --suppress-cc' '
67 test_no_confirm --suppress-cc=sob &&
68 check_no_confirm
69'
70
71
72test_expect_success $PREREQ 'No confirm with --confirm=never' '
73 test_no_confirm --confirm=never &&
74 check_no_confirm
75'
76
77# leave sendemail.confirm set to never after this so that none of the
78# remaining tests prompt unintentionally.
79test_expect_success $PREREQ 'No confirm with sendemail.confirm=never' '
80 git config sendemail.confirm never &&
81 test_no_confirm --compose --subject=foo &&
82 check_no_confirm
83'
84
85test_expect_success $PREREQ 'Send patches' '
86 git send-email --suppress-cc=sob --from="Example <nobody@example.com>" --to=nobody@example.com --smtp-server="$(pwd)/fake.sendmail" $patches 2>errors
87'
88
89test_expect_success $PREREQ 'setup expect' '
90cat >expected <<\EOF
91!nobody@example.com!
92!author@example.com!
93!one@example.com!
94!two@example.com!
95EOF
96'
97
98test_expect_success $PREREQ \
99 'Verify commandline' \
100 'test_cmp expected commandline1'
101
102test_expect_success $PREREQ 'Send patches with --envelope-sender' '
103 clean_fake_sendmail &&
104 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
105'
106
107test_expect_success $PREREQ 'setup expect' '
108cat >expected <<\EOF
109!patch@example.com!
110!-i!
111!nobody@example.com!
112!author@example.com!
113!one@example.com!
114!two@example.com!
115EOF
116'
117
118test_expect_success $PREREQ \
119 'Verify commandline' \
120 'test_cmp expected commandline1'
121
122test_expect_success $PREREQ 'Send patches with --envelope-sender=auto' '
123 clean_fake_sendmail &&
124 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
125'
126
127test_expect_success $PREREQ 'setup expect' '
128cat >expected <<\EOF
129!nobody@example.com!
130!-i!
131!nobody@example.com!
132!author@example.com!
133!one@example.com!
134!two@example.com!
135EOF
136'
137
138test_expect_success $PREREQ \
139 'Verify commandline' \
140 'test_cmp expected commandline1'
141
142test_expect_success $PREREQ 'setup expect' "
143cat >expected-show-all-headers <<\EOF
1440001-Second.patch
145(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
146(mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
147(mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
148Dry-OK. Log says:
149Server: relay.example.com
150MAIL FROM:<from@example.com>
151RCPT TO:<to@example.com>
152RCPT TO:<cc@example.com>
153RCPT TO:<author@example.com>
154RCPT TO:<one@example.com>
155RCPT TO:<two@example.com>
156RCPT TO:<bcc@example.com>
157From: Example <from@example.com>
158To: to@example.com
159Cc: cc@example.com,
160 A <author@example.com>,
161 One <one@example.com>,
162 two@example.com
163Subject: [PATCH 1/1] Second.
164Date: DATE-STRING
165Message-Id: MESSAGE-ID-STRING
166X-Mailer: X-MAILER-STRING
167In-Reply-To: <unique-message-id@example.com>
168References: <unique-message-id@example.com>
169
170Result: OK
171EOF
172"
173
174test_suppress_self () {
175 test_commit $3 &&
176 test_when_finished "git reset --hard HEAD^" &&
177
178 write_script cccmd-sed <<-EOF &&
179 sed -n -e s/^cccmd--//p "\$1"
180 EOF
181
182 git commit --amend --author="$1 <$2>" -F - &&
183 clean_fake_sendmail &&
184 git format-patch --stdout -1 >"suppress-self-$3.patch" &&
185
186 git send-email --from="$1 <$2>" \
187 --to=nobody@example.com \
188 --cc-cmd=./cccmd-sed \
189 --suppress-cc=self \
190 --smtp-server="$(pwd)/fake.sendmail" \
191 suppress-self-$3.patch &&
192
193 mv msgtxt1 msgtxt1-$3 &&
194 sed -e '/^$/q' msgtxt1-$3 >"msghdr1-$3" &&
195 >"expected-no-cc-$3" &&
196
197 (grep '^Cc:' msghdr1-$3 >"actual-no-cc-$3";
198 test_cmp expected-no-cc-$3 actual-no-cc-$3)
199}
200
201test_suppress_self_unquoted () {
202 test_suppress_self "$1" "$2" "unquoted-$3" <<-EOF
203 test suppress-cc.self unquoted-$3 with name $1 email $2
204
205 unquoted-$3
206
207 cccmd--$1 <$2>
208
209 Cc: $1 <$2>
210 Signed-off-by: $1 <$2>
211 EOF
212}
213
214test_suppress_self_quoted () {
215 test_suppress_self "$1" "$2" "quoted-$3" <<-EOF
216 test suppress-cc.self quoted-$3 with name $1 email $2
217
218 quoted-$3
219
220 cccmd--"$1" <$2>
221
222 Cc: $1 <$2>
223 Cc: "$1" <$2>
224 Signed-off-by: $1 <$2>
225 Signed-off-by: "$1" <$2>
226 EOF
227}
228
229test_expect_success $PREREQ 'self name is suppressed' "
230 test_suppress_self_unquoted 'A U Thor' 'author@example.com' \
231 'self_name_suppressed'
232"
233
234test_expect_success $PREREQ 'self name with dot is suppressed' "
235 test_suppress_self_quoted 'A U. Thor' 'author@example.com' \
236 'self_name_dot_suppressed'
237"
238
239test_expect_success $PREREQ 'non-ascii self name is suppressed' "
240 test_suppress_self_quoted 'Füñný Nâmé' 'odd_?=mail@example.com' \
241 'non_ascii_self_suppressed'
242"
243
244test_expect_success $PREREQ 'sanitized self name is suppressed' "
245 test_suppress_self_unquoted '\"A U. Thor\"' 'author@example.com' \
246 'self_name_sanitized_suppressed'
247"
248
249test_expect_success $PREREQ 'Show all headers' '
250 git send-email \
251 --dry-run \
252 --suppress-cc=sob \
253 --from="Example <from@example.com>" \
254 --to=to@example.com \
255 --cc=cc@example.com \
256 --bcc=bcc@example.com \
257 --in-reply-to="<unique-message-id@example.com>" \
258 --smtp-server relay.example.com \
259 $patches |
260 sed -e "s/^\(Date:\).*/\1 DATE-STRING/" \
261 -e "s/^\(Message-Id:\).*/\1 MESSAGE-ID-STRING/" \
262 -e "s/^\(X-Mailer:\).*/\1 X-MAILER-STRING/" \
263 >actual-show-all-headers &&
264 test_cmp expected-show-all-headers actual-show-all-headers
265'
266
267test_expect_success $PREREQ 'Prompting works' '
268 clean_fake_sendmail &&
269 (echo "to@example.com"
270 echo ""
271 ) | GIT_SEND_EMAIL_NOTTY=1 git send-email \
272 --smtp-server="$(pwd)/fake.sendmail" \
273 $patches \
274 2>errors &&
275 grep "^From: A U Thor <author@example.com>\$" msgtxt1 &&
276 grep "^To: to@example.com\$" msgtxt1
277'
278
279test_expect_success $PREREQ,AUTOIDENT 'implicit ident is allowed' '
280 clean_fake_sendmail &&
281 (sane_unset GIT_AUTHOR_NAME &&
282 sane_unset GIT_AUTHOR_EMAIL &&
283 sane_unset GIT_COMMITTER_NAME &&
284 sane_unset GIT_COMMITTER_EMAIL &&
285 GIT_SEND_EMAIL_NOTTY=1 git send-email \
286 --smtp-server="$(pwd)/fake.sendmail" \
287 --to=to@example.com \
288 $patches </dev/null 2>errors
289 )
290'
291
292test_expect_success $PREREQ,!AUTOIDENT 'broken implicit ident aborts send-email' '
293 clean_fake_sendmail &&
294 (sane_unset GIT_AUTHOR_NAME &&
295 sane_unset GIT_AUTHOR_EMAIL &&
296 sane_unset GIT_COMMITTER_NAME &&
297 sane_unset GIT_COMMITTER_EMAIL &&
298 GIT_SEND_EMAIL_NOTTY=1 && export GIT_SEND_EMAIL_NOTTY &&
299 test_must_fail git send-email \
300 --smtp-server="$(pwd)/fake.sendmail" \
301 --to=to@example.com \
302 $patches </dev/null 2>errors &&
303 test_i18ngrep "tell me who you are" errors
304 )
305'
306
307test_expect_success $PREREQ 'tocmd works' '
308 clean_fake_sendmail &&
309 cp $patches tocmd.patch &&
310 echo tocmd--tocmd@example.com >>tocmd.patch &&
311 {
312 echo "#!$SHELL_PATH"
313 echo sed -n -e s/^tocmd--//p \"\$1\"
314 } > tocmd-sed &&
315 chmod +x tocmd-sed &&
316 git send-email \
317 --from="Example <nobody@example.com>" \
318 --to-cmd=./tocmd-sed \
319 --smtp-server="$(pwd)/fake.sendmail" \
320 tocmd.patch \
321 &&
322 grep "^To: tocmd@example.com" msgtxt1
323'
324
325test_expect_success $PREREQ 'cccmd works' '
326 clean_fake_sendmail &&
327 cp $patches cccmd.patch &&
328 echo "cccmd-- cccmd@example.com" >>cccmd.patch &&
329 {
330 echo "#!$SHELL_PATH"
331 echo sed -n -e s/^cccmd--//p \"\$1\"
332 } > cccmd-sed &&
333 chmod +x cccmd-sed &&
334 git send-email \
335 --from="Example <nobody@example.com>" \
336 --to=nobody@example.com \
337 --cc-cmd=./cccmd-sed \
338 --smtp-server="$(pwd)/fake.sendmail" \
339 cccmd.patch \
340 &&
341 grep "^ cccmd@example.com" msgtxt1
342'
343
344test_expect_success $PREREQ 'reject long lines' '
345 z8=zzzzzzzz &&
346 z64=$z8$z8$z8$z8$z8$z8$z8$z8 &&
347 z512=$z64$z64$z64$z64$z64$z64$z64$z64 &&
348 clean_fake_sendmail &&
349 cp $patches longline.patch &&
350 echo $z512$z512 >>longline.patch &&
351 test_must_fail git send-email \
352 --from="Example <nobody@example.com>" \
353 --to=nobody@example.com \
354 --smtp-server="$(pwd)/fake.sendmail" \
355 $patches longline.patch \
356 2>errors &&
357 grep longline.patch errors
358'
359
360test_expect_success $PREREQ 'no patch was sent' '
361 ! test -e commandline1
362'
363
364test_expect_success $PREREQ 'Author From: in message body' '
365 clean_fake_sendmail &&
366 git send-email \
367 --from="Example <nobody@example.com>" \
368 --to=nobody@example.com \
369 --smtp-server="$(pwd)/fake.sendmail" \
370 $patches &&
371 sed "1,/^\$/d" < msgtxt1 > msgbody1 &&
372 grep "From: A <author@example.com>" msgbody1
373'
374
375test_expect_success $PREREQ 'Author From: not in message body' '
376 clean_fake_sendmail &&
377 git send-email \
378 --from="A <author@example.com>" \
379 --to=nobody@example.com \
380 --smtp-server="$(pwd)/fake.sendmail" \
381 $patches &&
382 sed "1,/^\$/d" < msgtxt1 > msgbody1 &&
383 ! grep "From: A <author@example.com>" msgbody1
384'
385
386test_expect_success $PREREQ 'allow long lines with --no-validate' '
387 git send-email \
388 --from="Example <nobody@example.com>" \
389 --to=nobody@example.com \
390 --smtp-server="$(pwd)/fake.sendmail" \
391 --novalidate \
392 $patches longline.patch \
393 2>errors
394'
395
396test_expect_success $PREREQ 'Invalid In-Reply-To' '
397 clean_fake_sendmail &&
398 git send-email \
399 --from="Example <nobody@example.com>" \
400 --to=nobody@example.com \
401 --in-reply-to=" " \
402 --smtp-server="$(pwd)/fake.sendmail" \
403 $patches \
404 2>errors &&
405 ! grep "^In-Reply-To: < *>" msgtxt1
406'
407
408test_expect_success $PREREQ 'Valid In-Reply-To when prompting' '
409 clean_fake_sendmail &&
410 (echo "From Example <from@example.com>"
411 echo "To Example <to@example.com>"
412 echo ""
413 ) | env GIT_SEND_EMAIL_NOTTY=1 git send-email \
414 --smtp-server="$(pwd)/fake.sendmail" \
415 $patches 2>errors &&
416 ! grep "^In-Reply-To: < *>" msgtxt1
417'
418
419test_expect_success $PREREQ 'In-Reply-To without --chain-reply-to' '
420 clean_fake_sendmail &&
421 echo "<unique-message-id@example.com>" >expect &&
422 git send-email \
423 --from="Example <nobody@example.com>" \
424 --to=nobody@example.com \
425 --nochain-reply-to \
426 --in-reply-to="$(cat expect)" \
427 --smtp-server="$(pwd)/fake.sendmail" \
428 $patches $patches $patches \
429 2>errors &&
430 # The first message is a reply to --in-reply-to
431 sed -n -e "s/^In-Reply-To: *\(.*\)/\1/p" msgtxt1 >actual &&
432 test_cmp expect actual &&
433 # Second and subsequent messages are replies to the first one
434 sed -n -e "s/^Message-Id: *\(.*\)/\1/p" msgtxt1 >expect &&
435 sed -n -e "s/^In-Reply-To: *\(.*\)/\1/p" msgtxt2 >actual &&
436 test_cmp expect actual &&
437 sed -n -e "s/^In-Reply-To: *\(.*\)/\1/p" msgtxt3 >actual &&
438 test_cmp expect actual
439'
440
441test_expect_success $PREREQ 'In-Reply-To with --chain-reply-to' '
442 clean_fake_sendmail &&
443 echo "<unique-message-id@example.com>" >expect &&
444 git send-email \
445 --from="Example <nobody@example.com>" \
446 --to=nobody@example.com \
447 --chain-reply-to \
448 --in-reply-to="$(cat expect)" \
449 --smtp-server="$(pwd)/fake.sendmail" \
450 $patches $patches $patches \
451 2>errors &&
452 sed -n -e "s/^In-Reply-To: *\(.*\)/\1/p" msgtxt1 >actual &&
453 test_cmp expect actual &&
454 sed -n -e "s/^Message-Id: *\(.*\)/\1/p" msgtxt1 >expect &&
455 sed -n -e "s/^In-Reply-To: *\(.*\)/\1/p" msgtxt2 >actual &&
456 test_cmp expect actual &&
457 sed -n -e "s/^Message-Id: *\(.*\)/\1/p" msgtxt2 >expect &&
458 sed -n -e "s/^In-Reply-To: *\(.*\)/\1/p" msgtxt3 >actual &&
459 test_cmp expect actual
460'
461
462test_expect_success $PREREQ 'setup fake editor' '
463 (echo "#!$SHELL_PATH" &&
464 echo "echo fake edit >>\"\$1\""
465 ) >fake-editor &&
466 chmod +x fake-editor
467'
468
469test_set_editor "$(pwd)/fake-editor"
470
471test_expect_success $PREREQ '--compose works' '
472 clean_fake_sendmail &&
473 git send-email \
474 --compose --subject foo \
475 --from="Example <nobody@example.com>" \
476 --to=nobody@example.com \
477 --smtp-server="$(pwd)/fake.sendmail" \
478 $patches \
479 2>errors
480'
481
482test_expect_success $PREREQ 'first message is compose text' '
483 grep "^fake edit" msgtxt1
484'
485
486test_expect_success $PREREQ 'second message is patch' '
487 grep "Subject:.*Second" msgtxt2
488'
489
490test_expect_success $PREREQ 'setup expect' "
491cat >expected-suppress-sob <<\EOF
4920001-Second.patch
493(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
494(mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
495(mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
496Dry-OK. Log says:
497Server: relay.example.com
498MAIL FROM:<from@example.com>
499RCPT TO:<to@example.com>
500RCPT TO:<cc@example.com>
501RCPT TO:<author@example.com>
502RCPT TO:<one@example.com>
503RCPT TO:<two@example.com>
504From: Example <from@example.com>
505To: to@example.com
506Cc: cc@example.com,
507 A <author@example.com>,
508 One <one@example.com>,
509 two@example.com
510Subject: [PATCH 1/1] Second.
511Date: DATE-STRING
512Message-Id: MESSAGE-ID-STRING
513X-Mailer: X-MAILER-STRING
514
515Result: OK
516EOF
517"
518
519test_suppression () {
520 git send-email \
521 --dry-run \
522 --suppress-cc=$1 ${2+"--suppress-cc=$2"} \
523 --from="Example <from@example.com>" \
524 --to=to@example.com \
525 --smtp-server relay.example.com \
526 $patches |
527 sed -e "s/^\(Date:\).*/\1 DATE-STRING/" \
528 -e "s/^\(Message-Id:\).*/\1 MESSAGE-ID-STRING/" \
529 -e "s/^\(X-Mailer:\).*/\1 X-MAILER-STRING/" \
530 >actual-suppress-$1${2+"-$2"} &&
531 test_cmp expected-suppress-$1${2+"-$2"} actual-suppress-$1${2+"-$2"}
532}
533
534test_expect_success $PREREQ 'sendemail.cc set' '
535 git config sendemail.cc cc@example.com &&
536 test_suppression sob
537'
538
539test_expect_success $PREREQ 'setup expect' "
540cat >expected-suppress-sob <<\EOF
5410001-Second.patch
542(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
543(mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
544(mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
545Dry-OK. Log says:
546Server: relay.example.com
547MAIL FROM:<from@example.com>
548RCPT TO:<to@example.com>
549RCPT TO:<author@example.com>
550RCPT TO:<one@example.com>
551RCPT TO:<two@example.com>
552From: Example <from@example.com>
553To: to@example.com
554Cc: A <author@example.com>,
555 One <one@example.com>,
556 two@example.com
557Subject: [PATCH 1/1] Second.
558Date: DATE-STRING
559Message-Id: MESSAGE-ID-STRING
560X-Mailer: X-MAILER-STRING
561
562Result: OK
563EOF
564"
565
566test_expect_success $PREREQ 'sendemail.cc unset' '
567 git config --unset sendemail.cc &&
568 test_suppression sob
569'
570
571test_expect_success $PREREQ 'setup expect' "
572cat >expected-suppress-cccmd <<\EOF
5730001-Second.patch
574(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
575(mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
576(mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
577(body) Adding cc: C O Mitter <committer@example.com> from line 'Signed-off-by: C O Mitter <committer@example.com>'
578Dry-OK. Log says:
579Server: relay.example.com
580MAIL FROM:<from@example.com>
581RCPT TO:<to@example.com>
582RCPT TO:<author@example.com>
583RCPT TO:<one@example.com>
584RCPT TO:<two@example.com>
585RCPT TO:<committer@example.com>
586From: Example <from@example.com>
587To: to@example.com
588Cc: A <author@example.com>,
589 One <one@example.com>,
590 two@example.com,
591 C O Mitter <committer@example.com>
592Subject: [PATCH 1/1] Second.
593Date: DATE-STRING
594Message-Id: MESSAGE-ID-STRING
595X-Mailer: X-MAILER-STRING
596
597Result: OK
598EOF
599"
600
601test_expect_success $PREREQ 'sendemail.cccmd' '
602 echo echo cc-cmd@example.com > cccmd &&
603 chmod +x cccmd &&
604 git config sendemail.cccmd ./cccmd &&
605 test_suppression cccmd
606'
607
608test_expect_success $PREREQ 'setup expect' '
609cat >expected-suppress-all <<\EOF
6100001-Second.patch
611Dry-OK. Log says:
612Server: relay.example.com
613MAIL FROM:<from@example.com>
614RCPT TO:<to@example.com>
615From: Example <from@example.com>
616To: to@example.com
617Subject: [PATCH 1/1] Second.
618Date: DATE-STRING
619Message-Id: MESSAGE-ID-STRING
620X-Mailer: X-MAILER-STRING
621
622Result: OK
623EOF
624'
625
626test_expect_success $PREREQ '--suppress-cc=all' '
627 test_suppression all
628'
629
630test_expect_success $PREREQ 'setup expect' "
631cat >expected-suppress-body <<\EOF
6320001-Second.patch
633(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
634(mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
635(mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
636(cc-cmd) Adding cc: cc-cmd@example.com from: './cccmd'
637Dry-OK. Log says:
638Server: relay.example.com
639MAIL FROM:<from@example.com>
640RCPT TO:<to@example.com>
641RCPT TO:<author@example.com>
642RCPT TO:<one@example.com>
643RCPT TO:<two@example.com>
644RCPT TO:<cc-cmd@example.com>
645From: Example <from@example.com>
646To: to@example.com
647Cc: A <author@example.com>,
648 One <one@example.com>,
649 two@example.com,
650 cc-cmd@example.com
651Subject: [PATCH 1/1] Second.
652Date: DATE-STRING
653Message-Id: MESSAGE-ID-STRING
654X-Mailer: X-MAILER-STRING
655
656Result: OK
657EOF
658"
659
660test_expect_success $PREREQ '--suppress-cc=body' '
661 test_suppression body
662'
663
664test_expect_success $PREREQ 'setup expect' "
665cat >expected-suppress-body-cccmd <<\EOF
6660001-Second.patch
667(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
668(mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
669(mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
670Dry-OK. Log says:
671Server: relay.example.com
672MAIL FROM:<from@example.com>
673RCPT TO:<to@example.com>
674RCPT TO:<author@example.com>
675RCPT TO:<one@example.com>
676RCPT TO:<two@example.com>
677From: Example <from@example.com>
678To: to@example.com
679Cc: A <author@example.com>,
680 One <one@example.com>,
681 two@example.com
682Subject: [PATCH 1/1] Second.
683Date: DATE-STRING
684Message-Id: MESSAGE-ID-STRING
685X-Mailer: X-MAILER-STRING
686
687Result: OK
688EOF
689"
690
691test_expect_success $PREREQ '--suppress-cc=body --suppress-cc=cccmd' '
692 test_suppression body cccmd
693'
694
695test_expect_success $PREREQ 'setup expect' "
696cat >expected-suppress-sob <<\EOF
6970001-Second.patch
698(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
699(mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
700(mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
701Dry-OK. Log says:
702Server: relay.example.com
703MAIL FROM:<from@example.com>
704RCPT TO:<to@example.com>
705RCPT TO:<author@example.com>
706RCPT TO:<one@example.com>
707RCPT TO:<two@example.com>
708From: Example <from@example.com>
709To: to@example.com
710Cc: A <author@example.com>,
711 One <one@example.com>,
712 two@example.com
713Subject: [PATCH 1/1] Second.
714Date: DATE-STRING
715Message-Id: MESSAGE-ID-STRING
716X-Mailer: X-MAILER-STRING
717
718Result: OK
719EOF
720"
721
722test_expect_success $PREREQ '--suppress-cc=sob' '
723 test_might_fail git config --unset sendemail.cccmd &&
724 test_suppression sob
725'
726
727test_expect_success $PREREQ 'setup expect' "
728cat >expected-suppress-bodycc <<\EOF
7290001-Second.patch
730(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
731(mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
732(mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
733(body) Adding cc: C O Mitter <committer@example.com> from line 'Signed-off-by: C O Mitter <committer@example.com>'
734Dry-OK. Log says:
735Server: relay.example.com
736MAIL FROM:<from@example.com>
737RCPT TO:<to@example.com>
738RCPT TO:<author@example.com>
739RCPT TO:<one@example.com>
740RCPT TO:<two@example.com>
741RCPT TO:<committer@example.com>
742From: Example <from@example.com>
743To: to@example.com
744Cc: A <author@example.com>,
745 One <one@example.com>,
746 two@example.com,
747 C O Mitter <committer@example.com>
748Subject: [PATCH 1/1] Second.
749Date: DATE-STRING
750Message-Id: MESSAGE-ID-STRING
751X-Mailer: X-MAILER-STRING
752
753Result: OK
754EOF
755"
756
757test_expect_success $PREREQ '--suppress-cc=bodycc' '
758 test_suppression bodycc
759'
760
761test_expect_success $PREREQ 'setup expect' "
762cat >expected-suppress-cc <<\EOF
7630001-Second.patch
764(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
765(body) Adding cc: C O Mitter <committer@example.com> from line 'Signed-off-by: C O Mitter <committer@example.com>'
766Dry-OK. Log says:
767Server: relay.example.com
768MAIL FROM:<from@example.com>
769RCPT TO:<to@example.com>
770RCPT TO:<author@example.com>
771RCPT TO:<committer@example.com>
772From: Example <from@example.com>
773To: to@example.com
774Cc: A <author@example.com>,
775 C O Mitter <committer@example.com>
776Subject: [PATCH 1/1] Second.
777Date: DATE-STRING
778Message-Id: MESSAGE-ID-STRING
779X-Mailer: X-MAILER-STRING
780
781Result: OK
782EOF
783"
784
785test_expect_success $PREREQ '--suppress-cc=cc' '
786 test_suppression cc
787'
788
789test_confirm () {
790 echo y | \
791 GIT_SEND_EMAIL_NOTTY=1 \
792 git send-email \
793 --from="Example <nobody@example.com>" \
794 --to=nobody@example.com \
795 --smtp-server="$(pwd)/fake.sendmail" \
796 $@ $patches > stdout &&
797 grep "Send this email" stdout
798}
799
800test_expect_success $PREREQ '--confirm=always' '
801 test_confirm --confirm=always --suppress-cc=all
802'
803
804test_expect_success $PREREQ '--confirm=auto' '
805 test_confirm --confirm=auto
806'
807
808test_expect_success $PREREQ '--confirm=cc' '
809 test_confirm --confirm=cc
810'
811
812test_expect_success $PREREQ '--confirm=compose' '
813 test_confirm --confirm=compose --compose
814'
815
816test_expect_success $PREREQ 'confirm by default (due to cc)' '
817 CONFIRM=$(git config --get sendemail.confirm) &&
818 git config --unset sendemail.confirm &&
819 test_confirm
820 ret="$?"
821 git config sendemail.confirm ${CONFIRM:-never}
822 test $ret = "0"
823'
824
825test_expect_success $PREREQ 'confirm by default (due to --compose)' '
826 CONFIRM=$(git config --get sendemail.confirm) &&
827 git config --unset sendemail.confirm &&
828 test_confirm --suppress-cc=all --compose
829 ret="$?"
830 git config sendemail.confirm ${CONFIRM:-never}
831 test $ret = "0"
832'
833
834test_expect_success $PREREQ 'confirm detects EOF (inform assumes y)' '
835 CONFIRM=$(git config --get sendemail.confirm) &&
836 git config --unset sendemail.confirm &&
837 rm -fr outdir &&
838 git format-patch -2 -o outdir &&
839 GIT_SEND_EMAIL_NOTTY=1 \
840 git send-email \
841 --from="Example <nobody@example.com>" \
842 --to=nobody@example.com \
843 --smtp-server="$(pwd)/fake.sendmail" \
844 outdir/*.patch < /dev/null
845 ret="$?"
846 git config sendemail.confirm ${CONFIRM:-never}
847 test $ret = "0"
848'
849
850test_expect_success $PREREQ 'confirm detects EOF (auto causes failure)' '
851 CONFIRM=$(git config --get sendemail.confirm) &&
852 git config sendemail.confirm auto &&
853 GIT_SEND_EMAIL_NOTTY=1 &&
854 export GIT_SEND_EMAIL_NOTTY &&
855 test_must_fail git send-email \
856 --from="Example <nobody@example.com>" \
857 --to=nobody@example.com \
858 --smtp-server="$(pwd)/fake.sendmail" \
859 $patches < /dev/null
860 ret="$?"
861 git config sendemail.confirm ${CONFIRM:-never}
862 test $ret = "0"
863'
864
865test_expect_success $PREREQ 'confirm does not loop forever' '
866 CONFIRM=$(git config --get sendemail.confirm) &&
867 git config sendemail.confirm auto &&
868 GIT_SEND_EMAIL_NOTTY=1 &&
869 export GIT_SEND_EMAIL_NOTTY &&
870 yes "bogus" | test_must_fail git send-email \
871 --from="Example <nobody@example.com>" \
872 --to=nobody@example.com \
873 --smtp-server="$(pwd)/fake.sendmail" \
874 $patches
875 ret="$?"
876 git config sendemail.confirm ${CONFIRM:-never}
877 test $ret = "0"
878'
879
880test_expect_success $PREREQ 'utf8 Cc is rfc2047 encoded' '
881 clean_fake_sendmail &&
882 rm -fr outdir &&
883 git format-patch -1 -o outdir --cc="àéìöú <utf8@example.com>" &&
884 git send-email \
885 --from="Example <nobody@example.com>" \
886 --to=nobody@example.com \
887 --smtp-server="$(pwd)/fake.sendmail" \
888 outdir/*.patch &&
889 grep "^ " msgtxt1 |
890 grep "=?UTF-8?q?=C3=A0=C3=A9=C3=AC=C3=B6=C3=BA?= <utf8@example.com>"
891'
892
893test_expect_success $PREREQ '--compose adds MIME for utf8 body' '
894 clean_fake_sendmail &&
895 (echo "#!$SHELL_PATH" &&
896 echo "echo utf8 body: àéìöú >>\"\$1\""
897 ) >fake-editor-utf8 &&
898 chmod +x fake-editor-utf8 &&
899 GIT_EDITOR="\"$(pwd)/fake-editor-utf8\"" \
900 git send-email \
901 --compose --subject foo \
902 --from="Example <nobody@example.com>" \
903 --to=nobody@example.com \
904 --smtp-server="$(pwd)/fake.sendmail" \
905 $patches &&
906 grep "^utf8 body" msgtxt1 &&
907 grep "^Content-Type: text/plain; charset=UTF-8" msgtxt1
908'
909
910test_expect_success $PREREQ '--compose respects user mime type' '
911 clean_fake_sendmail &&
912 (echo "#!$SHELL_PATH" &&
913 echo "(echo MIME-Version: 1.0"
914 echo " echo Content-Type: text/plain\\; charset=iso-8859-1"
915 echo " echo Content-Transfer-Encoding: 8bit"
916 echo " echo Subject: foo"
917 echo " echo "
918 echo " echo utf8 body: àéìöú) >\"\$1\""
919 ) >fake-editor-utf8-mime &&
920 chmod +x fake-editor-utf8-mime &&
921 GIT_EDITOR="\"$(pwd)/fake-editor-utf8-mime\"" \
922 git send-email \
923 --compose --subject foo \
924 --from="Example <nobody@example.com>" \
925 --to=nobody@example.com \
926 --smtp-server="$(pwd)/fake.sendmail" \
927 $patches &&
928 grep "^utf8 body" msgtxt1 &&
929 grep "^Content-Type: text/plain; charset=iso-8859-1" msgtxt1 &&
930 ! grep "^Content-Type: text/plain; charset=UTF-8" msgtxt1
931'
932
933test_expect_success $PREREQ '--compose adds MIME for utf8 subject' '
934 clean_fake_sendmail &&
935 GIT_EDITOR="\"$(pwd)/fake-editor\"" \
936 git send-email \
937 --compose --subject utf8-sübjëct \
938 --from="Example <nobody@example.com>" \
939 --to=nobody@example.com \
940 --smtp-server="$(pwd)/fake.sendmail" \
941 $patches &&
942 grep "^fake edit" msgtxt1 &&
943 grep "^Subject: =?UTF-8?q?utf8-s=C3=BCbj=C3=ABct?=" msgtxt1
944'
945
946test_expect_success $PREREQ 'utf8 author is correctly passed on' '
947 clean_fake_sendmail &&
948 test_commit weird_author &&
949 test_when_finished "git reset --hard HEAD^" &&
950 git commit --amend --author "Füñný Nâmé <odd_?=mail@example.com>" &&
951 git format-patch --stdout -1 >funny_name.patch &&
952 git send-email --from="Example <nobody@example.com>" \
953 --to=nobody@example.com \
954 --smtp-server="$(pwd)/fake.sendmail" \
955 funny_name.patch &&
956 grep "^From: Füñný Nâmé <odd_?=mail@example.com>" msgtxt1
957'
958
959test_expect_success $PREREQ 'utf8 sender is not duplicated' '
960 clean_fake_sendmail &&
961 test_commit weird_sender &&
962 test_when_finished "git reset --hard HEAD^" &&
963 git commit --amend --author "Füñný Nâmé <odd_?=mail@example.com>" &&
964 git format-patch --stdout -1 >funny_name.patch &&
965 git send-email --from="Füñný Nâmé <odd_?=mail@example.com>" \
966 --to=nobody@example.com \
967 --smtp-server="$(pwd)/fake.sendmail" \
968 funny_name.patch &&
969 grep "^From: " msgtxt1 >msgfrom &&
970 test_line_count = 1 msgfrom
971'
972
973test_expect_success $PREREQ 'sendemail.composeencoding works' '
974 clean_fake_sendmail &&
975 git config sendemail.composeencoding iso-8859-1 &&
976 (echo "#!$SHELL_PATH" &&
977 echo "echo utf8 body: àéìöú >>\"\$1\""
978 ) >fake-editor-utf8 &&
979 chmod +x fake-editor-utf8 &&
980 GIT_EDITOR="\"$(pwd)/fake-editor-utf8\"" \
981 git send-email \
982 --compose --subject foo \
983 --from="Example <nobody@example.com>" \
984 --to=nobody@example.com \
985 --smtp-server="$(pwd)/fake.sendmail" \
986 $patches &&
987 grep "^utf8 body" msgtxt1 &&
988 grep "^Content-Type: text/plain; charset=iso-8859-1" msgtxt1
989'
990
991test_expect_success $PREREQ '--compose-encoding works' '
992 clean_fake_sendmail &&
993 (echo "#!$SHELL_PATH" &&
994 echo "echo utf8 body: àéìöú >>\"\$1\""
995 ) >fake-editor-utf8 &&
996 chmod +x fake-editor-utf8 &&
997 GIT_EDITOR="\"$(pwd)/fake-editor-utf8\"" \
998 git send-email \
999 --compose-encoding iso-8859-1 \
1000 --compose --subject foo \
1001 --from="Example <nobody@example.com>" \
1002 --to=nobody@example.com \
1003 --smtp-server="$(pwd)/fake.sendmail" \
1004 $patches &&
1005 grep "^utf8 body" msgtxt1 &&
1006 grep "^Content-Type: text/plain; charset=iso-8859-1" msgtxt1
1007'
1008
1009test_expect_success $PREREQ '--compose-encoding overrides sendemail.composeencoding' '
1010 clean_fake_sendmail &&
1011 git config sendemail.composeencoding iso-8859-1 &&
1012 (echo "#!$SHELL_PATH" &&
1013 echo "echo utf8 body: àéìöú >>\"\$1\""
1014 ) >fake-editor-utf8 &&
1015 chmod +x fake-editor-utf8 &&
1016 GIT_EDITOR="\"$(pwd)/fake-editor-utf8\"" \
1017 git send-email \
1018 --compose-encoding iso-8859-2 \
1019 --compose --subject foo \
1020 --from="Example <nobody@example.com>" \
1021 --to=nobody@example.com \
1022 --smtp-server="$(pwd)/fake.sendmail" \
1023 $patches &&
1024 grep "^utf8 body" msgtxt1 &&
1025 grep "^Content-Type: text/plain; charset=iso-8859-2" msgtxt1
1026'
1027
1028test_expect_success $PREREQ '--compose-encoding adds correct MIME for subject' '
1029 clean_fake_sendmail &&
1030 GIT_EDITOR="\"$(pwd)/fake-editor\"" \
1031 git send-email \
1032 --compose-encoding iso-8859-2 \
1033 --compose --subject utf8-sübjëct \
1034 --from="Example <nobody@example.com>" \
1035 --to=nobody@example.com \
1036 --smtp-server="$(pwd)/fake.sendmail" \
1037 $patches &&
1038 grep "^fake edit" msgtxt1 &&
1039 grep "^Subject: =?iso-8859-2?q?utf8-s=C3=BCbj=C3=ABct?=" msgtxt1
1040'
1041
1042test_expect_success $PREREQ 'detects ambiguous reference/file conflict' '
1043 echo master > master &&
1044 git add master &&
1045 git commit -m"add master" &&
1046 test_must_fail git send-email --dry-run master 2>errors &&
1047 grep disambiguate errors
1048'
1049
1050test_expect_success $PREREQ 'feed two files' '
1051 rm -fr outdir &&
1052 git format-patch -2 -o outdir &&
1053 git send-email \
1054 --dry-run \
1055 --from="Example <nobody@example.com>" \
1056 --to=nobody@example.com \
1057 outdir/000?-*.patch 2>errors >out &&
1058 grep "^Subject: " out >subjects &&
1059 test "z$(sed -n -e 1p subjects)" = "zSubject: [PATCH 1/2] Second." &&
1060 test "z$(sed -n -e 2p subjects)" = "zSubject: [PATCH 2/2] add master"
1061'
1062
1063test_expect_success $PREREQ 'in-reply-to but no threading' '
1064 git send-email \
1065 --dry-run \
1066 --from="Example <nobody@example.com>" \
1067 --to=nobody@example.com \
1068 --in-reply-to="<in-reply-id@example.com>" \
1069 --nothread \
1070 $patches |
1071 grep "In-Reply-To: <in-reply-id@example.com>"
1072'
1073
1074test_expect_success $PREREQ 'no in-reply-to and no threading' '
1075 git send-email \
1076 --dry-run \
1077 --from="Example <nobody@example.com>" \
1078 --to=nobody@example.com \
1079 --nothread \
1080 $patches $patches >stdout &&
1081 ! grep "In-Reply-To: " stdout
1082'
1083
1084test_expect_success $PREREQ 'threading but no chain-reply-to' '
1085 git send-email \
1086 --dry-run \
1087 --from="Example <nobody@example.com>" \
1088 --to=nobody@example.com \
1089 --thread \
1090 --nochain-reply-to \
1091 $patches $patches >stdout &&
1092 grep "In-Reply-To: " stdout
1093'
1094
1095test_expect_success $PREREQ 'warning with an implicit --chain-reply-to' '
1096 git send-email \
1097 --dry-run \
1098 --from="Example <nobody@example.com>" \
1099 --to=nobody@example.com \
1100 outdir/000?-*.patch 2>errors >out &&
1101 grep "no-chain-reply-to" errors
1102'
1103
1104test_expect_success $PREREQ 'no warning with an explicit --chain-reply-to' '
1105 git send-email \
1106 --dry-run \
1107 --from="Example <nobody@example.com>" \
1108 --to=nobody@example.com \
1109 --chain-reply-to \
1110 outdir/000?-*.patch 2>errors >out &&
1111 ! grep "no-chain-reply-to" errors
1112'
1113
1114test_expect_success $PREREQ 'no warning with an explicit --no-chain-reply-to' '
1115 git send-email \
1116 --dry-run \
1117 --from="Example <nobody@example.com>" \
1118 --to=nobody@example.com \
1119 --nochain-reply-to \
1120 outdir/000?-*.patch 2>errors >out &&
1121 ! grep "no-chain-reply-to" errors
1122'
1123
1124test_expect_success $PREREQ 'no warning with sendemail.chainreplyto = false' '
1125 git config sendemail.chainreplyto false &&
1126 git send-email \
1127 --dry-run \
1128 --from="Example <nobody@example.com>" \
1129 --to=nobody@example.com \
1130 outdir/000?-*.patch 2>errors >out &&
1131 ! grep "no-chain-reply-to" errors
1132'
1133
1134test_expect_success $PREREQ 'no warning with sendemail.chainreplyto = true' '
1135 git config sendemail.chainreplyto true &&
1136 git send-email \
1137 --dry-run \
1138 --from="Example <nobody@example.com>" \
1139 --to=nobody@example.com \
1140 outdir/000?-*.patch 2>errors >out &&
1141 ! grep "no-chain-reply-to" errors
1142'
1143
1144test_expect_success $PREREQ 'sendemail.to works' '
1145 git config --replace-all sendemail.to "Somebody <somebody@ex.com>" &&
1146 git send-email \
1147 --dry-run \
1148 --from="Example <nobody@example.com>" \
1149 $patches $patches >stdout &&
1150 grep "To: Somebody <somebody@ex.com>" stdout
1151'
1152
1153test_expect_success $PREREQ '--no-to overrides sendemail.to' '
1154 git send-email \
1155 --dry-run \
1156 --from="Example <nobody@example.com>" \
1157 --no-to \
1158 --to=nobody@example.com \
1159 $patches $patches >stdout &&
1160 grep "To: nobody@example.com" stdout &&
1161 ! grep "To: Somebody <somebody@ex.com>" stdout
1162'
1163
1164test_expect_success $PREREQ 'sendemail.cc works' '
1165 git config --replace-all sendemail.cc "Somebody <somebody@ex.com>" &&
1166 git send-email \
1167 --dry-run \
1168 --from="Example <nobody@example.com>" \
1169 --to=nobody@example.com \
1170 $patches $patches >stdout &&
1171 grep "Cc: Somebody <somebody@ex.com>" stdout
1172'
1173
1174test_expect_success $PREREQ '--no-cc overrides sendemail.cc' '
1175 git send-email \
1176 --dry-run \
1177 --from="Example <nobody@example.com>" \
1178 --no-cc \
1179 --cc=bodies@example.com \
1180 --to=nobody@example.com \
1181 $patches $patches >stdout &&
1182 grep "Cc: bodies@example.com" stdout &&
1183 ! grep "Cc: Somebody <somebody@ex.com>" stdout
1184'
1185
1186test_expect_success $PREREQ 'sendemail.bcc works' '
1187 git config --replace-all sendemail.bcc "Other <other@ex.com>" &&
1188 git send-email \
1189 --dry-run \
1190 --from="Example <nobody@example.com>" \
1191 --to=nobody@example.com \
1192 --smtp-server relay.example.com \
1193 $patches $patches >stdout &&
1194 grep "RCPT TO:<other@ex.com>" stdout
1195'
1196
1197test_expect_success $PREREQ '--no-bcc overrides sendemail.bcc' '
1198 git send-email \
1199 --dry-run \
1200 --from="Example <nobody@example.com>" \
1201 --no-bcc \
1202 --bcc=bodies@example.com \
1203 --to=nobody@example.com \
1204 --smtp-server relay.example.com \
1205 $patches $patches >stdout &&
1206 grep "RCPT TO:<bodies@example.com>" stdout &&
1207 ! grep "RCPT TO:<other@ex.com>" stdout
1208'
1209
1210test_expect_success $PREREQ 'patches To headers are used by default' '
1211 patch=`git format-patch -1 --to="bodies@example.com"` &&
1212 test_when_finished "rm $patch" &&
1213 git send-email \
1214 --dry-run \
1215 --from="Example <nobody@example.com>" \
1216 --smtp-server relay.example.com \
1217 $patch >stdout &&
1218 grep "RCPT TO:<bodies@example.com>" stdout
1219'
1220
1221test_expect_success $PREREQ 'patches To headers are appended to' '
1222 patch=`git format-patch -1 --to="bodies@example.com"` &&
1223 test_when_finished "rm $patch" &&
1224 git send-email \
1225 --dry-run \
1226 --from="Example <nobody@example.com>" \
1227 --to=nobody@example.com \
1228 --smtp-server relay.example.com \
1229 $patch >stdout &&
1230 grep "RCPT TO:<bodies@example.com>" stdout &&
1231 grep "RCPT TO:<nobody@example.com>" stdout
1232'
1233
1234test_expect_success $PREREQ 'To headers from files reset each patch' '
1235 patch1=`git format-patch -1 --to="bodies@example.com"` &&
1236 patch2=`git format-patch -1 --to="other@example.com" HEAD~` &&
1237 test_when_finished "rm $patch1 && rm $patch2" &&
1238 git send-email \
1239 --dry-run \
1240 --from="Example <nobody@example.com>" \
1241 --to="nobody@example.com" \
1242 --smtp-server relay.example.com \
1243 $patch1 $patch2 >stdout &&
1244 test $(grep -c "RCPT TO:<bodies@example.com>" stdout) = 1 &&
1245 test $(grep -c "RCPT TO:<nobody@example.com>" stdout) = 2 &&
1246 test $(grep -c "RCPT TO:<other@example.com>" stdout) = 1
1247'
1248
1249test_expect_success $PREREQ 'setup expect' '
1250cat >email-using-8bit <<EOF
1251From fe6ecc66ece37198fe5db91fa2fc41d9f4fe5cc4 Mon Sep 17 00:00:00 2001
1252Message-Id: <bogus-message-id@example.com>
1253From: author@example.com
1254Date: Sat, 12 Jun 2010 15:53:58 +0200
1255Subject: subject goes here
1256
1257Dieser deutsche Text enthält einen Umlaut!
1258EOF
1259'
1260
1261test_expect_success $PREREQ 'setup expect' '
1262cat >expected <<EOF
1263Subject: subject goes here
1264EOF
1265'
1266
1267test_expect_success $PREREQ 'ASCII subject is not RFC2047 quoted' '
1268 clean_fake_sendmail &&
1269 echo bogus |
1270 git send-email --from=author@example.com --to=nobody@example.com \
1271 --smtp-server="$(pwd)/fake.sendmail" \
1272 --8bit-encoding=UTF-8 \
1273 email-using-8bit >stdout &&
1274 grep "Subject" msgtxt1 >actual &&
1275 test_cmp expected actual
1276'
1277
1278test_expect_success $PREREQ 'setup expect' '
1279cat >content-type-decl <<EOF
1280MIME-Version: 1.0
1281Content-Type: text/plain; charset=UTF-8
1282Content-Transfer-Encoding: 8bit
1283EOF
1284'
1285
1286test_expect_success $PREREQ 'asks about and fixes 8bit encodings' '
1287 clean_fake_sendmail &&
1288 echo |
1289 git send-email --from=author@example.com --to=nobody@example.com \
1290 --smtp-server="$(pwd)/fake.sendmail" \
1291 email-using-8bit >stdout &&
1292 grep "do not declare a Content-Transfer-Encoding" stdout &&
1293 grep email-using-8bit stdout &&
1294 grep "Which 8bit encoding" stdout &&
1295 egrep "Content|MIME" msgtxt1 >actual &&
1296 test_cmp actual content-type-decl
1297'
1298
1299test_expect_success $PREREQ 'sendemail.8bitEncoding works' '
1300 clean_fake_sendmail &&
1301 git config sendemail.assume8bitEncoding UTF-8 &&
1302 echo bogus |
1303 git send-email --from=author@example.com --to=nobody@example.com \
1304 --smtp-server="$(pwd)/fake.sendmail" \
1305 email-using-8bit >stdout &&
1306 egrep "Content|MIME" msgtxt1 >actual &&
1307 test_cmp actual content-type-decl
1308'
1309
1310test_expect_success $PREREQ '--8bit-encoding overrides sendemail.8bitEncoding' '
1311 clean_fake_sendmail &&
1312 git config sendemail.assume8bitEncoding "bogus too" &&
1313 echo bogus |
1314 git send-email --from=author@example.com --to=nobody@example.com \
1315 --smtp-server="$(pwd)/fake.sendmail" \
1316 --8bit-encoding=UTF-8 \
1317 email-using-8bit >stdout &&
1318 egrep "Content|MIME" msgtxt1 >actual &&
1319 test_cmp actual content-type-decl
1320'
1321
1322test_expect_success $PREREQ 'setup expect' '
1323cat >email-using-8bit <<EOF
1324From fe6ecc66ece37198fe5db91fa2fc41d9f4fe5cc4 Mon Sep 17 00:00:00 2001
1325Message-Id: <bogus-message-id@example.com>
1326From: author@example.com
1327Date: Sat, 12 Jun 2010 15:53:58 +0200
1328Subject: Dieser Betreff enthält auch einen Umlaut!
1329
1330Nothing to see here.
1331EOF
1332'
1333
1334test_expect_success $PREREQ 'setup expect' '
1335cat >expected <<EOF
1336Subject: =?UTF-8?q?Dieser=20Betreff=20enth=C3=A4lt=20auch=20einen=20Umlaut!?=
1337EOF
1338'
1339
1340test_expect_success $PREREQ '--8bit-encoding also treats subject' '
1341 clean_fake_sendmail &&
1342 echo bogus |
1343 git send-email --from=author@example.com --to=nobody@example.com \
1344 --smtp-server="$(pwd)/fake.sendmail" \
1345 --8bit-encoding=UTF-8 \
1346 email-using-8bit >stdout &&
1347 grep "Subject" msgtxt1 >actual &&
1348 test_cmp expected actual
1349'
1350
1351# Note that the patches in this test are deliberately out of order; we
1352# want to make sure it works even if the cover-letter is not in the
1353# first mail.
1354test_expect_success $PREREQ 'refusing to send cover letter template' '
1355 clean_fake_sendmail &&
1356 rm -fr outdir &&
1357 git format-patch --cover-letter -2 -o outdir &&
1358 test_must_fail git send-email \
1359 --from="Example <nobody@example.com>" \
1360 --to=nobody@example.com \
1361 --smtp-server="$(pwd)/fake.sendmail" \
1362 outdir/0002-*.patch \
1363 outdir/0000-*.patch \
1364 outdir/0001-*.patch \
1365 2>errors >out &&
1366 grep "SUBJECT HERE" errors &&
1367 test -z "$(ls msgtxt*)"
1368'
1369
1370test_expect_success $PREREQ '--force sends cover letter template anyway' '
1371 clean_fake_sendmail &&
1372 rm -fr outdir &&
1373 git format-patch --cover-letter -2 -o outdir &&
1374 git send-email \
1375 --force \
1376 --from="Example <nobody@example.com>" \
1377 --to=nobody@example.com \
1378 --smtp-server="$(pwd)/fake.sendmail" \
1379 outdir/0002-*.patch \
1380 outdir/0000-*.patch \
1381 outdir/0001-*.patch \
1382 2>errors >out &&
1383 ! grep "SUBJECT HERE" errors &&
1384 test -n "$(ls msgtxt*)"
1385'
1386
1387test_expect_success $PREREQ 'sendemail.aliasfiletype=mailrc' '
1388 clean_fake_sendmail &&
1389 echo "alias sbd somebody@example.org" >.mailrc &&
1390 git config --replace-all sendemail.aliasesfile "$(pwd)/.mailrc" &&
1391 git config sendemail.aliasfiletype mailrc &&
1392 git send-email \
1393 --from="Example <nobody@example.com>" \
1394 --to=sbd \
1395 --smtp-server="$(pwd)/fake.sendmail" \
1396 outdir/0001-*.patch \
1397 2>errors >out &&
1398 grep "^!somebody@example\.org!$" commandline1
1399'
1400
1401test_expect_success $PREREQ 'sendemail.aliasfile=~/.mailrc' '
1402 clean_fake_sendmail &&
1403 echo "alias sbd someone@example.org" >~/.mailrc &&
1404 git config --replace-all sendemail.aliasesfile "~/.mailrc" &&
1405 git config sendemail.aliasfiletype mailrc &&
1406 git send-email \
1407 --from="Example <nobody@example.com>" \
1408 --to=sbd \
1409 --smtp-server="$(pwd)/fake.sendmail" \
1410 outdir/0001-*.patch \
1411 2>errors >out &&
1412 grep "^!someone@example\.org!$" commandline1
1413'
1414
1415test_done