Merge branch 'cc/fix-missing-va-end-in-revert' into maint
[git/mjg.git] / t / t9001-send-email.sh
blob8c12c65c72658acb37fa715fc93756381bc824bb
1 #!/bin/sh
3 test_description='git send-email'
4 . ./test-lib.sh
6 # May be altered later in the test
7 PREREQ="PERL"
9 test_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."'
16 test_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."'
33 clean_fake_sendmail() {
34 rm -f commandline* msgtxt*
37 test_expect_success $PREREQ 'Extract patches' '
38 patches=`git format-patch -s --cc="One <one@example.com>" --cc=two@example.com -n HEAD^1`
41 # Test no confirm early to ensure remaining tests will not hang
42 test_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
56 # Exit immediately to prevent hang if a no-confirm test fails
57 check_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"
63 return 0
66 test_expect_success $PREREQ 'No confirm with --suppress-cc' '
67 test_no_confirm --suppress-cc=sob &&
68 check_no_confirm
72 test_expect_success $PREREQ 'No confirm with --confirm=never' '
73 test_no_confirm --confirm=never &&
74 check_no_confirm
77 # leave sendemail.confirm set to never after this so that none of the
78 # remaining tests prompt unintentionally.
79 test_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
85 test_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
89 test_expect_success $PREREQ 'setup expect' '
90 cat >expected <<\EOF
91 !nobody@example.com!
92 !author@example.com!
93 !one@example.com!
94 !two@example.com!
95 EOF
98 test_expect_success $PREREQ \
99 'Verify commandline' \
100 'test_cmp expected commandline1'
102 test_expect_success $PREREQ 'Send patches with --envelope-sender' '
103 clean_fake_sendmail &&
104 git send-email --envelope-sender="Patch Contributer <patch@example.com>" --suppress-cc=sob --from="Example <nobody@example.com>" --to=nobody@example.com --smtp-server="$(pwd)/fake.sendmail" $patches 2>errors
107 test_expect_success $PREREQ 'setup expect' '
108 cat >expected <<\EOF
109 !patch@example.com!
110 !-i!
111 !nobody@example.com!
112 !author@example.com!
113 !one@example.com!
114 !two@example.com!
118 test_expect_success $PREREQ \
119 'Verify commandline' \
120 'test_cmp expected commandline1'
122 test_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
127 test_expect_success $PREREQ 'setup expect' '
128 cat >expected <<\EOF
129 !nobody@example.com!
130 !-i!
131 !nobody@example.com!
132 !author@example.com!
133 !one@example.com!
134 !two@example.com!
138 test_expect_success $PREREQ \
139 'Verify commandline' \
140 'test_cmp expected commandline1'
142 test_expect_success $PREREQ 'setup expect' "
143 cat >expected-show-all-headers <<\EOF
144 0001-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'
148 Dry-OK. Log says:
149 Server: relay.example.com
150 MAIL FROM:<from@example.com>
151 RCPT TO:<to@example.com>
152 RCPT TO:<cc@example.com>
153 RCPT TO:<author@example.com>
154 RCPT TO:<one@example.com>
155 RCPT TO:<two@example.com>
156 RCPT TO:<bcc@example.com>
157 From: Example <from@example.com>
158 To: to@example.com
159 Cc: cc@example.com,
160 A <author@example.com>,
161 One <one@example.com>,
162 two@example.com
163 Subject: [PATCH 1/1] Second.
164 Date: DATE-STRING
165 Message-Id: MESSAGE-ID-STRING
166 X-Mailer: X-MAILER-STRING
167 In-Reply-To: <unique-message-id@example.com>
168 References: <unique-message-id@example.com>
170 Result: OK
174 test_expect_success $PREREQ 'Show all headers' '
175 git send-email \
176 --dry-run \
177 --suppress-cc=sob \
178 --from="Example <from@example.com>" \
179 --to=to@example.com \
180 --cc=cc@example.com \
181 --bcc=bcc@example.com \
182 --in-reply-to="<unique-message-id@example.com>" \
183 --smtp-server relay.example.com \
184 $patches |
185 sed -e "s/^\(Date:\).*/\1 DATE-STRING/" \
186 -e "s/^\(Message-Id:\).*/\1 MESSAGE-ID-STRING/" \
187 -e "s/^\(X-Mailer:\).*/\1 X-MAILER-STRING/" \
188 >actual-show-all-headers &&
189 test_cmp expected-show-all-headers actual-show-all-headers
192 test_expect_success $PREREQ 'Prompting works' '
193 clean_fake_sendmail &&
194 (echo "Example <from@example.com>"
195 echo "to@example.com"
196 echo ""
197 ) | GIT_SEND_EMAIL_NOTTY=1 git send-email \
198 --smtp-server="$(pwd)/fake.sendmail" \
199 $patches \
200 2>errors &&
201 grep "^From: Example <from@example.com>\$" msgtxt1 &&
202 grep "^To: to@example.com\$" msgtxt1
205 test_expect_success $PREREQ 'tocmd works' '
206 clean_fake_sendmail &&
207 cp $patches tocmd.patch &&
208 echo tocmd--tocmd@example.com >>tocmd.patch &&
210 echo "#!$SHELL_PATH"
211 echo sed -n -e s/^tocmd--//p \"\$1\"
212 } > tocmd-sed &&
213 chmod +x tocmd-sed &&
214 git send-email \
215 --from="Example <nobody@example.com>" \
216 --to-cmd=./tocmd-sed \
217 --smtp-server="$(pwd)/fake.sendmail" \
218 tocmd.patch \
220 grep "^To: tocmd@example.com" msgtxt1
223 test_expect_success $PREREQ 'cccmd works' '
224 clean_fake_sendmail &&
225 cp $patches cccmd.patch &&
226 echo "cccmd-- cccmd@example.com" >>cccmd.patch &&
228 echo "#!$SHELL_PATH"
229 echo sed -n -e s/^cccmd--//p \"\$1\"
230 } > cccmd-sed &&
231 chmod +x cccmd-sed &&
232 git send-email \
233 --from="Example <nobody@example.com>" \
234 --to=nobody@example.com \
235 --cc-cmd=./cccmd-sed \
236 --smtp-server="$(pwd)/fake.sendmail" \
237 cccmd.patch \
239 grep "^ cccmd@example.com" msgtxt1
242 test_expect_success $PREREQ 'reject long lines' '
243 z8=zzzzzzzz &&
244 z64=$z8$z8$z8$z8$z8$z8$z8$z8 &&
245 z512=$z64$z64$z64$z64$z64$z64$z64$z64 &&
246 clean_fake_sendmail &&
247 cp $patches longline.patch &&
248 echo $z512$z512 >>longline.patch &&
249 test_must_fail git send-email \
250 --from="Example <nobody@example.com>" \
251 --to=nobody@example.com \
252 --smtp-server="$(pwd)/fake.sendmail" \
253 $patches longline.patch \
254 2>errors &&
255 grep longline.patch errors
258 test_expect_success $PREREQ 'no patch was sent' '
259 ! test -e commandline1
262 test_expect_success $PREREQ 'Author From: in message body' '
263 clean_fake_sendmail &&
264 git send-email \
265 --from="Example <nobody@example.com>" \
266 --to=nobody@example.com \
267 --smtp-server="$(pwd)/fake.sendmail" \
268 $patches &&
269 sed "1,/^\$/d" < msgtxt1 > msgbody1 &&
270 grep "From: A <author@example.com>" msgbody1
273 test_expect_success $PREREQ 'Author From: not in message body' '
274 clean_fake_sendmail &&
275 git send-email \
276 --from="A <author@example.com>" \
277 --to=nobody@example.com \
278 --smtp-server="$(pwd)/fake.sendmail" \
279 $patches &&
280 sed "1,/^\$/d" < msgtxt1 > msgbody1 &&
281 ! grep "From: A <author@example.com>" msgbody1
284 test_expect_success $PREREQ 'allow long lines with --no-validate' '
285 git send-email \
286 --from="Example <nobody@example.com>" \
287 --to=nobody@example.com \
288 --smtp-server="$(pwd)/fake.sendmail" \
289 --novalidate \
290 $patches longline.patch \
291 2>errors
294 test_expect_success $PREREQ 'Invalid In-Reply-To' '
295 clean_fake_sendmail &&
296 git send-email \
297 --from="Example <nobody@example.com>" \
298 --to=nobody@example.com \
299 --in-reply-to=" " \
300 --smtp-server="$(pwd)/fake.sendmail" \
301 $patches \
302 2>errors &&
303 ! grep "^In-Reply-To: < *>" msgtxt1
306 test_expect_success $PREREQ 'Valid In-Reply-To when prompting' '
307 clean_fake_sendmail &&
308 (echo "From Example <from@example.com>"
309 echo "To Example <to@example.com>"
310 echo ""
311 ) | env GIT_SEND_EMAIL_NOTTY=1 git send-email \
312 --smtp-server="$(pwd)/fake.sendmail" \
313 $patches 2>errors &&
314 ! grep "^In-Reply-To: < *>" msgtxt1
317 test_expect_success $PREREQ 'In-Reply-To without --chain-reply-to' '
318 clean_fake_sendmail &&
319 echo "<unique-message-id@example.com>" >expect &&
320 git send-email \
321 --from="Example <nobody@example.com>" \
322 --to=nobody@example.com \
323 --nochain-reply-to \
324 --in-reply-to="$(cat expect)" \
325 --smtp-server="$(pwd)/fake.sendmail" \
326 $patches $patches $patches \
327 2>errors &&
328 # The first message is a reply to --in-reply-to
329 sed -n -e "s/^In-Reply-To: *\(.*\)/\1/p" msgtxt1 >actual &&
330 test_cmp expect actual &&
331 # Second and subsequent messages are replies to the first one
332 sed -n -e "s/^Message-Id: *\(.*\)/\1/p" msgtxt1 >expect &&
333 sed -n -e "s/^In-Reply-To: *\(.*\)/\1/p" msgtxt2 >actual &&
334 test_cmp expect actual &&
335 sed -n -e "s/^In-Reply-To: *\(.*\)/\1/p" msgtxt3 >actual &&
336 test_cmp expect actual
339 test_expect_success $PREREQ 'In-Reply-To with --chain-reply-to' '
340 clean_fake_sendmail &&
341 echo "<unique-message-id@example.com>" >expect &&
342 git send-email \
343 --from="Example <nobody@example.com>" \
344 --to=nobody@example.com \
345 --chain-reply-to \
346 --in-reply-to="$(cat expect)" \
347 --smtp-server="$(pwd)/fake.sendmail" \
348 $patches $patches $patches \
349 2>errors &&
350 sed -n -e "s/^In-Reply-To: *\(.*\)/\1/p" msgtxt1 >actual &&
351 test_cmp expect actual &&
352 sed -n -e "s/^Message-Id: *\(.*\)/\1/p" msgtxt1 >expect &&
353 sed -n -e "s/^In-Reply-To: *\(.*\)/\1/p" msgtxt2 >actual &&
354 test_cmp expect actual &&
355 sed -n -e "s/^Message-Id: *\(.*\)/\1/p" msgtxt2 >expect &&
356 sed -n -e "s/^In-Reply-To: *\(.*\)/\1/p" msgtxt3 >actual &&
357 test_cmp expect actual
360 test_expect_success $PREREQ 'setup fake editor' '
361 (echo "#!$SHELL_PATH" &&
362 echo "echo fake edit >>\"\$1\""
363 ) >fake-editor &&
364 chmod +x fake-editor
367 test_set_editor "$(pwd)/fake-editor"
369 test_expect_success $PREREQ '--compose works' '
370 clean_fake_sendmail &&
371 git send-email \
372 --compose --subject foo \
373 --from="Example <nobody@example.com>" \
374 --to=nobody@example.com \
375 --smtp-server="$(pwd)/fake.sendmail" \
376 $patches \
377 2>errors
380 test_expect_success $PREREQ 'first message is compose text' '
381 grep "^fake edit" msgtxt1
384 test_expect_success $PREREQ 'second message is patch' '
385 grep "Subject:.*Second" msgtxt2
388 test_expect_success $PREREQ 'setup expect' "
389 cat >expected-suppress-sob <<\EOF
390 0001-Second.patch
391 (mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
392 (mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
393 (mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
394 Dry-OK. Log says:
395 Server: relay.example.com
396 MAIL FROM:<from@example.com>
397 RCPT TO:<to@example.com>
398 RCPT TO:<cc@example.com>
399 RCPT TO:<author@example.com>
400 RCPT TO:<one@example.com>
401 RCPT TO:<two@example.com>
402 From: Example <from@example.com>
403 To: to@example.com
404 Cc: cc@example.com,
405 A <author@example.com>,
406 One <one@example.com>,
407 two@example.com
408 Subject: [PATCH 1/1] Second.
409 Date: DATE-STRING
410 Message-Id: MESSAGE-ID-STRING
411 X-Mailer: X-MAILER-STRING
413 Result: OK
417 test_suppression () {
418 git send-email \
419 --dry-run \
420 --suppress-cc=$1 ${2+"--suppress-cc=$2"} \
421 --from="Example <from@example.com>" \
422 --to=to@example.com \
423 --smtp-server relay.example.com \
424 $patches |
425 sed -e "s/^\(Date:\).*/\1 DATE-STRING/" \
426 -e "s/^\(Message-Id:\).*/\1 MESSAGE-ID-STRING/" \
427 -e "s/^\(X-Mailer:\).*/\1 X-MAILER-STRING/" \
428 >actual-suppress-$1${2+"-$2"} &&
429 test_cmp expected-suppress-$1${2+"-$2"} actual-suppress-$1${2+"-$2"}
432 test_expect_success $PREREQ 'sendemail.cc set' '
433 git config sendemail.cc cc@example.com &&
434 test_suppression sob
437 test_expect_success $PREREQ 'setup expect' "
438 cat >expected-suppress-sob <<\EOF
439 0001-Second.patch
440 (mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
441 (mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
442 (mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
443 Dry-OK. Log says:
444 Server: relay.example.com
445 MAIL FROM:<from@example.com>
446 RCPT TO:<to@example.com>
447 RCPT TO:<author@example.com>
448 RCPT TO:<one@example.com>
449 RCPT TO:<two@example.com>
450 From: Example <from@example.com>
451 To: to@example.com
452 Cc: A <author@example.com>,
453 One <one@example.com>,
454 two@example.com
455 Subject: [PATCH 1/1] Second.
456 Date: DATE-STRING
457 Message-Id: MESSAGE-ID-STRING
458 X-Mailer: X-MAILER-STRING
460 Result: OK
464 test_expect_success $PREREQ 'sendemail.cc unset' '
465 git config --unset sendemail.cc &&
466 test_suppression sob
469 test_expect_success $PREREQ 'setup expect' "
470 cat >expected-suppress-cccmd <<\EOF
471 0001-Second.patch
472 (mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
473 (mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
474 (mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
475 (body) Adding cc: C O Mitter <committer@example.com> from line 'Signed-off-by: C O Mitter <committer@example.com>'
476 Dry-OK. Log says:
477 Server: relay.example.com
478 MAIL FROM:<from@example.com>
479 RCPT TO:<to@example.com>
480 RCPT TO:<author@example.com>
481 RCPT TO:<one@example.com>
482 RCPT TO:<two@example.com>
483 RCPT TO:<committer@example.com>
484 From: Example <from@example.com>
485 To: to@example.com
486 Cc: A <author@example.com>,
487 One <one@example.com>,
488 two@example.com,
489 C O Mitter <committer@example.com>
490 Subject: [PATCH 1/1] Second.
491 Date: DATE-STRING
492 Message-Id: MESSAGE-ID-STRING
493 X-Mailer: X-MAILER-STRING
495 Result: OK
499 test_expect_success $PREREQ 'sendemail.cccmd' '
500 echo echo cc-cmd@example.com > cccmd &&
501 chmod +x cccmd &&
502 git config sendemail.cccmd ./cccmd &&
503 test_suppression cccmd
506 test_expect_success $PREREQ 'setup expect' '
507 cat >expected-suppress-all <<\EOF
508 0001-Second.patch
509 Dry-OK. Log says:
510 Server: relay.example.com
511 MAIL FROM:<from@example.com>
512 RCPT TO:<to@example.com>
513 From: Example <from@example.com>
514 To: to@example.com
515 Subject: [PATCH 1/1] Second.
516 Date: DATE-STRING
517 Message-Id: MESSAGE-ID-STRING
518 X-Mailer: X-MAILER-STRING
520 Result: OK
524 test_expect_success $PREREQ '--suppress-cc=all' '
525 test_suppression all
528 test_expect_success $PREREQ 'setup expect' "
529 cat >expected-suppress-body <<\EOF
530 0001-Second.patch
531 (mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
532 (mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
533 (mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
534 (cc-cmd) Adding cc: cc-cmd@example.com from: './cccmd'
535 Dry-OK. Log says:
536 Server: relay.example.com
537 MAIL FROM:<from@example.com>
538 RCPT TO:<to@example.com>
539 RCPT TO:<author@example.com>
540 RCPT TO:<one@example.com>
541 RCPT TO:<two@example.com>
542 RCPT TO:<cc-cmd@example.com>
543 From: Example <from@example.com>
544 To: to@example.com
545 Cc: A <author@example.com>,
546 One <one@example.com>,
547 two@example.com,
548 cc-cmd@example.com
549 Subject: [PATCH 1/1] Second.
550 Date: DATE-STRING
551 Message-Id: MESSAGE-ID-STRING
552 X-Mailer: X-MAILER-STRING
554 Result: OK
558 test_expect_success $PREREQ '--suppress-cc=body' '
559 test_suppression body
562 test_expect_success $PREREQ 'setup expect' "
563 cat >expected-suppress-body-cccmd <<\EOF
564 0001-Second.patch
565 (mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
566 (mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
567 (mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
568 Dry-OK. Log says:
569 Server: relay.example.com
570 MAIL FROM:<from@example.com>
571 RCPT TO:<to@example.com>
572 RCPT TO:<author@example.com>
573 RCPT TO:<one@example.com>
574 RCPT TO:<two@example.com>
575 From: Example <from@example.com>
576 To: to@example.com
577 Cc: A <author@example.com>,
578 One <one@example.com>,
579 two@example.com
580 Subject: [PATCH 1/1] Second.
581 Date: DATE-STRING
582 Message-Id: MESSAGE-ID-STRING
583 X-Mailer: X-MAILER-STRING
585 Result: OK
589 test_expect_success $PREREQ '--suppress-cc=body --suppress-cc=cccmd' '
590 test_suppression body cccmd
593 test_expect_success $PREREQ 'setup expect' "
594 cat >expected-suppress-sob <<\EOF
595 0001-Second.patch
596 (mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
597 (mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
598 (mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
599 Dry-OK. Log says:
600 Server: relay.example.com
601 MAIL FROM:<from@example.com>
602 RCPT TO:<to@example.com>
603 RCPT TO:<author@example.com>
604 RCPT TO:<one@example.com>
605 RCPT TO:<two@example.com>
606 From: Example <from@example.com>
607 To: to@example.com
608 Cc: A <author@example.com>,
609 One <one@example.com>,
610 two@example.com
611 Subject: [PATCH 1/1] Second.
612 Date: DATE-STRING
613 Message-Id: MESSAGE-ID-STRING
614 X-Mailer: X-MAILER-STRING
616 Result: OK
620 test_expect_success $PREREQ '--suppress-cc=sob' '
621 test_might_fail git config --unset sendemail.cccmd &&
622 test_suppression sob
625 test_expect_success $PREREQ 'setup expect' "
626 cat >expected-suppress-bodycc <<\EOF
627 0001-Second.patch
628 (mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
629 (mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
630 (mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
631 (body) Adding cc: C O Mitter <committer@example.com> from line 'Signed-off-by: C O Mitter <committer@example.com>'
632 Dry-OK. Log says:
633 Server: relay.example.com
634 MAIL FROM:<from@example.com>
635 RCPT TO:<to@example.com>
636 RCPT TO:<author@example.com>
637 RCPT TO:<one@example.com>
638 RCPT TO:<two@example.com>
639 RCPT TO:<committer@example.com>
640 From: Example <from@example.com>
641 To: to@example.com
642 Cc: A <author@example.com>,
643 One <one@example.com>,
644 two@example.com,
645 C O Mitter <committer@example.com>
646 Subject: [PATCH 1/1] Second.
647 Date: DATE-STRING
648 Message-Id: MESSAGE-ID-STRING
649 X-Mailer: X-MAILER-STRING
651 Result: OK
655 test_expect_success $PREREQ '--suppress-cc=bodycc' '
656 test_suppression bodycc
659 test_expect_success $PREREQ 'setup expect' "
660 cat >expected-suppress-cc <<\EOF
661 0001-Second.patch
662 (mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
663 (body) Adding cc: C O Mitter <committer@example.com> from line 'Signed-off-by: C O Mitter <committer@example.com>'
664 Dry-OK. Log says:
665 Server: relay.example.com
666 MAIL FROM:<from@example.com>
667 RCPT TO:<to@example.com>
668 RCPT TO:<author@example.com>
669 RCPT TO:<committer@example.com>
670 From: Example <from@example.com>
671 To: to@example.com
672 Cc: A <author@example.com>,
673 C O Mitter <committer@example.com>
674 Subject: [PATCH 1/1] Second.
675 Date: DATE-STRING
676 Message-Id: MESSAGE-ID-STRING
677 X-Mailer: X-MAILER-STRING
679 Result: OK
683 test_expect_success $PREREQ '--suppress-cc=cc' '
684 test_suppression cc
687 test_confirm () {
688 echo y | \
689 GIT_SEND_EMAIL_NOTTY=1 \
690 git send-email \
691 --from="Example <nobody@example.com>" \
692 --to=nobody@example.com \
693 --smtp-server="$(pwd)/fake.sendmail" \
694 $@ $patches > stdout &&
695 grep "Send this email" stdout
698 test_expect_success $PREREQ '--confirm=always' '
699 test_confirm --confirm=always --suppress-cc=all
702 test_expect_success $PREREQ '--confirm=auto' '
703 test_confirm --confirm=auto
706 test_expect_success $PREREQ '--confirm=cc' '
707 test_confirm --confirm=cc
710 test_expect_success $PREREQ '--confirm=compose' '
711 test_confirm --confirm=compose --compose
714 test_expect_success $PREREQ 'confirm by default (due to cc)' '
715 CONFIRM=$(git config --get sendemail.confirm) &&
716 git config --unset sendemail.confirm &&
717 test_confirm
718 ret="$?"
719 git config sendemail.confirm ${CONFIRM:-never}
720 test $ret = "0"
723 test_expect_success $PREREQ 'confirm by default (due to --compose)' '
724 CONFIRM=$(git config --get sendemail.confirm) &&
725 git config --unset sendemail.confirm &&
726 test_confirm --suppress-cc=all --compose
727 ret="$?"
728 git config sendemail.confirm ${CONFIRM:-never}
729 test $ret = "0"
732 test_expect_success $PREREQ 'confirm detects EOF (inform assumes y)' '
733 CONFIRM=$(git config --get sendemail.confirm) &&
734 git config --unset sendemail.confirm &&
735 rm -fr outdir &&
736 git format-patch -2 -o outdir &&
737 GIT_SEND_EMAIL_NOTTY=1 \
738 git send-email \
739 --from="Example <nobody@example.com>" \
740 --to=nobody@example.com \
741 --smtp-server="$(pwd)/fake.sendmail" \
742 outdir/*.patch < /dev/null
743 ret="$?"
744 git config sendemail.confirm ${CONFIRM:-never}
745 test $ret = "0"
748 test_expect_success $PREREQ 'confirm detects EOF (auto causes failure)' '
749 CONFIRM=$(git config --get sendemail.confirm) &&
750 git config sendemail.confirm auto &&
751 GIT_SEND_EMAIL_NOTTY=1 &&
752 export GIT_SEND_EMAIL_NOTTY &&
753 test_must_fail git send-email \
754 --from="Example <nobody@example.com>" \
755 --to=nobody@example.com \
756 --smtp-server="$(pwd)/fake.sendmail" \
757 $patches < /dev/null
758 ret="$?"
759 git config sendemail.confirm ${CONFIRM:-never}
760 test $ret = "0"
763 test_expect_success $PREREQ 'confirm doesnt loop forever' '
764 CONFIRM=$(git config --get sendemail.confirm) &&
765 git config sendemail.confirm auto &&
766 GIT_SEND_EMAIL_NOTTY=1 &&
767 export GIT_SEND_EMAIL_NOTTY &&
768 yes "bogus" | test_must_fail git send-email \
769 --from="Example <nobody@example.com>" \
770 --to=nobody@example.com \
771 --smtp-server="$(pwd)/fake.sendmail" \
772 $patches
773 ret="$?"
774 git config sendemail.confirm ${CONFIRM:-never}
775 test $ret = "0"
778 test_expect_success $PREREQ 'utf8 Cc is rfc2047 encoded' '
779 clean_fake_sendmail &&
780 rm -fr outdir &&
781 git format-patch -1 -o outdir --cc="àéìöú <utf8@example.com>" &&
782 git send-email \
783 --from="Example <nobody@example.com>" \
784 --to=nobody@example.com \
785 --smtp-server="$(pwd)/fake.sendmail" \
786 outdir/*.patch &&
787 grep "^ " msgtxt1 |
788 grep "=?UTF-8?q?=C3=A0=C3=A9=C3=AC=C3=B6=C3=BA?= <utf8@example.com>"
791 test_expect_success $PREREQ '--compose adds MIME for utf8 body' '
792 clean_fake_sendmail &&
793 (echo "#!$SHELL_PATH" &&
794 echo "echo utf8 body: àéìöú >>\"\$1\""
795 ) >fake-editor-utf8 &&
796 chmod +x fake-editor-utf8 &&
797 GIT_EDITOR="\"$(pwd)/fake-editor-utf8\"" \
798 git send-email \
799 --compose --subject foo \
800 --from="Example <nobody@example.com>" \
801 --to=nobody@example.com \
802 --smtp-server="$(pwd)/fake.sendmail" \
803 $patches &&
804 grep "^utf8 body" msgtxt1 &&
805 grep "^Content-Type: text/plain; charset=UTF-8" msgtxt1
808 test_expect_success $PREREQ '--compose respects user mime type' '
809 clean_fake_sendmail &&
810 (echo "#!$SHELL_PATH" &&
811 echo "(echo MIME-Version: 1.0"
812 echo " echo Content-Type: text/plain\\; charset=iso-8859-1"
813 echo " echo Content-Transfer-Encoding: 8bit"
814 echo " echo Subject: foo"
815 echo " echo "
816 echo " echo utf8 body: àéìöú) >\"\$1\""
817 ) >fake-editor-utf8-mime &&
818 chmod +x fake-editor-utf8-mime &&
819 GIT_EDITOR="\"$(pwd)/fake-editor-utf8-mime\"" \
820 git send-email \
821 --compose --subject foo \
822 --from="Example <nobody@example.com>" \
823 --to=nobody@example.com \
824 --smtp-server="$(pwd)/fake.sendmail" \
825 $patches &&
826 grep "^utf8 body" msgtxt1 &&
827 grep "^Content-Type: text/plain; charset=iso-8859-1" msgtxt1 &&
828 ! grep "^Content-Type: text/plain; charset=UTF-8" msgtxt1
831 test_expect_success $PREREQ '--compose adds MIME for utf8 subject' '
832 clean_fake_sendmail &&
833 GIT_EDITOR="\"$(pwd)/fake-editor\"" \
834 git send-email \
835 --compose --subject utf8-sübjëct \
836 --from="Example <nobody@example.com>" \
837 --to=nobody@example.com \
838 --smtp-server="$(pwd)/fake.sendmail" \
839 $patches &&
840 grep "^fake edit" msgtxt1 &&
841 grep "^Subject: =?UTF-8?q?utf8-s=C3=BCbj=C3=ABct?=" msgtxt1
844 test_expect_success $PREREQ 'detects ambiguous reference/file conflict' '
845 echo master > master &&
846 git add master &&
847 git commit -m"add master" &&
848 test_must_fail git send-email --dry-run master 2>errors &&
849 grep disambiguate errors
852 test_expect_success $PREREQ 'feed two files' '
853 rm -fr outdir &&
854 git format-patch -2 -o outdir &&
855 git send-email \
856 --dry-run \
857 --from="Example <nobody@example.com>" \
858 --to=nobody@example.com \
859 outdir/000?-*.patch 2>errors >out &&
860 grep "^Subject: " out >subjects &&
861 test "z$(sed -n -e 1p subjects)" = "zSubject: [PATCH 1/2] Second." &&
862 test "z$(sed -n -e 2p subjects)" = "zSubject: [PATCH 2/2] add master"
865 test_expect_success $PREREQ 'in-reply-to but no threading' '
866 git send-email \
867 --dry-run \
868 --from="Example <nobody@example.com>" \
869 --to=nobody@example.com \
870 --in-reply-to="<in-reply-id@example.com>" \
871 --nothread \
872 $patches |
873 grep "In-Reply-To: <in-reply-id@example.com>"
876 test_expect_success $PREREQ 'no in-reply-to and no threading' '
877 git send-email \
878 --dry-run \
879 --from="Example <nobody@example.com>" \
880 --to=nobody@example.com \
881 --nothread \
882 $patches $patches >stdout &&
883 ! grep "In-Reply-To: " stdout
886 test_expect_success $PREREQ 'threading but no chain-reply-to' '
887 git send-email \
888 --dry-run \
889 --from="Example <nobody@example.com>" \
890 --to=nobody@example.com \
891 --thread \
892 --nochain-reply-to \
893 $patches $patches >stdout &&
894 grep "In-Reply-To: " stdout
897 test_expect_success $PREREQ 'warning with an implicit --chain-reply-to' '
898 git send-email \
899 --dry-run \
900 --from="Example <nobody@example.com>" \
901 --to=nobody@example.com \
902 outdir/000?-*.patch 2>errors >out &&
903 grep "no-chain-reply-to" errors
906 test_expect_success $PREREQ 'no warning with an explicit --chain-reply-to' '
907 git send-email \
908 --dry-run \
909 --from="Example <nobody@example.com>" \
910 --to=nobody@example.com \
911 --chain-reply-to \
912 outdir/000?-*.patch 2>errors >out &&
913 ! grep "no-chain-reply-to" errors
916 test_expect_success $PREREQ 'no warning with an explicit --no-chain-reply-to' '
917 git send-email \
918 --dry-run \
919 --from="Example <nobody@example.com>" \
920 --to=nobody@example.com \
921 --nochain-reply-to \
922 outdir/000?-*.patch 2>errors >out &&
923 ! grep "no-chain-reply-to" errors
926 test_expect_success $PREREQ 'no warning with sendemail.chainreplyto = false' '
927 git config sendemail.chainreplyto false &&
928 git send-email \
929 --dry-run \
930 --from="Example <nobody@example.com>" \
931 --to=nobody@example.com \
932 outdir/000?-*.patch 2>errors >out &&
933 ! grep "no-chain-reply-to" errors
936 test_expect_success $PREREQ 'no warning with sendemail.chainreplyto = true' '
937 git config sendemail.chainreplyto true &&
938 git send-email \
939 --dry-run \
940 --from="Example <nobody@example.com>" \
941 --to=nobody@example.com \
942 outdir/000?-*.patch 2>errors >out &&
943 ! grep "no-chain-reply-to" errors
946 test_expect_success $PREREQ 'sendemail.to works' '
947 git config --replace-all sendemail.to "Somebody <somebody@ex.com>" &&
948 git send-email \
949 --dry-run \
950 --from="Example <nobody@example.com>" \
951 $patches $patches >stdout &&
952 grep "To: Somebody <somebody@ex.com>" stdout
955 test_expect_success $PREREQ '--no-to overrides sendemail.to' '
956 git send-email \
957 --dry-run \
958 --from="Example <nobody@example.com>" \
959 --no-to \
960 --to=nobody@example.com \
961 $patches $patches >stdout &&
962 grep "To: nobody@example.com" stdout &&
963 ! grep "To: Somebody <somebody@ex.com>" stdout
966 test_expect_success $PREREQ 'sendemail.cc works' '
967 git config --replace-all sendemail.cc "Somebody <somebody@ex.com>" &&
968 git send-email \
969 --dry-run \
970 --from="Example <nobody@example.com>" \
971 --to=nobody@example.com \
972 $patches $patches >stdout &&
973 grep "Cc: Somebody <somebody@ex.com>" stdout
976 test_expect_success $PREREQ '--no-cc overrides sendemail.cc' '
977 git send-email \
978 --dry-run \
979 --from="Example <nobody@example.com>" \
980 --no-cc \
981 --cc=bodies@example.com \
982 --to=nobody@example.com \
983 $patches $patches >stdout &&
984 grep "Cc: bodies@example.com" stdout &&
985 ! grep "Cc: Somebody <somebody@ex.com>" stdout
988 test_expect_success $PREREQ 'sendemail.bcc works' '
989 git config --replace-all sendemail.bcc "Other <other@ex.com>" &&
990 git send-email \
991 --dry-run \
992 --from="Example <nobody@example.com>" \
993 --to=nobody@example.com \
994 --smtp-server relay.example.com \
995 $patches $patches >stdout &&
996 grep "RCPT TO:<other@ex.com>" stdout
999 test_expect_success $PREREQ '--no-bcc overrides sendemail.bcc' '
1000 git send-email \
1001 --dry-run \
1002 --from="Example <nobody@example.com>" \
1003 --no-bcc \
1004 --bcc=bodies@example.com \
1005 --to=nobody@example.com \
1006 --smtp-server relay.example.com \
1007 $patches $patches >stdout &&
1008 grep "RCPT TO:<bodies@example.com>" stdout &&
1009 ! grep "RCPT TO:<other@ex.com>" stdout
1012 test_expect_success $PREREQ 'patches To headers are used by default' '
1013 patch=`git format-patch -1 --to="bodies@example.com"` &&
1014 test_when_finished "rm $patch" &&
1015 git send-email \
1016 --dry-run \
1017 --from="Example <nobody@example.com>" \
1018 --smtp-server relay.example.com \
1019 $patch >stdout &&
1020 grep "RCPT TO:<bodies@example.com>" stdout
1023 test_expect_success $PREREQ 'patches To headers are appended to' '
1024 patch=`git format-patch -1 --to="bodies@example.com"` &&
1025 test_when_finished "rm $patch" &&
1026 git send-email \
1027 --dry-run \
1028 --from="Example <nobody@example.com>" \
1029 --to=nobody@example.com \
1030 --smtp-server relay.example.com \
1031 $patch >stdout &&
1032 grep "RCPT TO:<bodies@example.com>" stdout &&
1033 grep "RCPT TO:<nobody@example.com>" stdout
1036 test_expect_success $PREREQ 'To headers from files reset each patch' '
1037 patch1=`git format-patch -1 --to="bodies@example.com"` &&
1038 patch2=`git format-patch -1 --to="other@example.com" HEAD~` &&
1039 test_when_finished "rm $patch1 && rm $patch2" &&
1040 git send-email \
1041 --dry-run \
1042 --from="Example <nobody@example.com>" \
1043 --to="nobody@example.com" \
1044 --smtp-server relay.example.com \
1045 $patch1 $patch2 >stdout &&
1046 test $(grep -c "RCPT TO:<bodies@example.com>" stdout) = 1 &&
1047 test $(grep -c "RCPT TO:<nobody@example.com>" stdout) = 2 &&
1048 test $(grep -c "RCPT TO:<other@example.com>" stdout) = 1
1051 test_expect_success $PREREQ 'setup expect' '
1052 cat >email-using-8bit <<EOF
1053 From fe6ecc66ece37198fe5db91fa2fc41d9f4fe5cc4 Mon Sep 17 00:00:00 2001
1054 Message-Id: <bogus-message-id@example.com>
1055 From: author@example.com
1056 Date: Sat, 12 Jun 2010 15:53:58 +0200
1057 Subject: subject goes here
1059 Dieser deutsche Text enthält einen Umlaut!
1063 test_expect_success $PREREQ 'setup expect' '
1064 cat >content-type-decl <<EOF
1065 MIME-Version: 1.0
1066 Content-Type: text/plain; charset=UTF-8
1067 Content-Transfer-Encoding: 8bit
1071 test_expect_success $PREREQ 'asks about and fixes 8bit encodings' '
1072 clean_fake_sendmail &&
1073 echo |
1074 git send-email --from=author@example.com --to=nobody@example.com \
1075 --smtp-server="$(pwd)/fake.sendmail" \
1076 email-using-8bit >stdout &&
1077 grep "do not declare a Content-Transfer-Encoding" stdout &&
1078 grep email-using-8bit stdout &&
1079 grep "Which 8bit encoding" stdout &&
1080 egrep "Content|MIME" msgtxt1 >actual &&
1081 test_cmp actual content-type-decl
1084 test_expect_success $PREREQ 'sendemail.8bitEncoding works' '
1085 clean_fake_sendmail &&
1086 git config sendemail.assume8bitEncoding UTF-8 &&
1087 echo bogus |
1088 git send-email --from=author@example.com --to=nobody@example.com \
1089 --smtp-server="$(pwd)/fake.sendmail" \
1090 email-using-8bit >stdout &&
1091 egrep "Content|MIME" msgtxt1 >actual &&
1092 test_cmp actual content-type-decl
1095 test_expect_success $PREREQ '--8bit-encoding overrides sendemail.8bitEncoding' '
1096 clean_fake_sendmail &&
1097 git config sendemail.assume8bitEncoding "bogus too" &&
1098 echo bogus |
1099 git send-email --from=author@example.com --to=nobody@example.com \
1100 --smtp-server="$(pwd)/fake.sendmail" \
1101 --8bit-encoding=UTF-8 \
1102 email-using-8bit >stdout &&
1103 egrep "Content|MIME" msgtxt1 >actual &&
1104 test_cmp actual content-type-decl
1107 test_expect_success $PREREQ 'setup expect' '
1108 cat >email-using-8bit <<EOF
1109 From fe6ecc66ece37198fe5db91fa2fc41d9f4fe5cc4 Mon Sep 17 00:00:00 2001
1110 Message-Id: <bogus-message-id@example.com>
1111 From: author@example.com
1112 Date: Sat, 12 Jun 2010 15:53:58 +0200
1113 Subject: Dieser Betreff enthält auch einen Umlaut!
1115 Nothing to see here.
1119 test_expect_success $PREREQ 'setup expect' '
1120 cat >expected <<EOF
1121 Subject: =?UTF-8?q?Dieser=20Betreff=20enth=C3=A4lt=20auch=20einen=20Umlaut!?=
1125 test_expect_success $PREREQ '--8bit-encoding also treats subject' '
1126 clean_fake_sendmail &&
1127 echo bogus |
1128 git send-email --from=author@example.com --to=nobody@example.com \
1129 --smtp-server="$(pwd)/fake.sendmail" \
1130 --8bit-encoding=UTF-8 \
1131 email-using-8bit >stdout &&
1132 grep "Subject" msgtxt1 >actual &&
1133 test_cmp expected actual
1136 # Note that the patches in this test are deliberately out of order; we
1137 # want to make sure it works even if the cover-letter is not in the
1138 # first mail.
1139 test_expect_success $PREREQ 'refusing to send cover letter template' '
1140 clean_fake_sendmail &&
1141 rm -fr outdir &&
1142 git format-patch --cover-letter -2 -o outdir &&
1143 test_must_fail git send-email \
1144 --from="Example <nobody@example.com>" \
1145 --to=nobody@example.com \
1146 --smtp-server="$(pwd)/fake.sendmail" \
1147 outdir/0002-*.patch \
1148 outdir/0000-*.patch \
1149 outdir/0001-*.patch \
1150 2>errors >out &&
1151 grep "SUBJECT HERE" errors &&
1152 test -z "$(ls msgtxt*)"
1155 test_expect_success $PREREQ '--force sends cover letter template anyway' '
1156 clean_fake_sendmail &&
1157 rm -fr outdir &&
1158 git format-patch --cover-letter -2 -o outdir &&
1159 git send-email \
1160 --force \
1161 --from="Example <nobody@example.com>" \
1162 --to=nobody@example.com \
1163 --smtp-server="$(pwd)/fake.sendmail" \
1164 outdir/0002-*.patch \
1165 outdir/0000-*.patch \
1166 outdir/0001-*.patch \
1167 2>errors >out &&
1168 ! grep "SUBJECT HERE" errors &&
1169 test -n "$(ls msgtxt*)"
1172 test_expect_success $PREREQ 'sendemail.aliasfiletype=mailrc' '
1173 clean_fake_sendmail &&
1174 echo "alias sbd somebody@example.org" >.mailrc &&
1175 git config --replace-all sendemail.aliasesfile "$(pwd)/.mailrc" &&
1176 git config sendemail.aliasfiletype mailrc &&
1177 git send-email \
1178 --from="Example <nobody@example.com>" \
1179 --to=sbd \
1180 --smtp-server="$(pwd)/fake.sendmail" \
1181 outdir/0001-*.patch \
1182 2>errors >out &&
1183 grep "^!somebody@example\.org!$" commandline1
1186 test_expect_success $PREREQ 'sendemail.aliasfile=~/.mailrc' '
1187 clean_fake_sendmail &&
1188 echo "alias sbd someone@example.org" >~/.mailrc &&
1189 git config --replace-all sendemail.aliasesfile "~/.mailrc" &&
1190 git config sendemail.aliasfiletype mailrc &&
1191 git send-email \
1192 --from="Example <nobody@example.com>" \
1193 --to=sbd \
1194 --smtp-server="$(pwd)/fake.sendmail" \
1195 outdir/0001-*.patch \
1196 2>errors >out &&
1197 grep "^!someone@example\.org!$" commandline1
1200 test_done