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 echo "cat > msgtxt\$output"
27 ) >fake.sendmail &&
28 chmod +x ./fake.sendmail &&
29 git add fake.sendmail &&
30 GIT_AUTHOR_NAME="A" git commit -a -m "Second."'
31
32clean_fake_sendmail() {
33 rm -f commandline* msgtxt*
34}
35
36test_expect_success $PREREQ 'Extract patches' '
37 patches=`git format-patch -s --cc="One <one@example.com>" --cc=two@example.com -n HEAD^1`
38'
39
40# Test no confirm early to ensure remaining tests will not hang
41test_no_confirm () {
42 rm -f no_confirm_okay
43 echo n | \
44 GIT_SEND_EMAIL_NOTTY=1 \
45 git send-email \
46 --from="Example <from@example.com>" \
47 --to=nobody@example.com \
48 --smtp-server="$(pwd)/fake.sendmail" \
49 $@ \
50 $patches > stdout &&
51 test_must_fail grep "Send this email" stdout &&
52 > no_confirm_okay
53}
54
55# Exit immediately to prevent hang if a no-confirm test fails
56check_no_confirm () {
57 if ! test -f no_confirm_okay
58 then
59 say 'confirm test failed; skipping remaining tests to prevent hanging'
60 PREREQ="$PREREQ,CHECK_NO_CONFIRM"
61 fi
62 return 0
63}
64
65test_expect_success $PREREQ 'No confirm with --suppress-cc' '
66 test_no_confirm --suppress-cc=sob &&
67 check_no_confirm
68'
69
70
71test_expect_success $PREREQ 'No confirm with --confirm=never' '
72 test_no_confirm --confirm=never &&
73 check_no_confirm
74'
75
76# leave sendemail.confirm set to never after this so that none of the
77# remaining tests prompt unintentionally.
78test_expect_success $PREREQ 'No confirm with sendemail.confirm=never' '
79 git config sendemail.confirm never &&
80 test_no_confirm --compose --subject=foo &&
81 check_no_confirm
82'
83
84test_expect_success $PREREQ 'Send patches' '
85 git send-email --suppress-cc=sob --from="Example <nobody@example.com>" --to=nobody@example.com --smtp-server="$(pwd)/fake.sendmail" $patches 2>errors
86'
87
88test_expect_success $PREREQ 'setup expect' '
89cat >expected <<\EOF
90!nobody@example.com!
91!author@example.com!
92!one@example.com!
93!two@example.com!
94EOF
95'
96
97test_expect_success $PREREQ \
98 'Verify commandline' \
99 'test_cmp expected commandline1'
100
101test_expect_success $PREREQ 'Send patches with --envelope-sender' '
102 clean_fake_sendmail &&
103 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
104'
105
106test_expect_success $PREREQ 'setup expect' '
107cat >expected <<\EOF
108!patch@example.com!
109!-i!
110!nobody@example.com!
111!author@example.com!
112!one@example.com!
113!two@example.com!
114EOF
115'
116
117test_expect_success $PREREQ \
118 'Verify commandline' \
119 'test_cmp expected commandline1'
120
121test_expect_success $PREREQ 'Send patches with --envelope-sender=auto' '
122 clean_fake_sendmail &&
123 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
124'
125
126test_expect_success $PREREQ 'setup expect' '
127cat >expected <<\EOF
128!nobody@example.com!
129!-i!
130!nobody@example.com!
131!author@example.com!
132!one@example.com!
133!two@example.com!
134EOF
135'
136
137test_expect_success $PREREQ \
138 'Verify commandline' \
139 'test_cmp expected commandline1'
140
141test_expect_success $PREREQ 'setup expect' "
142cat >expected-show-all-headers <<\EOF
1430001-Second.patch
144(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
145(mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
146(mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
147Dry-OK. Log says:
148Server: relay.example.com
149MAIL FROM:<from@example.com>
150RCPT TO:<to@example.com>
151RCPT TO:<cc@example.com>
152RCPT TO:<author@example.com>
153RCPT TO:<one@example.com>
154RCPT TO:<two@example.com>
155RCPT TO:<bcc@example.com>
156From: Example <from@example.com>
157To: to@example.com
158Cc: cc@example.com,
159 A <author@example.com>,
160 One <one@example.com>,
161 two@example.com
162Subject: [PATCH 1/1] Second.
163Date: DATE-STRING
164Message-Id: MESSAGE-ID-STRING
165X-Mailer: X-MAILER-STRING
166In-Reply-To: <unique-message-id@example.com>
167References: <unique-message-id@example.com>
168
169Result: OK
170EOF
171"
172
173test_expect_success $PREREQ 'Show all headers' '
174 git send-email \
175 --dry-run \
176 --suppress-cc=sob \
177 --from="Example <from@example.com>" \
178 --to=to@example.com \
179 --cc=cc@example.com \
180 --bcc=bcc@example.com \
181 --in-reply-to="<unique-message-id@example.com>" \
182 --smtp-server relay.example.com \
183 $patches |
184 sed -e "s/^\(Date:\).*/\1 DATE-STRING/" \
185 -e "s/^\(Message-Id:\).*/\1 MESSAGE-ID-STRING/" \
186 -e "s/^\(X-Mailer:\).*/\1 X-MAILER-STRING/" \
187 >actual-show-all-headers &&
188 test_cmp expected-show-all-headers actual-show-all-headers
189'
190
191test_expect_success $PREREQ 'Prompting works' '
192 clean_fake_sendmail &&
193 (echo "Example <from@example.com>"
194 echo "to@example.com"
195 echo ""
196 ) | GIT_SEND_EMAIL_NOTTY=1 git send-email \
197 --smtp-server="$(pwd)/fake.sendmail" \
198 $patches \
199 2>errors &&
200 grep "^From: Example <from@example.com>\$" msgtxt1 &&
201 grep "^To: to@example.com\$" msgtxt1
202'
203
204test_expect_success $PREREQ 'cccmd works' '
205 clean_fake_sendmail &&
206 cp $patches cccmd.patch &&
207 echo cccmd--cccmd@example.com >>cccmd.patch &&
208 {
209 echo "#!$SHELL_PATH"
210 echo sed -n -e s/^cccmd--//p \"\$1\"
211 } > cccmd-sed &&
212 chmod +x cccmd-sed &&
213 git send-email \
214 --from="Example <nobody@example.com>" \
215 --to=nobody@example.com \
216 --cc-cmd=./cccmd-sed \
217 --smtp-server="$(pwd)/fake.sendmail" \
218 cccmd.patch \
219 &&
220 grep "^ cccmd@example.com" msgtxt1
221'
222
223test_expect_success $PREREQ 'reject long lines' '
224 z8=zzzzzzzz &&
225 z64=$z8$z8$z8$z8$z8$z8$z8$z8 &&
226 z512=$z64$z64$z64$z64$z64$z64$z64$z64 &&
227 clean_fake_sendmail &&
228 cp $patches longline.patch &&
229 echo $z512$z512 >>longline.patch &&
230 test_must_fail git send-email \
231 --from="Example <nobody@example.com>" \
232 --to=nobody@example.com \
233 --smtp-server="$(pwd)/fake.sendmail" \
234 $patches longline.patch \
235 2>errors &&
236 grep longline.patch errors
237'
238
239test_expect_success $PREREQ 'no patch was sent' '
240 ! test -e commandline1
241'
242
243test_expect_success $PREREQ 'Author From: in message body' '
244 clean_fake_sendmail &&
245 git send-email \
246 --from="Example <nobody@example.com>" \
247 --to=nobody@example.com \
248 --smtp-server="$(pwd)/fake.sendmail" \
249 $patches &&
250 sed "1,/^\$/d" < msgtxt1 > msgbody1
251 grep "From: A <author@example.com>" msgbody1
252'
253
254test_expect_success $PREREQ 'Author From: not in message body' '
255 clean_fake_sendmail &&
256 git send-email \
257 --from="A <author@example.com>" \
258 --to=nobody@example.com \
259 --smtp-server="$(pwd)/fake.sendmail" \
260 $patches &&
261 sed "1,/^\$/d" < msgtxt1 > msgbody1
262 ! grep "From: A <author@example.com>" msgbody1
263'
264
265test_expect_success $PREREQ 'allow long lines with --no-validate' '
266 git send-email \
267 --from="Example <nobody@example.com>" \
268 --to=nobody@example.com \
269 --smtp-server="$(pwd)/fake.sendmail" \
270 --novalidate \
271 $patches longline.patch \
272 2>errors
273'
274
275test_expect_success $PREREQ 'Invalid In-Reply-To' '
276 clean_fake_sendmail &&
277 git send-email \
278 --from="Example <nobody@example.com>" \
279 --to=nobody@example.com \
280 --in-reply-to=" " \
281 --smtp-server="$(pwd)/fake.sendmail" \
282 $patches \
283 2>errors
284 ! grep "^In-Reply-To: < *>" msgtxt1
285'
286
287test_expect_success $PREREQ 'Valid In-Reply-To when prompting' '
288 clean_fake_sendmail &&
289 (echo "From Example <from@example.com>"
290 echo "To Example <to@example.com>"
291 echo ""
292 ) | env GIT_SEND_EMAIL_NOTTY=1 git send-email \
293 --smtp-server="$(pwd)/fake.sendmail" \
294 $patches 2>errors &&
295 ! grep "^In-Reply-To: < *>" msgtxt1
296'
297
298test_expect_success $PREREQ 'setup fake editor' '
299 (echo "#!$SHELL_PATH" &&
300 echo "echo fake edit >>\"\$1\""
301 ) >fake-editor &&
302 chmod +x fake-editor
303'
304
305test_set_editor "$(pwd)/fake-editor"
306
307test_expect_success $PREREQ '--compose works' '
308 clean_fake_sendmail &&
309 git send-email \
310 --compose --subject foo \
311 --from="Example <nobody@example.com>" \
312 --to=nobody@example.com \
313 --smtp-server="$(pwd)/fake.sendmail" \
314 $patches \
315 2>errors
316'
317
318test_expect_success $PREREQ 'first message is compose text' '
319 grep "^fake edit" msgtxt1
320'
321
322test_expect_success $PREREQ 'second message is patch' '
323 grep "Subject:.*Second" msgtxt2
324'
325
326test_expect_success $PREREQ 'setup expect' "
327cat >expected-suppress-sob <<\EOF
3280001-Second.patch
329(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
330(mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
331(mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
332Dry-OK. Log says:
333Server: relay.example.com
334MAIL FROM:<from@example.com>
335RCPT TO:<to@example.com>
336RCPT TO:<cc@example.com>
337RCPT TO:<author@example.com>
338RCPT TO:<one@example.com>
339RCPT TO:<two@example.com>
340From: Example <from@example.com>
341To: to@example.com
342Cc: cc@example.com,
343 A <author@example.com>,
344 One <one@example.com>,
345 two@example.com
346Subject: [PATCH 1/1] Second.
347Date: DATE-STRING
348Message-Id: MESSAGE-ID-STRING
349X-Mailer: X-MAILER-STRING
350
351Result: OK
352EOF
353"
354
355test_suppression () {
356 git send-email \
357 --dry-run \
358 --suppress-cc=$1 ${2+"--suppress-cc=$2"} \
359 --from="Example <from@example.com>" \
360 --to=to@example.com \
361 --smtp-server relay.example.com \
362 $patches |
363 sed -e "s/^\(Date:\).*/\1 DATE-STRING/" \
364 -e "s/^\(Message-Id:\).*/\1 MESSAGE-ID-STRING/" \
365 -e "s/^\(X-Mailer:\).*/\1 X-MAILER-STRING/" \
366 >actual-suppress-$1${2+"-$2"} &&
367 test_cmp expected-suppress-$1${2+"-$2"} actual-suppress-$1${2+"-$2"}
368}
369
370test_expect_success $PREREQ 'sendemail.cc set' '
371 git config sendemail.cc cc@example.com &&
372 test_suppression sob
373'
374
375test_expect_success $PREREQ 'setup expect' "
376cat >expected-suppress-sob <<\EOF
3770001-Second.patch
378(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
379(mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
380(mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
381Dry-OK. Log says:
382Server: relay.example.com
383MAIL FROM:<from@example.com>
384RCPT TO:<to@example.com>
385RCPT TO:<author@example.com>
386RCPT TO:<one@example.com>
387RCPT TO:<two@example.com>
388From: Example <from@example.com>
389To: to@example.com
390Cc: A <author@example.com>,
391 One <one@example.com>,
392 two@example.com
393Subject: [PATCH 1/1] Second.
394Date: DATE-STRING
395Message-Id: MESSAGE-ID-STRING
396X-Mailer: X-MAILER-STRING
397
398Result: OK
399EOF
400"
401
402test_expect_success $PREREQ 'sendemail.cc unset' '
403 git config --unset sendemail.cc &&
404 test_suppression sob
405'
406
407test_expect_success $PREREQ 'setup expect' "
408cat >expected-suppress-cccmd <<\EOF
4090001-Second.patch
410(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
411(mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
412(mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
413(body) Adding cc: C O Mitter <committer@example.com> from line 'Signed-off-by: C O Mitter <committer@example.com>'
414Dry-OK. Log says:
415Server: relay.example.com
416MAIL FROM:<from@example.com>
417RCPT TO:<to@example.com>
418RCPT TO:<author@example.com>
419RCPT TO:<one@example.com>
420RCPT TO:<two@example.com>
421RCPT TO:<committer@example.com>
422From: Example <from@example.com>
423To: to@example.com
424Cc: A <author@example.com>,
425 One <one@example.com>,
426 two@example.com,
427 C O Mitter <committer@example.com>
428Subject: [PATCH 1/1] Second.
429Date: DATE-STRING
430Message-Id: MESSAGE-ID-STRING
431X-Mailer: X-MAILER-STRING
432
433Result: OK
434EOF
435"
436
437test_expect_success $PREREQ 'sendemail.cccmd' '
438 echo echo cc-cmd@example.com > cccmd &&
439 chmod +x cccmd &&
440 git config sendemail.cccmd ./cccmd &&
441 test_suppression cccmd
442'
443
444test_expect_success $PREREQ 'setup expect' '
445cat >expected-suppress-all <<\EOF
4460001-Second.patch
447Dry-OK. Log says:
448Server: relay.example.com
449MAIL FROM:<from@example.com>
450RCPT TO:<to@example.com>
451From: Example <from@example.com>
452To: to@example.com
453Subject: [PATCH 1/1] Second.
454Date: DATE-STRING
455Message-Id: MESSAGE-ID-STRING
456X-Mailer: X-MAILER-STRING
457
458Result: OK
459EOF
460'
461
462test_expect_success $PREREQ '--suppress-cc=all' '
463 test_suppression all
464'
465
466test_expect_success $PREREQ 'setup expect' "
467cat >expected-suppress-body <<\EOF
4680001-Second.patch
469(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
470(mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
471(mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
472(cc-cmd) Adding cc: cc-cmd@example.com from: './cccmd'
473Dry-OK. Log says:
474Server: relay.example.com
475MAIL FROM:<from@example.com>
476RCPT TO:<to@example.com>
477RCPT TO:<author@example.com>
478RCPT TO:<one@example.com>
479RCPT TO:<two@example.com>
480RCPT TO:<cc-cmd@example.com>
481From: Example <from@example.com>
482To: to@example.com
483Cc: A <author@example.com>,
484 One <one@example.com>,
485 two@example.com,
486 cc-cmd@example.com
487Subject: [PATCH 1/1] Second.
488Date: DATE-STRING
489Message-Id: MESSAGE-ID-STRING
490X-Mailer: X-MAILER-STRING
491
492Result: OK
493EOF
494"
495
496test_expect_success $PREREQ '--suppress-cc=body' '
497 test_suppression body
498'
499
500test_expect_success $PREREQ 'setup expect' "
501cat >expected-suppress-body-cccmd <<\EOF
5020001-Second.patch
503(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
504(mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
505(mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
506Dry-OK. Log says:
507Server: relay.example.com
508MAIL FROM:<from@example.com>
509RCPT TO:<to@example.com>
510RCPT TO:<author@example.com>
511RCPT TO:<one@example.com>
512RCPT TO:<two@example.com>
513From: Example <from@example.com>
514To: to@example.com
515Cc: A <author@example.com>,
516 One <one@example.com>,
517 two@example.com
518Subject: [PATCH 1/1] Second.
519Date: DATE-STRING
520Message-Id: MESSAGE-ID-STRING
521X-Mailer: X-MAILER-STRING
522
523Result: OK
524EOF
525"
526
527test_expect_success $PREREQ '--suppress-cc=body --suppress-cc=cccmd' '
528 test_suppression body cccmd
529'
530
531test_expect_success $PREREQ 'setup expect' "
532cat >expected-suppress-sob <<\EOF
5330001-Second.patch
534(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
535(mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
536(mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
537Dry-OK. Log says:
538Server: relay.example.com
539MAIL FROM:<from@example.com>
540RCPT TO:<to@example.com>
541RCPT TO:<author@example.com>
542RCPT TO:<one@example.com>
543RCPT TO:<two@example.com>
544From: Example <from@example.com>
545To: to@example.com
546Cc: A <author@example.com>,
547 One <one@example.com>,
548 two@example.com
549Subject: [PATCH 1/1] Second.
550Date: DATE-STRING
551Message-Id: MESSAGE-ID-STRING
552X-Mailer: X-MAILER-STRING
553
554Result: OK
555EOF
556"
557
558test_expect_success $PREREQ '--suppress-cc=sob' '
559 git config --unset sendemail.cccmd
560 test_suppression sob
561'
562
563test_expect_success $PREREQ 'setup expect' "
564cat >expected-suppress-bodycc <<\EOF
5650001-Second.patch
566(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
567(mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
568(mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
569(body) Adding cc: C O Mitter <committer@example.com> from line 'Signed-off-by: C O Mitter <committer@example.com>'
570Dry-OK. Log says:
571Server: relay.example.com
572MAIL FROM:<from@example.com>
573RCPT TO:<to@example.com>
574RCPT TO:<author@example.com>
575RCPT TO:<one@example.com>
576RCPT TO:<two@example.com>
577RCPT TO:<committer@example.com>
578From: Example <from@example.com>
579To: to@example.com
580Cc: A <author@example.com>,
581 One <one@example.com>,
582 two@example.com,
583 C O Mitter <committer@example.com>
584Subject: [PATCH 1/1] Second.
585Date: DATE-STRING
586Message-Id: MESSAGE-ID-STRING
587X-Mailer: X-MAILER-STRING
588
589Result: OK
590EOF
591"
592
593test_expect_success $PREREQ '--suppress-cc=bodycc' '
594 test_suppression bodycc
595'
596
597test_expect_success $PREREQ 'setup expect' "
598cat >expected-suppress-cc <<\EOF
5990001-Second.patch
600(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
601(body) Adding cc: C O Mitter <committer@example.com> from line 'Signed-off-by: C O Mitter <committer@example.com>'
602Dry-OK. Log says:
603Server: relay.example.com
604MAIL FROM:<from@example.com>
605RCPT TO:<to@example.com>
606RCPT TO:<author@example.com>
607RCPT TO:<committer@example.com>
608From: Example <from@example.com>
609To: to@example.com
610Cc: A <author@example.com>,
611 C O Mitter <committer@example.com>
612Subject: [PATCH 1/1] Second.
613Date: DATE-STRING
614Message-Id: MESSAGE-ID-STRING
615X-Mailer: X-MAILER-STRING
616
617Result: OK
618EOF
619"
620
621test_expect_success $PREREQ '--suppress-cc=cc' '
622 test_suppression cc
623'
624
625test_confirm () {
626 echo y | \
627 GIT_SEND_EMAIL_NOTTY=1 \
628 git send-email \
629 --from="Example <nobody@example.com>" \
630 --to=nobody@example.com \
631 --smtp-server="$(pwd)/fake.sendmail" \
632 $@ $patches > stdout &&
633 grep "Send this email" stdout
634}
635
636test_expect_success $PREREQ '--confirm=always' '
637 test_confirm --confirm=always --suppress-cc=all
638'
639
640test_expect_success $PREREQ '--confirm=auto' '
641 test_confirm --confirm=auto
642'
643
644test_expect_success $PREREQ '--confirm=cc' '
645 test_confirm --confirm=cc
646'
647
648test_expect_success $PREREQ '--confirm=compose' '
649 test_confirm --confirm=compose --compose
650'
651
652test_expect_success $PREREQ 'confirm by default (due to cc)' '
653 CONFIRM=$(git config --get sendemail.confirm) &&
654 git config --unset sendemail.confirm &&
655 test_confirm
656 ret="$?"
657 git config sendemail.confirm ${CONFIRM:-never}
658 test $ret = "0"
659'
660
661test_expect_success $PREREQ 'confirm by default (due to --compose)' '
662 CONFIRM=$(git config --get sendemail.confirm) &&
663 git config --unset sendemail.confirm &&
664 test_confirm --suppress-cc=all --compose
665 ret="$?"
666 git config sendemail.confirm ${CONFIRM:-never}
667 test $ret = "0"
668'
669
670test_expect_success $PREREQ 'confirm detects EOF (inform assumes y)' '
671 CONFIRM=$(git config --get sendemail.confirm) &&
672 git config --unset sendemail.confirm &&
673 rm -fr outdir &&
674 git format-patch -2 -o outdir &&
675 GIT_SEND_EMAIL_NOTTY=1 \
676 git send-email \
677 --from="Example <nobody@example.com>" \
678 --to=nobody@example.com \
679 --smtp-server="$(pwd)/fake.sendmail" \
680 outdir/*.patch < /dev/null
681 ret="$?"
682 git config sendemail.confirm ${CONFIRM:-never}
683 test $ret = "0"
684'
685
686test_expect_success $PREREQ 'confirm detects EOF (auto causes failure)' '
687 CONFIRM=$(git config --get sendemail.confirm) &&
688 git config sendemail.confirm auto &&
689 GIT_SEND_EMAIL_NOTTY=1 &&
690 export GIT_SEND_EMAIL_NOTTY &&
691 test_must_fail git send-email \
692 --from="Example <nobody@example.com>" \
693 --to=nobody@example.com \
694 --smtp-server="$(pwd)/fake.sendmail" \
695 $patches < /dev/null
696 ret="$?"
697 git config sendemail.confirm ${CONFIRM:-never}
698 test $ret = "0"
699'
700
701test_expect_success $PREREQ 'confirm doesnt loop forever' '
702 CONFIRM=$(git config --get sendemail.confirm) &&
703 git config sendemail.confirm auto &&
704 GIT_SEND_EMAIL_NOTTY=1 &&
705 export GIT_SEND_EMAIL_NOTTY &&
706 yes "bogus" | test_must_fail git send-email \
707 --from="Example <nobody@example.com>" \
708 --to=nobody@example.com \
709 --smtp-server="$(pwd)/fake.sendmail" \
710 $patches
711 ret="$?"
712 git config sendemail.confirm ${CONFIRM:-never}
713 test $ret = "0"
714'
715
716test_expect_success $PREREQ 'utf8 Cc is rfc2047 encoded' '
717 clean_fake_sendmail &&
718 rm -fr outdir &&
719 git format-patch -1 -o outdir --cc="àéìöú <utf8@example.com>" &&
720 git send-email \
721 --from="Example <nobody@example.com>" \
722 --to=nobody@example.com \
723 --smtp-server="$(pwd)/fake.sendmail" \
724 outdir/*.patch &&
725 grep "^ " msgtxt1 |
726 grep "=?UTF-8?q?=C3=A0=C3=A9=C3=AC=C3=B6=C3=BA?= <utf8@example.com>"
727'
728
729test_expect_success $PREREQ '--compose adds MIME for utf8 body' '
730 clean_fake_sendmail &&
731 (echo "#!$SHELL_PATH" &&
732 echo "echo utf8 body: àéìöú >>\"\$1\""
733 ) >fake-editor-utf8 &&
734 chmod +x fake-editor-utf8 &&
735 GIT_EDITOR="\"$(pwd)/fake-editor-utf8\"" \
736 git send-email \
737 --compose --subject foo \
738 --from="Example <nobody@example.com>" \
739 --to=nobody@example.com \
740 --smtp-server="$(pwd)/fake.sendmail" \
741 $patches &&
742 grep "^utf8 body" msgtxt1 &&
743 grep "^Content-Type: text/plain; charset=UTF-8" msgtxt1
744'
745
746test_expect_success $PREREQ '--compose respects user mime type' '
747 clean_fake_sendmail &&
748 (echo "#!$SHELL_PATH" &&
749 echo "(echo MIME-Version: 1.0"
750 echo " echo Content-Type: text/plain\\; charset=iso-8859-1"
751 echo " echo Content-Transfer-Encoding: 8bit"
752 echo " echo Subject: foo"
753 echo " echo "
754 echo " echo utf8 body: àéìöú) >\"\$1\""
755 ) >fake-editor-utf8-mime &&
756 chmod +x fake-editor-utf8-mime &&
757 GIT_EDITOR="\"$(pwd)/fake-editor-utf8-mime\"" \
758 git send-email \
759 --compose --subject foo \
760 --from="Example <nobody@example.com>" \
761 --to=nobody@example.com \
762 --smtp-server="$(pwd)/fake.sendmail" \
763 $patches &&
764 grep "^utf8 body" msgtxt1 &&
765 grep "^Content-Type: text/plain; charset=iso-8859-1" msgtxt1 &&
766 ! grep "^Content-Type: text/plain; charset=UTF-8" msgtxt1
767'
768
769test_expect_success $PREREQ '--compose adds MIME for utf8 subject' '
770 clean_fake_sendmail &&
771 GIT_EDITOR="\"$(pwd)/fake-editor\"" \
772 git send-email \
773 --compose --subject utf8-sübjëct \
774 --from="Example <nobody@example.com>" \
775 --to=nobody@example.com \
776 --smtp-server="$(pwd)/fake.sendmail" \
777 $patches &&
778 grep "^fake edit" msgtxt1 &&
779 grep "^Subject: =?UTF-8?q?utf8-s=C3=BCbj=C3=ABct?=" msgtxt1
780'
781
782test_expect_success $PREREQ 'detects ambiguous reference/file conflict' '
783 echo master > master &&
784 git add master &&
785 git commit -m"add master" &&
786 test_must_fail git send-email --dry-run master 2>errors &&
787 grep disambiguate errors
788'
789
790test_expect_success $PREREQ 'feed two files' '
791 rm -fr outdir &&
792 git format-patch -2 -o outdir &&
793 git send-email \
794 --dry-run \
795 --from="Example <nobody@example.com>" \
796 --to=nobody@example.com \
797 outdir/000?-*.patch 2>errors >out &&
798 grep "^Subject: " out >subjects &&
799 test "z$(sed -n -e 1p subjects)" = "zSubject: [PATCH 1/2] Second." &&
800 test "z$(sed -n -e 2p subjects)" = "zSubject: [PATCH 2/2] add master"
801'
802
803test_expect_success $PREREQ 'in-reply-to but no threading' '
804 git send-email \
805 --dry-run \
806 --from="Example <nobody@example.com>" \
807 --to=nobody@example.com \
808 --in-reply-to="<in-reply-id@example.com>" \
809 --nothread \
810 $patches |
811 grep "In-Reply-To: <in-reply-id@example.com>"
812'
813
814test_expect_success $PREREQ 'no in-reply-to and no threading' '
815 git send-email \
816 --dry-run \
817 --from="Example <nobody@example.com>" \
818 --to=nobody@example.com \
819 --nothread \
820 $patches $patches >stdout &&
821 ! grep "In-Reply-To: " stdout
822'
823
824test_expect_success $PREREQ 'threading but no chain-reply-to' '
825 git send-email \
826 --dry-run \
827 --from="Example <nobody@example.com>" \
828 --to=nobody@example.com \
829 --thread \
830 --nochain-reply-to \
831 $patches $patches >stdout &&
832 grep "In-Reply-To: " stdout
833'
834
835test_expect_success $PREREQ 'warning with an implicit --chain-reply-to' '
836 git send-email \
837 --dry-run \
838 --from="Example <nobody@example.com>" \
839 --to=nobody@example.com \
840 outdir/000?-*.patch 2>errors >out &&
841 grep "no-chain-reply-to" errors
842'
843
844test_expect_success $PREREQ 'no warning with an explicit --chain-reply-to' '
845 git send-email \
846 --dry-run \
847 --from="Example <nobody@example.com>" \
848 --to=nobody@example.com \
849 --chain-reply-to \
850 outdir/000?-*.patch 2>errors >out &&
851 ! grep "no-chain-reply-to" errors
852'
853
854test_expect_success $PREREQ 'no warning with an explicit --no-chain-reply-to' '
855 git send-email \
856 --dry-run \
857 --from="Example <nobody@example.com>" \
858 --to=nobody@example.com \
859 --nochain-reply-to \
860 outdir/000?-*.patch 2>errors >out &&
861 ! grep "no-chain-reply-to" errors
862'
863
864test_expect_success $PREREQ 'no warning with sendemail.chainreplyto = false' '
865 git config sendemail.chainreplyto false &&
866 git send-email \
867 --dry-run \
868 --from="Example <nobody@example.com>" \
869 --to=nobody@example.com \
870 outdir/000?-*.patch 2>errors >out &&
871 ! grep "no-chain-reply-to" errors
872'
873
874test_expect_success $PREREQ 'no warning with sendemail.chainreplyto = true' '
875 git config sendemail.chainreplyto true &&
876 git send-email \
877 --dry-run \
878 --from="Example <nobody@example.com>" \
879 --to=nobody@example.com \
880 outdir/000?-*.patch 2>errors >out &&
881 ! grep "no-chain-reply-to" errors
882'
883
884test_expect_success $PREREQ 'sendemail.to works' '
885 git config --replace-all sendemail.to "Somebody <somebody@ex.com>" &&
886 git send-email \
887 --dry-run \
888 --from="Example <nobody@example.com>" \
889 $patches $patches >stdout &&
890 grep "To: Somebody <somebody@ex.com>" stdout
891'
892
893test_expect_success $PREREQ '--no-to overrides sendemail.to' '
894 git send-email \
895 --dry-run \
896 --from="Example <nobody@example.com>" \
897 --no-to \
898 --to=nobody@example.com \
899 $patches $patches >stdout &&
900 grep "To: nobody@example.com" stdout &&
901 ! grep "To: Somebody <somebody@ex.com>" stdout
902'
903
904test_expect_success $PREREQ 'sendemail.cc works' '
905 git config --replace-all sendemail.cc "Somebody <somebody@ex.com>" &&
906 git send-email \
907 --dry-run \
908 --from="Example <nobody@example.com>" \
909 --to=nobody@example.com \
910 $patches $patches >stdout &&
911 grep "Cc: Somebody <somebody@ex.com>" stdout
912'
913
914test_expect_success $PREREQ '--no-cc overrides sendemail.cc' '
915 git send-email \
916 --dry-run \
917 --from="Example <nobody@example.com>" \
918 --no-cc \
919 --cc=bodies@example.com \
920 --to=nobody@example.com \
921 $patches $patches >stdout &&
922 grep "Cc: bodies@example.com" stdout &&
923 ! grep "Cc: Somebody <somebody@ex.com>" stdout
924'
925
926test_expect_success $PREREQ 'sendemail.bcc works' '
927 git config --replace-all sendemail.bcc "Other <other@ex.com>" &&
928 git send-email \
929 --dry-run \
930 --from="Example <nobody@example.com>" \
931 --to=nobody@example.com \
932 --smtp-server relay.example.com \
933 $patches $patches >stdout &&
934 grep "RCPT TO:<other@ex.com>" stdout
935'
936
937test_expect_success $PREREQ '--no-bcc overrides sendemail.bcc' '
938 git send-email \
939 --dry-run \
940 --from="Example <nobody@example.com>" \
941 --no-bcc \
942 --bcc=bodies@example.com \
943 --to=nobody@example.com \
944 --smtp-server relay.example.com \
945 $patches $patches >stdout &&
946 grep "RCPT TO:<bodies@example.com>" stdout &&
947 ! grep "RCPT TO:<other@ex.com>" stdout
948'
949
950test_expect_success $PREREQ 'setup expect' '
951cat >email-using-8bit <<EOF
952From fe6ecc66ece37198fe5db91fa2fc41d9f4fe5cc4 Mon Sep 17 00:00:00 2001
953Message-Id: <bogus-message-id@example.com>
954From: author@example.com
955Date: Sat, 12 Jun 2010 15:53:58 +0200
956Subject: subject goes here
957
958Dieser deutsche Text enthält einen Umlaut!
959EOF
960'
961
962test_expect_success $PREREQ 'setup expect' '
963cat >content-type-decl <<EOF
964MIME-Version: 1.0
965Content-Type: text/plain; charset=UTF-8
966Content-Transfer-Encoding: 8bit
967EOF
968'
969
970test_expect_success $PREREQ 'asks about and fixes 8bit encodings' '
971 clean_fake_sendmail &&
972 echo |
973 git send-email --from=author@example.com --to=nobody@example.com \
974 --smtp-server="$(pwd)/fake.sendmail" \
975 email-using-8bit >stdout &&
976 grep "do not declare a Content-Transfer-Encoding" stdout &&
977 grep email-using-8bit stdout &&
978 grep "Which 8bit encoding" stdout &&
979 egrep "Content|MIME" msgtxt1 >actual &&
980 test_cmp actual content-type-decl
981'
982
983test_expect_success $PREREQ 'sendemail.8bitEncoding works' '
984 clean_fake_sendmail &&
985 git config sendemail.assume8bitEncoding UTF-8 &&
986 echo bogus |
987 git send-email --from=author@example.com --to=nobody@example.com \
988 --smtp-server="$(pwd)/fake.sendmail" \
989 email-using-8bit >stdout &&
990 egrep "Content|MIME" msgtxt1 >actual &&
991 test_cmp actual content-type-decl
992'
993
994test_expect_success $PREREQ '--8bit-encoding overrides sendemail.8bitEncoding' '
995 clean_fake_sendmail &&
996 git config sendemail.assume8bitEncoding "bogus too" &&
997 echo bogus |
998 git send-email --from=author@example.com --to=nobody@example.com \
999 --smtp-server="$(pwd)/fake.sendmail" \
1000 --8bit-encoding=UTF-8 \
1001 email-using-8bit >stdout &&
1002 egrep "Content|MIME" msgtxt1 >actual &&
1003 test_cmp actual content-type-decl
1004'
1005
1006test_expect_success $PREREQ 'setup expect' '
1007cat >email-using-8bit <<EOF
1008From fe6ecc66ece37198fe5db91fa2fc41d9f4fe5cc4 Mon Sep 17 00:00:00 2001
1009Message-Id: <bogus-message-id@example.com>
1010From: author@example.com
1011Date: Sat, 12 Jun 2010 15:53:58 +0200
1012Subject: Dieser Betreff enthält auch einen Umlaut!
1013
1014Nothing to see here.
1015EOF
1016'
1017
1018test_expect_success $PREREQ 'setup expect' '
1019cat >expected <<EOF
1020Subject: =?UTF-8?q?Dieser=20Betreff=20enth=C3=A4lt=20auch=20einen=20Umlaut!?=
1021EOF
1022'
1023
1024test_expect_success $PREREQ '--8bit-encoding also treats subject' '
1025 clean_fake_sendmail &&
1026 echo bogus |
1027 git send-email --from=author@example.com --to=nobody@example.com \
1028 --smtp-server="$(pwd)/fake.sendmail" \
1029 --8bit-encoding=UTF-8 \
1030 email-using-8bit >stdout &&
1031 grep "Subject" msgtxt1 >actual &&
1032 test_cmp expected actual
1033'
1034
1035# Note that the patches in this test are deliberately out of order; we
1036# want to make sure it works even if the cover-letter is not in the
1037# first mail.
1038test_expect_success $PREREQ 'refusing to send cover letter template' '
1039 clean_fake_sendmail &&
1040 rm -fr outdir &&
1041 git format-patch --cover-letter -2 -o outdir &&
1042 test_must_fail git send-email \
1043 --from="Example <nobody@example.com>" \
1044 --to=nobody@example.com \
1045 --smtp-server="$(pwd)/fake.sendmail" \
1046 outdir/0002-*.patch \
1047 outdir/0000-*.patch \
1048 outdir/0001-*.patch \
1049 2>errors >out &&
1050 grep "SUBJECT HERE" errors &&
1051 test -z "$(ls msgtxt*)"
1052'
1053
1054test_expect_success $PREREQ '--force sends cover letter template anyway' '
1055 clean_fake_sendmail &&
1056 rm -fr outdir &&
1057 git format-patch --cover-letter -2 -o outdir &&
1058 git send-email \
1059 --force \
1060 --from="Example <nobody@example.com>" \
1061 --to=nobody@example.com \
1062 --smtp-server="$(pwd)/fake.sendmail" \
1063 outdir/0002-*.patch \
1064 outdir/0000-*.patch \
1065 outdir/0001-*.patch \
1066 2>errors >out &&
1067 ! grep "SUBJECT HERE" errors &&
1068 test -n "$(ls msgtxt*)"
1069'
1070
1071test_done