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
9replace_variable_fields () {
10 sed -e "s/^\(Date:\).*/\1 DATE-STRING/" \
11 -e "s/^\(Message-Id:\).*/\1 MESSAGE-ID-STRING/" \
12 -e "s/^\(X-Mailer:\).*/\1 X-MAILER-STRING/"
13}
14
15test_expect_success $PREREQ 'prepare reference tree' '
16 echo "1A quick brown fox jumps over the" >file &&
17 echo "lazy dog" >>file &&
18 git add file &&
19 GIT_AUTHOR_NAME="A" git commit -a -m "Initial."
20'
21
22test_expect_success $PREREQ 'Setup helper tool' '
23 write_script fake.sendmail <<-\EOF &&
24 shift
25 output=1
26 while test -f commandline$output
27 do
28 output=$(($output+1))
29 done
30 for a
31 do
32 echo "!$a!"
33 done >commandline$output
34 cat >"msgtxt$output"
35 EOF
36 git add fake.sendmail &&
37 GIT_AUTHOR_NAME="A" git commit -a -m "Second."
38'
39
40clean_fake_sendmail () {
41 rm -f commandline* msgtxt*
42}
43
44test_expect_success $PREREQ 'Extract patches' '
45 patches=$(git format-patch -s --cc="One <one@example.com>" --cc=two@example.com -n HEAD^1)
46'
47
48# Test no confirm early to ensure remaining tests will not hang
49test_no_confirm () {
50 rm -f no_confirm_okay
51 echo n | \
52 GIT_SEND_EMAIL_NOTTY=1 \
53 git send-email \
54 --from="Example <from@example.com>" \
55 --to=nobody@example.com \
56 --smtp-server="$(pwd)/fake.sendmail" \
57 $@ \
58 $patches >stdout &&
59 ! grep "Send this email" stdout &&
60 >no_confirm_okay
61}
62
63# Exit immediately to prevent hang if a no-confirm test fails
64check_no_confirm () {
65 if ! test -f no_confirm_okay
66 then
67 say 'confirm test failed; skipping remaining tests to prevent hanging'
68 PREREQ="$PREREQ,CHECK_NO_CONFIRM"
69 fi
70 return 0
71}
72
73test_expect_success $PREREQ 'No confirm with --suppress-cc' '
74 test_no_confirm --suppress-cc=sob &&
75 check_no_confirm
76'
77
78
79test_expect_success $PREREQ 'No confirm with --confirm=never' '
80 test_no_confirm --confirm=never &&
81 check_no_confirm
82'
83
84# leave sendemail.confirm set to never after this so that none of the
85# remaining tests prompt unintentionally.
86test_expect_success $PREREQ 'No confirm with sendemail.confirm=never' '
87 git config sendemail.confirm never &&
88 test_no_confirm --compose --subject=foo &&
89 check_no_confirm
90'
91
92test_expect_success $PREREQ 'Send patches' '
93 git send-email --suppress-cc=sob --from="Example <nobody@example.com>" --to=nobody@example.com --smtp-server="$(pwd)/fake.sendmail" $patches 2>errors
94'
95
96test_expect_success $PREREQ 'setup expect' '
97 cat >expected <<-\EOF
98 !nobody@example.com!
99 !author@example.com!
100 !one@example.com!
101 !two@example.com!
102 EOF
103'
104
105test_expect_success $PREREQ 'Verify commandline' '
106 test_cmp expected commandline1
107'
108
109test_expect_success $PREREQ 'Send patches with --envelope-sender' '
110 clean_fake_sendmail &&
111 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
112'
113
114test_expect_success $PREREQ 'setup expect' '
115 cat >expected <<-\EOF
116 !patch@example.com!
117 !-i!
118 !nobody@example.com!
119 !author@example.com!
120 !one@example.com!
121 !two@example.com!
122 EOF
123'
124
125test_expect_success $PREREQ 'Verify commandline' '
126 test_cmp expected commandline1
127'
128
129test_expect_success $PREREQ 'Send patches with --envelope-sender=auto' '
130 clean_fake_sendmail &&
131 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
132'
133
134test_expect_success $PREREQ 'setup expect' '
135 cat >expected <<-\EOF
136 !nobody@example.com!
137 !-i!
138 !nobody@example.com!
139 !author@example.com!
140 !one@example.com!
141 !two@example.com!
142 EOF
143'
144
145test_expect_success $PREREQ 'Verify commandline' '
146 test_cmp expected commandline1
147'
148
149test_expect_success $PREREQ 'setup expect for cc trailer' "
150cat >expected-cc <<\EOF
151!recipient@example.com!
152!author@example.com!
153!one@example.com!
154!two@example.com!
155!three@example.com!
156!four@example.com!
157!five@example.com!
158!six@example.com!
159EOF
160"
161
162test_expect_success $PREREQ 'cc trailer with various syntax' '
163 test_commit cc-trailer &&
164 test_when_finished "git reset --hard HEAD^" &&
165 git commit --amend -F - <<-EOF &&
166 Test Cc: trailers.
167
168 Cc: one@example.com
169 Cc: <two@example.com> # trailing comments are ignored
170 Cc: <three@example.com>, <not.four@example.com> one address per line
171 Cc: "Some # Body" <four@example.com> [ <also.a.comment> ]
172 Cc: five@example.com # not.six@example.com
173 Cc: six@example.com, not.seven@example.com
174 EOF
175 clean_fake_sendmail &&
176 git send-email -1 --to=recipient@example.com \
177 --smtp-server="$(pwd)/fake.sendmail" &&
178 test_cmp expected-cc commandline1
179'
180
181test_expect_success $PREREQ 'setup fake get_maintainer.pl script for cc trailer' "
182 write_script expected-cc-script.sh <<-EOF
183 echo 'One Person <one@example.com> (supporter:THIS (FOO/bar))'
184 echo 'Two Person <two@example.com> (maintainer:THIS THING)'
185 echo 'Third List <three@example.com> (moderated list:THIS THING (FOO/bar))'
186 echo '<four@example.com> (moderated list:FOR THING)'
187 echo 'five@example.com (open list:FOR THING (FOO/bar))'
188 echo 'six@example.com (open list)'
189 EOF
190"
191
192test_expect_success $PREREQ 'cc trailer with get_maintainer.pl output' '
193 clean_fake_sendmail &&
194 git send-email -1 --to=recipient@example.com \
195 --cc-cmd=./expected-cc-script.sh \
196 --smtp-server="$(pwd)/fake.sendmail" &&
197 test_cmp expected-cc commandline1
198'
199
200test_expect_success $PREREQ 'setup expect' "
201cat >expected-show-all-headers <<\EOF
2020001-Second.patch
203(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
204(mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
205(mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
206Dry-OK. Log says:
207Server: relay.example.com
208MAIL FROM:<from@example.com>
209RCPT TO:<to@example.com>
210RCPT TO:<cc@example.com>
211RCPT TO:<author@example.com>
212RCPT TO:<one@example.com>
213RCPT TO:<two@example.com>
214RCPT TO:<bcc@example.com>
215From: Example <from@example.com>
216To: to@example.com
217Cc: cc@example.com,
218 A <author@example.com>,
219 One <one@example.com>,
220 two@example.com
221Subject: [PATCH 1/1] Second.
222Date: DATE-STRING
223Message-Id: MESSAGE-ID-STRING
224X-Mailer: X-MAILER-STRING
225In-Reply-To: <unique-message-id@example.com>
226References: <unique-message-id@example.com>
227Reply-To: Reply <reply@example.com>
228MIME-Version: 1.0
229Content-Transfer-Encoding: 8bit
230
231Result: OK
232EOF
233"
234
235test_suppress_self () {
236 test_commit $3 &&
237 test_when_finished "git reset --hard HEAD^" &&
238
239 write_script cccmd-sed <<-EOF &&
240 sed -n -e s/^cccmd--//p "\$1"
241 EOF
242
243 git commit --amend --author="$1 <$2>" -F - &&
244 clean_fake_sendmail &&
245 git format-patch --stdout -1 >"suppress-self-$3.patch" &&
246
247 git send-email --from="$1 <$2>" \
248 --to=nobody@example.com \
249 --cc-cmd=./cccmd-sed \
250 --suppress-cc=self \
251 --smtp-server="$(pwd)/fake.sendmail" \
252 suppress-self-$3.patch &&
253
254 mv msgtxt1 msgtxt1-$3 &&
255 sed -e '/^$/q' msgtxt1-$3 >"msghdr1-$3" &&
256 >"expected-no-cc-$3" &&
257
258 (grep '^Cc:' msghdr1-$3 >"actual-no-cc-$3";
259 test_cmp expected-no-cc-$3 actual-no-cc-$3)
260}
261
262test_suppress_self_unquoted () {
263 test_suppress_self "$1" "$2" "unquoted-$3" <<-EOF
264 test suppress-cc.self unquoted-$3 with name $1 email $2
265
266 unquoted-$3
267
268 cccmd--$1 <$2>
269
270 Cc: $1 <$2>
271 Signed-off-by: $1 <$2>
272 EOF
273}
274
275test_suppress_self_quoted () {
276 test_suppress_self "$1" "$2" "quoted-$3" <<-EOF
277 test suppress-cc.self quoted-$3 with name $1 email $2
278
279 quoted-$3
280
281 cccmd--"$1" <$2>
282
283 Cc: $1 <$2>
284 Cc: "$1" <$2>
285 Signed-off-by: $1 <$2>
286 Signed-off-by: "$1" <$2>
287 EOF
288}
289
290test_expect_success $PREREQ 'self name is suppressed' "
291 test_suppress_self_unquoted 'A U Thor' 'author@example.com' \
292 'self_name_suppressed'
293"
294
295test_expect_success $PREREQ 'self name with dot is suppressed' "
296 test_suppress_self_quoted 'A U. Thor' 'author@example.com' \
297 'self_name_dot_suppressed'
298"
299
300test_expect_success $PREREQ 'non-ascii self name is suppressed' "
301 test_suppress_self_quoted 'Füñný Nâmé' 'odd_?=mail@example.com' \
302 'non_ascii_self_suppressed'
303"
304
305# This name is long enough to force format-patch to split it into multiple
306# encoded-words, assuming it uses UTF-8 with the "Q" encoding.
307test_expect_success $PREREQ 'long non-ascii self name is suppressed' "
308 test_suppress_self_quoted 'Ƒüñníęř €. Nâṁé' 'odd_?=mail@example.com' \
309 'long_non_ascii_self_suppressed'
310"
311
312test_expect_success $PREREQ 'sanitized self name is suppressed' "
313 test_suppress_self_unquoted '\"A U. Thor\"' 'author@example.com' \
314 'self_name_sanitized_suppressed'
315"
316
317test_expect_success $PREREQ 'Show all headers' '
318 git send-email \
319 --dry-run \
320 --suppress-cc=sob \
321 --from="Example <from@example.com>" \
322 --reply-to="Reply <reply@example.com>" \
323 --to=to@example.com \
324 --cc=cc@example.com \
325 --bcc=bcc@example.com \
326 --in-reply-to="<unique-message-id@example.com>" \
327 --smtp-server relay.example.com \
328 $patches | replace_variable_fields \
329 >actual-show-all-headers &&
330 test_cmp expected-show-all-headers actual-show-all-headers
331'
332
333test_expect_success $PREREQ 'Prompting works' '
334 clean_fake_sendmail &&
335 (echo "to@example.com"
336 echo ""
337 ) | GIT_SEND_EMAIL_NOTTY=1 git send-email \
338 --smtp-server="$(pwd)/fake.sendmail" \
339 $patches \
340 2>errors &&
341 grep "^From: A U Thor <author@example.com>\$" msgtxt1 &&
342 grep "^To: to@example.com\$" msgtxt1
343'
344
345test_expect_success $PREREQ,AUTOIDENT 'implicit ident is allowed' '
346 clean_fake_sendmail &&
347 (sane_unset GIT_AUTHOR_NAME &&
348 sane_unset GIT_AUTHOR_EMAIL &&
349 sane_unset GIT_COMMITTER_NAME &&
350 sane_unset GIT_COMMITTER_EMAIL &&
351 GIT_SEND_EMAIL_NOTTY=1 git send-email \
352 --smtp-server="$(pwd)/fake.sendmail" \
353 --to=to@example.com \
354 $patches </dev/null 2>errors
355 )
356'
357
358test_expect_success $PREREQ,!AUTOIDENT 'broken implicit ident aborts send-email' '
359 clean_fake_sendmail &&
360 (sane_unset GIT_AUTHOR_NAME &&
361 sane_unset GIT_AUTHOR_EMAIL &&
362 sane_unset GIT_COMMITTER_NAME &&
363 sane_unset GIT_COMMITTER_EMAIL &&
364 GIT_SEND_EMAIL_NOTTY=1 && export GIT_SEND_EMAIL_NOTTY &&
365 test_must_fail git send-email \
366 --smtp-server="$(pwd)/fake.sendmail" \
367 --to=to@example.com \
368 $patches </dev/null 2>errors &&
369 test_i18ngrep "tell me who you are" errors
370 )
371'
372
373test_expect_success $PREREQ 'setup tocmd and cccmd scripts' '
374 write_script tocmd-sed <<-\EOF &&
375 sed -n -e "s/^tocmd--//p" "$1"
376 EOF
377 write_script cccmd-sed <<-\EOF
378 sed -n -e "s/^cccmd--//p" "$1"
379 EOF
380'
381
382test_expect_success $PREREQ 'tocmd works' '
383 clean_fake_sendmail &&
384 cp $patches tocmd.patch &&
385 echo tocmd--tocmd@example.com >>tocmd.patch &&
386 git send-email \
387 --from="Example <nobody@example.com>" \
388 --to-cmd=./tocmd-sed \
389 --smtp-server="$(pwd)/fake.sendmail" \
390 tocmd.patch \
391 &&
392 grep "^To: tocmd@example.com" msgtxt1
393'
394
395test_expect_success $PREREQ 'cccmd works' '
396 clean_fake_sendmail &&
397 cp $patches cccmd.patch &&
398 echo "cccmd-- cccmd@example.com" >>cccmd.patch &&
399 git send-email \
400 --from="Example <nobody@example.com>" \
401 --to=nobody@example.com \
402 --cc-cmd=./cccmd-sed \
403 --smtp-server="$(pwd)/fake.sendmail" \
404 cccmd.patch \
405 &&
406 grep "^ cccmd@example.com" msgtxt1
407'
408
409test_expect_success $PREREQ 'reject long lines' '
410 z8=zzzzzzzz &&
411 z64=$z8$z8$z8$z8$z8$z8$z8$z8 &&
412 z512=$z64$z64$z64$z64$z64$z64$z64$z64 &&
413 clean_fake_sendmail &&
414 cp $patches longline.patch &&
415 echo $z512$z512 >>longline.patch &&
416 test_must_fail git send-email \
417 --from="Example <nobody@example.com>" \
418 --to=nobody@example.com \
419 --smtp-server="$(pwd)/fake.sendmail" \
420 --transfer-encoding=8bit \
421 $patches longline.patch \
422 2>errors &&
423 grep longline.patch errors
424'
425
426test_expect_success $PREREQ 'no patch was sent' '
427 ! test -e commandline1
428'
429
430test_expect_success $PREREQ 'Author From: in message body' '
431 clean_fake_sendmail &&
432 git send-email \
433 --from="Example <nobody@example.com>" \
434 --to=nobody@example.com \
435 --smtp-server="$(pwd)/fake.sendmail" \
436 $patches &&
437 sed "1,/^\$/d" <msgtxt1 >msgbody1 &&
438 grep "From: A <author@example.com>" msgbody1
439'
440
441test_expect_success $PREREQ 'Author From: not in message body' '
442 clean_fake_sendmail &&
443 git send-email \
444 --from="A <author@example.com>" \
445 --to=nobody@example.com \
446 --smtp-server="$(pwd)/fake.sendmail" \
447 $patches &&
448 sed "1,/^\$/d" <msgtxt1 >msgbody1 &&
449 ! grep "From: A <author@example.com>" msgbody1
450'
451
452test_expect_success $PREREQ 'allow long lines with --no-validate' '
453 git send-email \
454 --from="Example <nobody@example.com>" \
455 --to=nobody@example.com \
456 --smtp-server="$(pwd)/fake.sendmail" \
457 --no-validate \
458 $patches longline.patch \
459 2>errors
460'
461
462test_expect_success $PREREQ 'short lines with auto encoding are 8bit' '
463 clean_fake_sendmail &&
464 git send-email \
465 --from="A <author@example.com>" \
466 --to=nobody@example.com \
467 --smtp-server="$(pwd)/fake.sendmail" \
468 --transfer-encoding=auto \
469 $patches &&
470 grep "Content-Transfer-Encoding: 8bit" msgtxt1
471'
472
473test_expect_success $PREREQ 'long lines with auto encoding are quoted-printable' '
474 clean_fake_sendmail &&
475 git send-email \
476 --from="Example <nobody@example.com>" \
477 --to=nobody@example.com \
478 --smtp-server="$(pwd)/fake.sendmail" \
479 --transfer-encoding=auto \
480 --no-validate \
481 longline.patch &&
482 grep "Content-Transfer-Encoding: quoted-printable" msgtxt1
483'
484
485for enc in auto quoted-printable base64
486do
487 test_expect_success $PREREQ "--validate passes with encoding $enc" '
488 git send-email \
489 --from="Example <nobody@example.com>" \
490 --to=nobody@example.com \
491 --smtp-server="$(pwd)/fake.sendmail" \
492 --transfer-encoding=$enc \
493 --validate \
494 $patches longline.patch
495 '
496done
497
498test_expect_success $PREREQ 'Invalid In-Reply-To' '
499 clean_fake_sendmail &&
500 git send-email \
501 --from="Example <nobody@example.com>" \
502 --to=nobody@example.com \
503 --in-reply-to=" " \
504 --smtp-server="$(pwd)/fake.sendmail" \
505 $patches \
506 2>errors &&
507 ! grep "^In-Reply-To: < *>" msgtxt1
508'
509
510test_expect_success $PREREQ 'Valid In-Reply-To when prompting' '
511 clean_fake_sendmail &&
512 (echo "From Example <from@example.com>"
513 echo "To Example <to@example.com>"
514 echo ""
515 ) | GIT_SEND_EMAIL_NOTTY=1 git send-email \
516 --smtp-server="$(pwd)/fake.sendmail" \
517 $patches 2>errors &&
518 ! grep "^In-Reply-To: < *>" msgtxt1
519'
520
521test_expect_success $PREREQ 'In-Reply-To without --chain-reply-to' '
522 clean_fake_sendmail &&
523 echo "<unique-message-id@example.com>" >expect &&
524 git send-email \
525 --from="Example <nobody@example.com>" \
526 --to=nobody@example.com \
527 --no-chain-reply-to \
528 --in-reply-to="$(cat expect)" \
529 --smtp-server="$(pwd)/fake.sendmail" \
530 $patches $patches $patches \
531 2>errors &&
532 # The first message is a reply to --in-reply-to
533 sed -n -e "s/^In-Reply-To: *\(.*\)/\1/p" msgtxt1 >actual &&
534 test_cmp expect actual &&
535 # Second and subsequent messages are replies to the first one
536 sed -n -e "s/^Message-Id: *\(.*\)/\1/p" msgtxt1 >expect &&
537 sed -n -e "s/^In-Reply-To: *\(.*\)/\1/p" msgtxt2 >actual &&
538 test_cmp expect actual &&
539 sed -n -e "s/^In-Reply-To: *\(.*\)/\1/p" msgtxt3 >actual &&
540 test_cmp expect actual
541'
542
543test_expect_success $PREREQ 'In-Reply-To with --chain-reply-to' '
544 clean_fake_sendmail &&
545 echo "<unique-message-id@example.com>" >expect &&
546 git send-email \
547 --from="Example <nobody@example.com>" \
548 --to=nobody@example.com \
549 --chain-reply-to \
550 --in-reply-to="$(cat expect)" \
551 --smtp-server="$(pwd)/fake.sendmail" \
552 $patches $patches $patches \
553 2>errors &&
554 sed -n -e "s/^In-Reply-To: *\(.*\)/\1/p" msgtxt1 >actual &&
555 test_cmp expect actual &&
556 sed -n -e "s/^Message-Id: *\(.*\)/\1/p" msgtxt1 >expect &&
557 sed -n -e "s/^In-Reply-To: *\(.*\)/\1/p" msgtxt2 >actual &&
558 test_cmp expect actual &&
559 sed -n -e "s/^Message-Id: *\(.*\)/\1/p" msgtxt2 >expect &&
560 sed -n -e "s/^In-Reply-To: *\(.*\)/\1/p" msgtxt3 >actual &&
561 test_cmp expect actual
562'
563
564test_expect_success $PREREQ 'setup fake editor' '
565 write_script fake-editor <<-\EOF
566 echo fake edit >>"$1"
567 EOF
568'
569
570test_set_editor "$(pwd)/fake-editor"
571
572test_expect_success $PREREQ '--compose works' '
573 clean_fake_sendmail &&
574 git send-email \
575 --compose --subject foo \
576 --from="Example <nobody@example.com>" \
577 --to=nobody@example.com \
578 --smtp-server="$(pwd)/fake.sendmail" \
579 $patches \
580 2>errors
581'
582
583test_expect_success $PREREQ 'first message is compose text' '
584 grep "^fake edit" msgtxt1
585'
586
587test_expect_success $PREREQ 'second message is patch' '
588 grep "Subject:.*Second" msgtxt2
589'
590
591test_expect_success $PREREQ 'setup expect' "
592cat >expected-suppress-sob <<\EOF
5930001-Second.patch
594(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
595(mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
596(mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
597Dry-OK. Log says:
598Server: relay.example.com
599MAIL FROM:<from@example.com>
600RCPT TO:<to@example.com>
601RCPT TO:<cc@example.com>
602RCPT TO:<author@example.com>
603RCPT TO:<one@example.com>
604RCPT TO:<two@example.com>
605From: Example <from@example.com>
606To: to@example.com
607Cc: cc@example.com,
608 A <author@example.com>,
609 One <one@example.com>,
610 two@example.com
611Subject: [PATCH 1/1] Second.
612Date: DATE-STRING
613Message-Id: MESSAGE-ID-STRING
614X-Mailer: X-MAILER-STRING
615MIME-Version: 1.0
616Content-Transfer-Encoding: 8bit
617
618Result: OK
619EOF
620"
621
622test_suppression () {
623 git send-email \
624 --dry-run \
625 --suppress-cc=$1 ${2+"--suppress-cc=$2"} \
626 --from="Example <from@example.com>" \
627 --to=to@example.com \
628 --smtp-server relay.example.com \
629 $patches | replace_variable_fields \
630 >actual-suppress-$1${2+"-$2"} &&
631 test_cmp expected-suppress-$1${2+"-$2"} actual-suppress-$1${2+"-$2"}
632}
633
634test_expect_success $PREREQ 'sendemail.cc set' '
635 git config sendemail.cc cc@example.com &&
636 test_suppression sob
637'
638
639test_expect_success $PREREQ 'setup expect' "
640cat >expected-suppress-sob <<\EOF
6410001-Second.patch
642(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
643(mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
644(mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
645Dry-OK. Log says:
646Server: relay.example.com
647MAIL FROM:<from@example.com>
648RCPT TO:<to@example.com>
649RCPT TO:<author@example.com>
650RCPT TO:<one@example.com>
651RCPT TO:<two@example.com>
652From: Example <from@example.com>
653To: to@example.com
654Cc: A <author@example.com>,
655 One <one@example.com>,
656 two@example.com
657Subject: [PATCH 1/1] Second.
658Date: DATE-STRING
659Message-Id: MESSAGE-ID-STRING
660X-Mailer: X-MAILER-STRING
661MIME-Version: 1.0
662Content-Transfer-Encoding: 8bit
663
664Result: OK
665EOF
666"
667
668test_expect_success $PREREQ 'sendemail.cc unset' '
669 git config --unset sendemail.cc &&
670 test_suppression sob
671'
672
673test_expect_success $PREREQ 'setup expect' "
674cat >expected-suppress-cccmd <<\EOF
6750001-Second.patch
676(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
677(mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
678(mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
679(body) Adding cc: C O Mitter <committer@example.com> from line 'Signed-off-by: C O Mitter <committer@example.com>'
680Dry-OK. Log says:
681Server: relay.example.com
682MAIL FROM:<from@example.com>
683RCPT TO:<to@example.com>
684RCPT TO:<author@example.com>
685RCPT TO:<one@example.com>
686RCPT TO:<two@example.com>
687RCPT TO:<committer@example.com>
688From: Example <from@example.com>
689To: to@example.com
690Cc: A <author@example.com>,
691 One <one@example.com>,
692 two@example.com,
693 C O Mitter <committer@example.com>
694Subject: [PATCH 1/1] Second.
695Date: DATE-STRING
696Message-Id: MESSAGE-ID-STRING
697X-Mailer: X-MAILER-STRING
698MIME-Version: 1.0
699Content-Transfer-Encoding: 8bit
700
701Result: OK
702EOF
703"
704
705test_expect_success $PREREQ 'sendemail.cccmd' '
706 write_script cccmd <<-\EOF &&
707 echo cc-cmd@example.com
708 EOF
709 git config sendemail.cccmd ./cccmd &&
710 test_suppression cccmd
711'
712
713test_expect_success $PREREQ 'setup expect' '
714cat >expected-suppress-all <<\EOF
7150001-Second.patch
716Dry-OK. Log says:
717Server: relay.example.com
718MAIL FROM:<from@example.com>
719RCPT TO:<to@example.com>
720From: Example <from@example.com>
721To: to@example.com
722Subject: [PATCH 1/1] Second.
723Date: DATE-STRING
724Message-Id: MESSAGE-ID-STRING
725X-Mailer: X-MAILER-STRING
726MIME-Version: 1.0
727Content-Transfer-Encoding: 8bit
728
729Result: OK
730EOF
731'
732
733test_expect_success $PREREQ '--suppress-cc=all' '
734 test_suppression all
735'
736
737test_expect_success $PREREQ 'setup expect' "
738cat >expected-suppress-body <<\EOF
7390001-Second.patch
740(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
741(mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
742(mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
743(cc-cmd) Adding cc: cc-cmd@example.com from: './cccmd'
744Dry-OK. Log says:
745Server: relay.example.com
746MAIL FROM:<from@example.com>
747RCPT TO:<to@example.com>
748RCPT TO:<author@example.com>
749RCPT TO:<one@example.com>
750RCPT TO:<two@example.com>
751RCPT TO:<cc-cmd@example.com>
752From: Example <from@example.com>
753To: to@example.com
754Cc: A <author@example.com>,
755 One <one@example.com>,
756 two@example.com,
757 cc-cmd@example.com
758Subject: [PATCH 1/1] Second.
759Date: DATE-STRING
760Message-Id: MESSAGE-ID-STRING
761X-Mailer: X-MAILER-STRING
762MIME-Version: 1.0
763Content-Transfer-Encoding: 8bit
764
765Result: OK
766EOF
767"
768
769test_expect_success $PREREQ '--suppress-cc=body' '
770 test_suppression body
771'
772
773test_expect_success $PREREQ 'setup expect' "
774cat >expected-suppress-body-cccmd <<\EOF
7750001-Second.patch
776(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
777(mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
778(mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
779Dry-OK. Log says:
780Server: relay.example.com
781MAIL FROM:<from@example.com>
782RCPT TO:<to@example.com>
783RCPT TO:<author@example.com>
784RCPT TO:<one@example.com>
785RCPT TO:<two@example.com>
786From: Example <from@example.com>
787To: to@example.com
788Cc: A <author@example.com>,
789 One <one@example.com>,
790 two@example.com
791Subject: [PATCH 1/1] Second.
792Date: DATE-STRING
793Message-Id: MESSAGE-ID-STRING
794X-Mailer: X-MAILER-STRING
795MIME-Version: 1.0
796Content-Transfer-Encoding: 8bit
797
798Result: OK
799EOF
800"
801
802test_expect_success $PREREQ '--suppress-cc=body --suppress-cc=cccmd' '
803 test_suppression body cccmd
804'
805
806test_expect_success $PREREQ 'setup expect' "
807cat >expected-suppress-sob <<\EOF
8080001-Second.patch
809(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
810(mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
811(mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
812Dry-OK. Log says:
813Server: relay.example.com
814MAIL FROM:<from@example.com>
815RCPT TO:<to@example.com>
816RCPT TO:<author@example.com>
817RCPT TO:<one@example.com>
818RCPT TO:<two@example.com>
819From: Example <from@example.com>
820To: to@example.com
821Cc: A <author@example.com>,
822 One <one@example.com>,
823 two@example.com
824Subject: [PATCH 1/1] Second.
825Date: DATE-STRING
826Message-Id: MESSAGE-ID-STRING
827X-Mailer: X-MAILER-STRING
828MIME-Version: 1.0
829Content-Transfer-Encoding: 8bit
830
831Result: OK
832EOF
833"
834
835test_expect_success $PREREQ '--suppress-cc=sob' '
836 test_might_fail git config --unset sendemail.cccmd &&
837 test_suppression sob
838'
839
840test_expect_success $PREREQ 'setup expect' "
841cat >expected-suppress-bodycc <<\EOF
8420001-Second.patch
843(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
844(mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
845(mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
846(body) Adding cc: C O Mitter <committer@example.com> from line 'Signed-off-by: C O Mitter <committer@example.com>'
847Dry-OK. Log says:
848Server: relay.example.com
849MAIL FROM:<from@example.com>
850RCPT TO:<to@example.com>
851RCPT TO:<author@example.com>
852RCPT TO:<one@example.com>
853RCPT TO:<two@example.com>
854RCPT TO:<committer@example.com>
855From: Example <from@example.com>
856To: to@example.com
857Cc: A <author@example.com>,
858 One <one@example.com>,
859 two@example.com,
860 C O Mitter <committer@example.com>
861Subject: [PATCH 1/1] Second.
862Date: DATE-STRING
863Message-Id: MESSAGE-ID-STRING
864X-Mailer: X-MAILER-STRING
865MIME-Version: 1.0
866Content-Transfer-Encoding: 8bit
867
868Result: OK
869EOF
870"
871
872test_expect_success $PREREQ '--suppress-cc=bodycc' '
873 test_suppression bodycc
874'
875
876test_expect_success $PREREQ 'setup expect' "
877cat >expected-suppress-cc <<\EOF
8780001-Second.patch
879(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
880(body) Adding cc: C O Mitter <committer@example.com> from line 'Signed-off-by: C O Mitter <committer@example.com>'
881Dry-OK. Log says:
882Server: relay.example.com
883MAIL FROM:<from@example.com>
884RCPT TO:<to@example.com>
885RCPT TO:<author@example.com>
886RCPT TO:<committer@example.com>
887From: Example <from@example.com>
888To: to@example.com
889Cc: A <author@example.com>,
890 C O Mitter <committer@example.com>
891Subject: [PATCH 1/1] Second.
892Date: DATE-STRING
893Message-Id: MESSAGE-ID-STRING
894X-Mailer: X-MAILER-STRING
895MIME-Version: 1.0
896Content-Transfer-Encoding: 8bit
897
898Result: OK
899EOF
900"
901
902test_expect_success $PREREQ '--suppress-cc=cc' '
903 test_suppression cc
904'
905
906test_confirm () {
907 echo y | \
908 GIT_SEND_EMAIL_NOTTY=1 \
909 git send-email \
910 --from="Example <nobody@example.com>" \
911 --to=nobody@example.com \
912 --smtp-server="$(pwd)/fake.sendmail" \
913 $@ $patches >stdout &&
914 grep "Send this email" stdout
915}
916
917test_expect_success $PREREQ '--confirm=always' '
918 test_confirm --confirm=always --suppress-cc=all
919'
920
921test_expect_success $PREREQ '--confirm=auto' '
922 test_confirm --confirm=auto
923'
924
925test_expect_success $PREREQ '--confirm=cc' '
926 test_confirm --confirm=cc
927'
928
929test_expect_success $PREREQ '--confirm=compose' '
930 test_confirm --confirm=compose --compose
931'
932
933test_expect_success $PREREQ 'confirm by default (due to cc)' '
934 test_when_finished git config sendemail.confirm never &&
935 git config --unset sendemail.confirm &&
936 test_confirm
937'
938
939test_expect_success $PREREQ 'confirm by default (due to --compose)' '
940 test_when_finished git config sendemail.confirm never &&
941 git config --unset sendemail.confirm &&
942 test_confirm --suppress-cc=all --compose
943'
944
945test_expect_success $PREREQ 'confirm detects EOF (inform assumes y)' '
946 test_when_finished git config sendemail.confirm never &&
947 git config --unset sendemail.confirm &&
948 rm -fr outdir &&
949 git format-patch -2 -o outdir &&
950 GIT_SEND_EMAIL_NOTTY=1 \
951 git send-email \
952 --from="Example <nobody@example.com>" \
953 --to=nobody@example.com \
954 --smtp-server="$(pwd)/fake.sendmail" \
955 outdir/*.patch </dev/null
956'
957
958test_expect_success $PREREQ 'confirm detects EOF (auto causes failure)' '
959 test_when_finished git config sendemail.confirm never &&
960 git config sendemail.confirm auto &&
961 GIT_SEND_EMAIL_NOTTY=1 &&
962 export GIT_SEND_EMAIL_NOTTY &&
963 test_must_fail git send-email \
964 --from="Example <nobody@example.com>" \
965 --to=nobody@example.com \
966 --smtp-server="$(pwd)/fake.sendmail" \
967 $patches </dev/null
968'
969
970test_expect_success $PREREQ 'confirm does not loop forever' '
971 test_when_finished git config sendemail.confirm never &&
972 git config sendemail.confirm auto &&
973 GIT_SEND_EMAIL_NOTTY=1 &&
974 export GIT_SEND_EMAIL_NOTTY &&
975 yes "bogus" | test_must_fail git send-email \
976 --from="Example <nobody@example.com>" \
977 --to=nobody@example.com \
978 --smtp-server="$(pwd)/fake.sendmail" \
979 $patches
980'
981
982test_expect_success $PREREQ 'utf8 Cc is rfc2047 encoded' '
983 clean_fake_sendmail &&
984 rm -fr outdir &&
985 git format-patch -1 -o outdir --cc="àéìöú <utf8@example.com>" &&
986 git send-email \
987 --from="Example <nobody@example.com>" \
988 --to=nobody@example.com \
989 --smtp-server="$(pwd)/fake.sendmail" \
990 outdir/*.patch &&
991 grep "^ " msgtxt1 |
992 grep "=?UTF-8?q?=C3=A0=C3=A9=C3=AC=C3=B6=C3=BA?= <utf8@example.com>"
993'
994
995test_expect_success $PREREQ '--compose adds MIME for utf8 body' '
996 clean_fake_sendmail &&
997 write_script fake-editor-utf8 <<-\EOF &&
998 echo "utf8 body: àéìöú" >>"$1"
999 EOF
1000 GIT_EDITOR="\"$(pwd)/fake-editor-utf8\"" \
1001 git send-email \
1002 --compose --subject foo \
1003 --from="Example <nobody@example.com>" \
1004 --to=nobody@example.com \
1005 --smtp-server="$(pwd)/fake.sendmail" \
1006 $patches &&
1007 grep "^utf8 body" msgtxt1 &&
1008 grep "^Content-Type: text/plain; charset=UTF-8" msgtxt1
1009'
1010
1011test_expect_success $PREREQ '--compose respects user mime type' '
1012 clean_fake_sendmail &&
1013 write_script fake-editor-utf8-mime <<-\EOF &&
1014 cat >"$1" <<-\EOM
1015 MIME-Version: 1.0
1016 Content-Type: text/plain; charset=iso-8859-1
1017 Content-Transfer-Encoding: 8bit
1018 Subject: foo
1019
1020 utf8 body: àéìöú
1021 EOM
1022 EOF
1023 GIT_EDITOR="\"$(pwd)/fake-editor-utf8-mime\"" \
1024 git send-email \
1025 --compose --subject foo \
1026 --from="Example <nobody@example.com>" \
1027 --to=nobody@example.com \
1028 --smtp-server="$(pwd)/fake.sendmail" \
1029 $patches &&
1030 grep "^utf8 body" msgtxt1 &&
1031 grep "^Content-Type: text/plain; charset=iso-8859-1" msgtxt1 &&
1032 ! grep "^Content-Type: text/plain; charset=UTF-8" msgtxt1
1033'
1034
1035test_expect_success $PREREQ '--compose adds MIME for utf8 subject' '
1036 clean_fake_sendmail &&
1037 GIT_EDITOR="\"$(pwd)/fake-editor\"" \
1038 git send-email \
1039 --compose --subject utf8-sübjëct \
1040 --from="Example <nobody@example.com>" \
1041 --to=nobody@example.com \
1042 --smtp-server="$(pwd)/fake.sendmail" \
1043 $patches &&
1044 grep "^fake edit" msgtxt1 &&
1045 grep "^Subject: =?UTF-8?q?utf8-s=C3=BCbj=C3=ABct?=" msgtxt1
1046'
1047
1048test_expect_success $PREREQ 'utf8 author is correctly passed on' '
1049 clean_fake_sendmail &&
1050 test_commit weird_author &&
1051 test_when_finished "git reset --hard HEAD^" &&
1052 git commit --amend --author "Füñný Nâmé <odd_?=mail@example.com>" &&
1053 git format-patch --stdout -1 >funny_name.patch &&
1054 git send-email --from="Example <nobody@example.com>" \
1055 --to=nobody@example.com \
1056 --smtp-server="$(pwd)/fake.sendmail" \
1057 funny_name.patch &&
1058 grep "^From: Füñný Nâmé <odd_?=mail@example.com>" msgtxt1
1059'
1060
1061test_expect_success $PREREQ 'utf8 sender is not duplicated' '
1062 clean_fake_sendmail &&
1063 test_commit weird_sender &&
1064 test_when_finished "git reset --hard HEAD^" &&
1065 git commit --amend --author "Füñný Nâmé <odd_?=mail@example.com>" &&
1066 git format-patch --stdout -1 >funny_name.patch &&
1067 git send-email --from="Füñný Nâmé <odd_?=mail@example.com>" \
1068 --to=nobody@example.com \
1069 --smtp-server="$(pwd)/fake.sendmail" \
1070 funny_name.patch &&
1071 grep "^From: " msgtxt1 >msgfrom &&
1072 test_line_count = 1 msgfrom
1073'
1074
1075test_expect_success $PREREQ 'sendemail.composeencoding works' '
1076 clean_fake_sendmail &&
1077 git config sendemail.composeencoding iso-8859-1 &&
1078 write_script fake-editor-utf8 <<-\EOF &&
1079 echo "utf8 body: àéìöú" >>"$1"
1080 EOF
1081 GIT_EDITOR="\"$(pwd)/fake-editor-utf8\"" \
1082 git send-email \
1083 --compose --subject foo \
1084 --from="Example <nobody@example.com>" \
1085 --to=nobody@example.com \
1086 --smtp-server="$(pwd)/fake.sendmail" \
1087 $patches &&
1088 grep "^utf8 body" msgtxt1 &&
1089 grep "^Content-Type: text/plain; charset=iso-8859-1" msgtxt1
1090'
1091
1092test_expect_success $PREREQ '--compose-encoding works' '
1093 clean_fake_sendmail &&
1094 write_script fake-editor-utf8 <<-\EOF &&
1095 echo "utf8 body: àéìöú" >>"$1"
1096 EOF
1097 GIT_EDITOR="\"$(pwd)/fake-editor-utf8\"" \
1098 git send-email \
1099 --compose-encoding iso-8859-1 \
1100 --compose --subject foo \
1101 --from="Example <nobody@example.com>" \
1102 --to=nobody@example.com \
1103 --smtp-server="$(pwd)/fake.sendmail" \
1104 $patches &&
1105 grep "^utf8 body" msgtxt1 &&
1106 grep "^Content-Type: text/plain; charset=iso-8859-1" msgtxt1
1107'
1108
1109test_expect_success $PREREQ '--compose-encoding overrides sendemail.composeencoding' '
1110 clean_fake_sendmail &&
1111 git config sendemail.composeencoding iso-8859-1 &&
1112 write_script fake-editor-utf8 <<-\EOF &&
1113 echo "utf8 body: àéìöú" >>"$1"
1114 EOF
1115 GIT_EDITOR="\"$(pwd)/fake-editor-utf8\"" \
1116 git send-email \
1117 --compose-encoding iso-8859-2 \
1118 --compose --subject foo \
1119 --from="Example <nobody@example.com>" \
1120 --to=nobody@example.com \
1121 --smtp-server="$(pwd)/fake.sendmail" \
1122 $patches &&
1123 grep "^utf8 body" msgtxt1 &&
1124 grep "^Content-Type: text/plain; charset=iso-8859-2" msgtxt1
1125'
1126
1127test_expect_success $PREREQ '--compose-encoding adds correct MIME for subject' '
1128 clean_fake_sendmail &&
1129 GIT_EDITOR="\"$(pwd)/fake-editor\"" \
1130 git send-email \
1131 --compose-encoding iso-8859-2 \
1132 --compose --subject utf8-sübjëct \
1133 --from="Example <nobody@example.com>" \
1134 --to=nobody@example.com \
1135 --smtp-server="$(pwd)/fake.sendmail" \
1136 $patches &&
1137 grep "^fake edit" msgtxt1 &&
1138 grep "^Subject: =?iso-8859-2?q?utf8-s=C3=BCbj=C3=ABct?=" msgtxt1
1139'
1140
1141test_expect_success $PREREQ 'detects ambiguous reference/file conflict' '
1142 echo master >master &&
1143 git add master &&
1144 git commit -m"add master" &&
1145 test_must_fail git send-email --dry-run master 2>errors &&
1146 grep disambiguate errors
1147'
1148
1149test_expect_success $PREREQ 'feed two files' '
1150 rm -fr outdir &&
1151 git format-patch -2 -o outdir &&
1152 git send-email \
1153 --dry-run \
1154 --from="Example <nobody@example.com>" \
1155 --to=nobody@example.com \
1156 outdir/000?-*.patch 2>errors >out &&
1157 grep "^Subject: " out >subjects &&
1158 test "z$(sed -n -e 1p subjects)" = "zSubject: [PATCH 1/2] Second." &&
1159 test "z$(sed -n -e 2p subjects)" = "zSubject: [PATCH 2/2] add master"
1160'
1161
1162test_expect_success $PREREQ 'in-reply-to but no threading' '
1163 git send-email \
1164 --dry-run \
1165 --from="Example <nobody@example.com>" \
1166 --to=nobody@example.com \
1167 --in-reply-to="<in-reply-id@example.com>" \
1168 --no-thread \
1169 $patches |
1170 grep "In-Reply-To: <in-reply-id@example.com>"
1171'
1172
1173test_expect_success $PREREQ 'no in-reply-to and no threading' '
1174 git send-email \
1175 --dry-run \
1176 --from="Example <nobody@example.com>" \
1177 --to=nobody@example.com \
1178 --no-thread \
1179 $patches >stdout &&
1180 ! grep "In-Reply-To: " stdout
1181'
1182
1183test_expect_success $PREREQ 'threading but no chain-reply-to' '
1184 git send-email \
1185 --dry-run \
1186 --from="Example <nobody@example.com>" \
1187 --to=nobody@example.com \
1188 --thread \
1189 --no-chain-reply-to \
1190 $patches $patches >stdout &&
1191 grep "In-Reply-To: " stdout
1192'
1193
1194test_expect_success $PREREQ 'sendemail.to works' '
1195 git config --replace-all sendemail.to "Somebody <somebody@ex.com>" &&
1196 git send-email \
1197 --dry-run \
1198 --from="Example <nobody@example.com>" \
1199 $patches >stdout &&
1200 grep "To: Somebody <somebody@ex.com>" stdout
1201'
1202
1203test_expect_success $PREREQ '--no-to overrides sendemail.to' '
1204 git send-email \
1205 --dry-run \
1206 --from="Example <nobody@example.com>" \
1207 --no-to \
1208 --to=nobody@example.com \
1209 $patches >stdout &&
1210 grep "To: nobody@example.com" stdout &&
1211 ! grep "To: Somebody <somebody@ex.com>" stdout
1212'
1213
1214test_expect_success $PREREQ 'sendemail.cc works' '
1215 git config --replace-all sendemail.cc "Somebody <somebody@ex.com>" &&
1216 git send-email \
1217 --dry-run \
1218 --from="Example <nobody@example.com>" \
1219 --to=nobody@example.com \
1220 $patches >stdout &&
1221 grep "Cc: Somebody <somebody@ex.com>" stdout
1222'
1223
1224test_expect_success $PREREQ '--no-cc overrides sendemail.cc' '
1225 git send-email \
1226 --dry-run \
1227 --from="Example <nobody@example.com>" \
1228 --no-cc \
1229 --cc=bodies@example.com \
1230 --to=nobody@example.com \
1231 $patches >stdout &&
1232 grep "Cc: bodies@example.com" stdout &&
1233 ! grep "Cc: Somebody <somebody@ex.com>" stdout
1234'
1235
1236test_expect_success $PREREQ 'sendemail.bcc works' '
1237 git config --replace-all sendemail.bcc "Other <other@ex.com>" &&
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 $patches >stdout &&
1244 grep "RCPT TO:<other@ex.com>" stdout
1245'
1246
1247test_expect_success $PREREQ '--no-bcc overrides sendemail.bcc' '
1248 git send-email \
1249 --dry-run \
1250 --from="Example <nobody@example.com>" \
1251 --no-bcc \
1252 --bcc=bodies@example.com \
1253 --to=nobody@example.com \
1254 --smtp-server relay.example.com \
1255 $patches >stdout &&
1256 grep "RCPT TO:<bodies@example.com>" stdout &&
1257 ! grep "RCPT TO:<other@ex.com>" stdout
1258'
1259
1260test_expect_success $PREREQ 'patches To headers are used by default' '
1261 patch=$(git format-patch -1 --to="bodies@example.com") &&
1262 test_when_finished "rm $patch" &&
1263 git send-email \
1264 --dry-run \
1265 --from="Example <nobody@example.com>" \
1266 --smtp-server relay.example.com \
1267 $patch >stdout &&
1268 grep "RCPT TO:<bodies@example.com>" stdout
1269'
1270
1271test_expect_success $PREREQ 'patches To headers are appended to' '
1272 patch=$(git format-patch -1 --to="bodies@example.com") &&
1273 test_when_finished "rm $patch" &&
1274 git send-email \
1275 --dry-run \
1276 --from="Example <nobody@example.com>" \
1277 --to=nobody@example.com \
1278 --smtp-server relay.example.com \
1279 $patch >stdout &&
1280 grep "RCPT TO:<bodies@example.com>" stdout &&
1281 grep "RCPT TO:<nobody@example.com>" stdout
1282'
1283
1284test_expect_success $PREREQ 'To headers from files reset each patch' '
1285 patch1=$(git format-patch -1 --to="bodies@example.com") &&
1286 patch2=$(git format-patch -1 --to="other@example.com" HEAD~) &&
1287 test_when_finished "rm $patch1 && rm $patch2" &&
1288 git send-email \
1289 --dry-run \
1290 --from="Example <nobody@example.com>" \
1291 --to="nobody@example.com" \
1292 --smtp-server relay.example.com \
1293 $patch1 $patch2 >stdout &&
1294 test $(grep -c "RCPT TO:<bodies@example.com>" stdout) = 1 &&
1295 test $(grep -c "RCPT TO:<nobody@example.com>" stdout) = 2 &&
1296 test $(grep -c "RCPT TO:<other@example.com>" stdout) = 1
1297'
1298
1299test_expect_success $PREREQ 'setup expect' '
1300cat >email-using-8bit <<\EOF
1301From fe6ecc66ece37198fe5db91fa2fc41d9f4fe5cc4 Mon Sep 17 00:00:00 2001
1302Message-Id: <bogus-message-id@example.com>
1303From: author@example.com
1304Date: Sat, 12 Jun 2010 15:53:58 +0200
1305Subject: subject goes here
1306
1307Dieser deutsche Text enthält einen Umlaut!
1308EOF
1309'
1310
1311test_expect_success $PREREQ 'setup expect' '
1312 echo "Subject: subject goes here" >expected
1313'
1314
1315test_expect_success $PREREQ 'ASCII subject is not RFC2047 quoted' '
1316 clean_fake_sendmail &&
1317 echo bogus |
1318 git send-email --from=author@example.com --to=nobody@example.com \
1319 --smtp-server="$(pwd)/fake.sendmail" \
1320 --8bit-encoding=UTF-8 \
1321 email-using-8bit >stdout &&
1322 grep "Subject" msgtxt1 >actual &&
1323 test_cmp expected actual
1324'
1325
1326test_expect_success $PREREQ 'setup expect' '
1327 cat >content-type-decl <<-\EOF
1328 MIME-Version: 1.0
1329 Content-Type: text/plain; charset=UTF-8
1330 Content-Transfer-Encoding: 8bit
1331 EOF
1332'
1333
1334test_expect_success $PREREQ 'asks about and fixes 8bit encodings' '
1335 clean_fake_sendmail &&
1336 echo |
1337 git send-email --from=author@example.com --to=nobody@example.com \
1338 --smtp-server="$(pwd)/fake.sendmail" \
1339 email-using-8bit >stdout &&
1340 grep "do not declare a Content-Transfer-Encoding" stdout &&
1341 grep email-using-8bit stdout &&
1342 grep "Which 8bit encoding" stdout &&
1343 egrep "Content|MIME" msgtxt1 >actual &&
1344 test_cmp content-type-decl actual
1345'
1346
1347test_expect_success $PREREQ 'sendemail.8bitEncoding works' '
1348 clean_fake_sendmail &&
1349 git config sendemail.assume8bitEncoding UTF-8 &&
1350 echo bogus |
1351 git send-email --from=author@example.com --to=nobody@example.com \
1352 --smtp-server="$(pwd)/fake.sendmail" \
1353 email-using-8bit >stdout &&
1354 egrep "Content|MIME" msgtxt1 >actual &&
1355 test_cmp content-type-decl actual
1356'
1357
1358test_expect_success $PREREQ '--8bit-encoding overrides sendemail.8bitEncoding' '
1359 clean_fake_sendmail &&
1360 git config sendemail.assume8bitEncoding "bogus too" &&
1361 echo bogus |
1362 git send-email --from=author@example.com --to=nobody@example.com \
1363 --smtp-server="$(pwd)/fake.sendmail" \
1364 --8bit-encoding=UTF-8 \
1365 email-using-8bit >stdout &&
1366 egrep "Content|MIME" msgtxt1 >actual &&
1367 test_cmp content-type-decl actual
1368'
1369
1370test_expect_success $PREREQ 'setup expect' '
1371 cat >email-using-8bit <<-\EOF
1372 From fe6ecc66ece37198fe5db91fa2fc41d9f4fe5cc4 Mon Sep 17 00:00:00 2001
1373 Message-Id: <bogus-message-id@example.com>
1374 From: author@example.com
1375 Date: Sat, 12 Jun 2010 15:53:58 +0200
1376 Subject: Dieser Betreff enthält auch einen Umlaut!
1377
1378 Nothing to see here.
1379 EOF
1380'
1381
1382test_expect_success $PREREQ 'setup expect' '
1383 cat >expected <<-\EOF
1384 Subject: =?UTF-8?q?Dieser=20Betreff=20enth=C3=A4lt=20auch=20einen=20Umlaut!?=
1385 EOF
1386'
1387
1388test_expect_success $PREREQ '--8bit-encoding also treats subject' '
1389 clean_fake_sendmail &&
1390 echo bogus |
1391 git send-email --from=author@example.com --to=nobody@example.com \
1392 --smtp-server="$(pwd)/fake.sendmail" \
1393 --8bit-encoding=UTF-8 \
1394 email-using-8bit >stdout &&
1395 grep "Subject" msgtxt1 >actual &&
1396 test_cmp expected actual
1397'
1398
1399test_expect_success $PREREQ 'setup expect' '
1400 cat >email-using-8bit <<-\EOF
1401 From fe6ecc66ece37198fe5db91fa2fc41d9f4fe5cc4 Mon Sep 17 00:00:00 2001
1402 Message-Id: <bogus-message-id@example.com>
1403 From: A U Thor <author@example.com>
1404 Date: Sat, 12 Jun 2010 15:53:58 +0200
1405 Content-Type: text/plain; charset=UTF-8
1406 Subject: Nothing to see here.
1407
1408 Dieser Betreff enthält auch einen Umlaut!
1409 EOF
1410'
1411
1412test_expect_success $PREREQ '--transfer-encoding overrides sendemail.transferEncoding' '
1413 clean_fake_sendmail &&
1414 test_must_fail git -c sendemail.transferEncoding=8bit \
1415 send-email \
1416 --transfer-encoding=7bit \
1417 --smtp-server="$(pwd)/fake.sendmail" \
1418 email-using-8bit \
1419 2>errors >out &&
1420 grep "cannot send message as 7bit" errors &&
1421 test -z "$(ls msgtxt*)"
1422'
1423
1424test_expect_success $PREREQ 'sendemail.transferEncoding via config' '
1425 clean_fake_sendmail &&
1426 test_must_fail git -c sendemail.transferEncoding=7bit \
1427 send-email \
1428 --smtp-server="$(pwd)/fake.sendmail" \
1429 email-using-8bit \
1430 2>errors >out &&
1431 grep "cannot send message as 7bit" errors &&
1432 test -z "$(ls msgtxt*)"
1433'
1434
1435test_expect_success $PREREQ 'sendemail.transferEncoding via cli' '
1436 clean_fake_sendmail &&
1437 test_must_fail git send-email \
1438 --transfer-encoding=7bit \
1439 --smtp-server="$(pwd)/fake.sendmail" \
1440 email-using-8bit \
1441 2>errors >out &&
1442 grep "cannot send message as 7bit" errors &&
1443 test -z "$(ls msgtxt*)"
1444'
1445
1446test_expect_success $PREREQ 'setup expect' '
1447 cat >expected <<-\EOF
1448 Dieser Betreff enth=C3=A4lt auch einen Umlaut!
1449 EOF
1450'
1451
1452test_expect_success $PREREQ '8-bit and sendemail.transferencoding=quoted-printable' '
1453 clean_fake_sendmail &&
1454 git send-email \
1455 --transfer-encoding=quoted-printable \
1456 --smtp-server="$(pwd)/fake.sendmail" \
1457 email-using-8bit \
1458 2>errors >out &&
1459 sed '1,/^$/d' msgtxt1 >actual &&
1460 test_cmp expected actual
1461'
1462
1463test_expect_success $PREREQ 'setup expect' '
1464 cat >expected <<-\EOF
1465 RGllc2VyIEJldHJlZmYgZW50aMOkbHQgYXVjaCBlaW5lbiBVbWxhdXQhCg==
1466 EOF
1467'
1468
1469test_expect_success $PREREQ '8-bit and sendemail.transferencoding=base64' '
1470 clean_fake_sendmail &&
1471 git send-email \
1472 --transfer-encoding=base64 \
1473 --smtp-server="$(pwd)/fake.sendmail" \
1474 email-using-8bit \
1475 2>errors >out &&
1476 sed '1,/^$/d' msgtxt1 >actual &&
1477 test_cmp expected actual
1478'
1479
1480test_expect_success $PREREQ 'setup expect' '
1481 cat >email-using-qp <<-\EOF
1482 From fe6ecc66ece37198fe5db91fa2fc41d9f4fe5cc4 Mon Sep 17 00:00:00 2001
1483 Message-Id: <bogus-message-id@example.com>
1484 From: A U Thor <author@example.com>
1485 Date: Sat, 12 Jun 2010 15:53:58 +0200
1486 MIME-Version: 1.0
1487 Content-Transfer-Encoding: quoted-printable
1488 Content-Type: text/plain; charset=UTF-8
1489 Subject: Nothing to see here.
1490
1491 Dieser Betreff enth=C3=A4lt auch einen Umlaut!
1492 EOF
1493'
1494
1495test_expect_success $PREREQ 'convert from quoted-printable to base64' '
1496 clean_fake_sendmail &&
1497 git send-email \
1498 --transfer-encoding=base64 \
1499 --smtp-server="$(pwd)/fake.sendmail" \
1500 email-using-qp \
1501 2>errors >out &&
1502 sed '1,/^$/d' msgtxt1 >actual &&
1503 test_cmp expected actual
1504'
1505
1506test_expect_success $PREREQ 'setup expect' "
1507tr -d '\\015' | tr '%' '\\015' >email-using-crlf <<EOF
1508From fe6ecc66ece37198fe5db91fa2fc41d9f4fe5cc4 Mon Sep 17 00:00:00 2001
1509Message-Id: <bogus-message-id@example.com>
1510From: A U Thor <author@example.com>
1511Date: Sat, 12 Jun 2010 15:53:58 +0200
1512Content-Type: text/plain; charset=UTF-8
1513Subject: Nothing to see here.
1514
1515Look, I have a CRLF and an = sign!%
1516EOF
1517"
1518
1519test_expect_success $PREREQ 'setup expect' '
1520 cat >expected <<-\EOF
1521 Look, I have a CRLF and an =3D sign!=0D
1522 EOF
1523'
1524
1525test_expect_success $PREREQ 'CRLF and sendemail.transferencoding=quoted-printable' '
1526 clean_fake_sendmail &&
1527 git send-email \
1528 --transfer-encoding=quoted-printable \
1529 --smtp-server="$(pwd)/fake.sendmail" \
1530 email-using-crlf \
1531 2>errors >out &&
1532 sed '1,/^$/d' msgtxt1 >actual &&
1533 test_cmp expected actual
1534'
1535
1536test_expect_success $PREREQ 'setup expect' '
1537 cat >expected <<-\EOF
1538 TG9vaywgSSBoYXZlIGEgQ1JMRiBhbmQgYW4gPSBzaWduIQ0K
1539 EOF
1540'
1541
1542test_expect_success $PREREQ 'CRLF and sendemail.transferencoding=base64' '
1543 clean_fake_sendmail &&
1544 git send-email \
1545 --transfer-encoding=base64 \
1546 --smtp-server="$(pwd)/fake.sendmail" \
1547 email-using-crlf \
1548 2>errors >out &&
1549 sed '1,/^$/d' msgtxt1 >actual &&
1550 test_cmp expected actual
1551'
1552
1553
1554# Note that the patches in this test are deliberately out of order; we
1555# want to make sure it works even if the cover-letter is not in the
1556# first mail.
1557test_expect_success $PREREQ 'refusing to send cover letter template' '
1558 clean_fake_sendmail &&
1559 rm -fr outdir &&
1560 git format-patch --cover-letter -2 -o outdir &&
1561 test_must_fail git send-email \
1562 --from="Example <nobody@example.com>" \
1563 --to=nobody@example.com \
1564 --smtp-server="$(pwd)/fake.sendmail" \
1565 outdir/0002-*.patch \
1566 outdir/0000-*.patch \
1567 outdir/0001-*.patch \
1568 2>errors >out &&
1569 grep "SUBJECT HERE" errors &&
1570 test -z "$(ls msgtxt*)"
1571'
1572
1573test_expect_success $PREREQ '--force sends cover letter template anyway' '
1574 clean_fake_sendmail &&
1575 rm -fr outdir &&
1576 git format-patch --cover-letter -2 -o outdir &&
1577 git send-email \
1578 --force \
1579 --from="Example <nobody@example.com>" \
1580 --to=nobody@example.com \
1581 --smtp-server="$(pwd)/fake.sendmail" \
1582 outdir/0002-*.patch \
1583 outdir/0000-*.patch \
1584 outdir/0001-*.patch \
1585 2>errors >out &&
1586 ! grep "SUBJECT HERE" errors &&
1587 test -n "$(ls msgtxt*)"
1588'
1589
1590test_cover_addresses () {
1591 header="$1"
1592 shift
1593 clean_fake_sendmail &&
1594 rm -fr outdir &&
1595 git format-patch --cover-letter -2 -o outdir &&
1596 cover=$(echo outdir/0000-*.patch) &&
1597 mv $cover cover-to-edit.patch &&
1598 perl -pe "s/^From:/$header: extra\@address.com\nFrom:/" cover-to-edit.patch >"$cover" &&
1599 git send-email \
1600 --force \
1601 --from="Example <nobody@example.com>" \
1602 --no-to --no-cc \
1603 "$@" \
1604 --smtp-server="$(pwd)/fake.sendmail" \
1605 outdir/0000-*.patch \
1606 outdir/0001-*.patch \
1607 outdir/0002-*.patch \
1608 2>errors >out &&
1609 grep "^$header: extra@address.com" msgtxt1 >to1 &&
1610 grep "^$header: extra@address.com" msgtxt2 >to2 &&
1611 grep "^$header: extra@address.com" msgtxt3 >to3 &&
1612 test_line_count = 1 to1 &&
1613 test_line_count = 1 to2 &&
1614 test_line_count = 1 to3
1615}
1616
1617test_expect_success $PREREQ 'to-cover adds To to all mail' '
1618 test_cover_addresses "To" --to-cover
1619'
1620
1621test_expect_success $PREREQ 'cc-cover adds Cc to all mail' '
1622 test_cover_addresses "Cc" --cc-cover
1623'
1624
1625test_expect_success $PREREQ 'tocover adds To to all mail' '
1626 test_config sendemail.tocover true &&
1627 test_cover_addresses "To"
1628'
1629
1630test_expect_success $PREREQ 'cccover adds Cc to all mail' '
1631 test_config sendemail.cccover true &&
1632 test_cover_addresses "Cc"
1633'
1634
1635test_expect_success $PREREQ 'escaped quotes in sendemail.aliasfiletype=mutt' '
1636 clean_fake_sendmail &&
1637 echo "alias sbd \\\"Dot U. Sir\\\" <somebody@example.org>" >.mutt &&
1638 git config --replace-all sendemail.aliasesfile "$(pwd)/.mutt" &&
1639 git config sendemail.aliasfiletype mutt &&
1640 git send-email \
1641 --from="Example <nobody@example.com>" \
1642 --to=sbd \
1643 --smtp-server="$(pwd)/fake.sendmail" \
1644 outdir/0001-*.patch \
1645 2>errors >out &&
1646 grep "^!somebody@example\.org!$" commandline1 &&
1647 grep -F "To: \"Dot U. Sir\" <somebody@example.org>" out
1648'
1649
1650test_expect_success $PREREQ 'sendemail.aliasfiletype=mailrc' '
1651 clean_fake_sendmail &&
1652 echo "alias sbd somebody@example.org" >.mailrc &&
1653 git config --replace-all sendemail.aliasesfile "$(pwd)/.mailrc" &&
1654 git config sendemail.aliasfiletype mailrc &&
1655 git send-email \
1656 --from="Example <nobody@example.com>" \
1657 --to=sbd \
1658 --smtp-server="$(pwd)/fake.sendmail" \
1659 outdir/0001-*.patch \
1660 2>errors >out &&
1661 grep "^!somebody@example\.org!$" commandline1
1662'
1663
1664test_expect_success $PREREQ 'sendemail.aliasfile=~/.mailrc' '
1665 clean_fake_sendmail &&
1666 echo "alias sbd someone@example.org" >"$HOME/.mailrc" &&
1667 git config --replace-all sendemail.aliasesfile "~/.mailrc" &&
1668 git config sendemail.aliasfiletype mailrc &&
1669 git send-email \
1670 --from="Example <nobody@example.com>" \
1671 --to=sbd \
1672 --smtp-server="$(pwd)/fake.sendmail" \
1673 outdir/0001-*.patch \
1674 2>errors >out &&
1675 grep "^!someone@example\.org!$" commandline1
1676'
1677
1678test_dump_aliases () {
1679 msg="$1" && shift &&
1680 filetype="$1" && shift &&
1681 printf '%s\n' "$@" >expect &&
1682 cat >.tmp-email-aliases &&
1683
1684 test_expect_success $PREREQ "$msg" '
1685 clean_fake_sendmail && rm -fr outdir &&
1686 git config --replace-all sendemail.aliasesfile \
1687 "$(pwd)/.tmp-email-aliases" &&
1688 git config sendemail.aliasfiletype "$filetype" &&
1689 git send-email --dump-aliases 2>errors >actual &&
1690 test_cmp expect actual
1691 '
1692}
1693
1694test_dump_aliases '--dump-aliases sendmail format' \
1695 'sendmail' \
1696 'abgroup' \
1697 'alice' \
1698 'bcgrp' \
1699 'bob' \
1700 'chloe' <<-\EOF
1701 alice: Alice W Land <awol@example.com>
1702 bob: Robert Bobbyton <bob@example.com>
1703 chloe: chloe@example.com
1704 abgroup: alice, bob
1705 bcgrp: bob, chloe, Other <o@example.com>
1706 EOF
1707
1708test_dump_aliases '--dump-aliases mutt format' \
1709 'mutt' \
1710 'alice' \
1711 'bob' \
1712 'chloe' \
1713 'donald' <<-\EOF
1714 alias alice Alice W Land <awol@example.com>
1715 alias donald Donald C Carlton <donc@example.com>
1716 alias bob Robert Bobbyton <bob@example.com>
1717 alias chloe chloe@example.com
1718 EOF
1719
1720test_dump_aliases '--dump-aliases mailrc format' \
1721 'mailrc' \
1722 'alice' \
1723 'bob' \
1724 'chloe' \
1725 'eve' <<-\EOF
1726 alias alice Alice W Land <awol@example.com>
1727 alias eve Eve <eve@example.com>
1728 alias bob Robert Bobbyton <bob@example.com>
1729 alias chloe chloe@example.com
1730 EOF
1731
1732test_dump_aliases '--dump-aliases pine format' \
1733 'pine' \
1734 'alice' \
1735 'bob' \
1736 'chloe' \
1737 'eve' <<-\EOF
1738 alice Alice W Land <awol@example.com>
1739 eve Eve <eve@example.com>
1740 bob Robert Bobbyton <bob@example.com>
1741 chloe chloe@example.com
1742 EOF
1743
1744test_dump_aliases '--dump-aliases gnus format' \
1745 'gnus' \
1746 'alice' \
1747 'bob' \
1748 'chloe' \
1749 'eve' <<-\EOF
1750 (define-mail-alias "alice" "awol@example.com")
1751 (define-mail-alias "eve" "eve@example.com")
1752 (define-mail-alias "bob" "bob@example.com")
1753 (define-mail-alias "chloe" "chloe@example.com")
1754 EOF
1755
1756test_expect_success '--dump-aliases must be used alone' '
1757 test_must_fail git send-email --dump-aliases --to=janice@example.com -1 refs/heads/accounting
1758'
1759
1760test_sendmail_aliases () {
1761 msg="$1" && shift &&
1762 expect="$@" &&
1763 cat >.tmp-email-aliases &&
1764
1765 test_expect_success $PREREQ "$msg" '
1766 clean_fake_sendmail && rm -fr outdir &&
1767 git format-patch -1 -o outdir &&
1768 git config --replace-all sendemail.aliasesfile \
1769 "$(pwd)/.tmp-email-aliases" &&
1770 git config sendemail.aliasfiletype sendmail &&
1771 git send-email \
1772 --from="Example <nobody@example.com>" \
1773 --to=alice --to=bcgrp \
1774 --smtp-server="$(pwd)/fake.sendmail" \
1775 outdir/0001-*.patch \
1776 2>errors >out &&
1777 for i in $expect
1778 do
1779 grep "^!$i!$" commandline1 || return 1
1780 done
1781 '
1782}
1783
1784test_sendmail_aliases 'sendemail.aliasfiletype=sendmail' \
1785 'awol@example\.com' \
1786 'bob@example\.com' \
1787 'chloe@example\.com' \
1788 'o@example\.com' <<-\EOF
1789 alice: Alice W Land <awol@example.com>
1790 bob: Robert Bobbyton <bob@example.com>
1791 # this is a comment
1792 # this is also a comment
1793 chloe: chloe@example.com
1794 abgroup: alice, bob
1795 bcgrp: bob, chloe, Other <o@example.com>
1796 EOF
1797
1798test_sendmail_aliases 'sendmail aliases line folding' \
1799 alice1 \
1800 bob1 bob2 \
1801 chuck1 chuck2 \
1802 darla1 darla2 darla3 \
1803 elton1 elton2 elton3 \
1804 fred1 fred2 \
1805 greg1 <<-\EOF
1806 alice: alice1
1807 bob: bob1,\
1808 bob2
1809 chuck: chuck1,
1810 chuck2
1811 darla: darla1,\
1812 darla2,
1813 darla3
1814 elton: elton1,
1815 elton2,\
1816 elton3
1817 fred: fred1,\
1818 fred2
1819 greg: greg1
1820 bcgrp: bob, chuck, darla, elton, fred, greg
1821 EOF
1822
1823test_sendmail_aliases 'sendmail aliases tolerate bogus line folding' \
1824 alice1 bob1 <<-\EOF
1825 alice: alice1
1826 bcgrp: bob1\
1827 EOF
1828
1829test_sendmail_aliases 'sendmail aliases empty' alice bcgrp <<-\EOF
1830 EOF
1831
1832test_expect_success $PREREQ 'alias support in To header' '
1833 clean_fake_sendmail &&
1834 echo "alias sbd someone@example.org" >.mailrc &&
1835 test_config sendemail.aliasesfile ".mailrc" &&
1836 test_config sendemail.aliasfiletype mailrc &&
1837 git format-patch --stdout -1 --to=sbd >aliased.patch &&
1838 git send-email \
1839 --from="Example <nobody@example.com>" \
1840 --smtp-server="$(pwd)/fake.sendmail" \
1841 aliased.patch \
1842 2>errors >out &&
1843 grep "^!someone@example\.org!$" commandline1
1844'
1845
1846test_expect_success $PREREQ 'alias support in Cc header' '
1847 clean_fake_sendmail &&
1848 echo "alias sbd someone@example.org" >.mailrc &&
1849 test_config sendemail.aliasesfile ".mailrc" &&
1850 test_config sendemail.aliasfiletype mailrc &&
1851 git format-patch --stdout -1 --cc=sbd >aliased.patch &&
1852 git send-email \
1853 --from="Example <nobody@example.com>" \
1854 --smtp-server="$(pwd)/fake.sendmail" \
1855 aliased.patch \
1856 2>errors >out &&
1857 grep "^!someone@example\.org!$" commandline1
1858'
1859
1860test_expect_success $PREREQ 'tocmd works with aliases' '
1861 clean_fake_sendmail &&
1862 echo "alias sbd someone@example.org" >.mailrc &&
1863 test_config sendemail.aliasesfile ".mailrc" &&
1864 test_config sendemail.aliasfiletype mailrc &&
1865 git format-patch --stdout -1 >tocmd.patch &&
1866 echo tocmd--sbd >>tocmd.patch &&
1867 git send-email \
1868 --from="Example <nobody@example.com>" \
1869 --to-cmd=./tocmd-sed \
1870 --smtp-server="$(pwd)/fake.sendmail" \
1871 tocmd.patch \
1872 2>errors >out &&
1873 grep "^!someone@example\.org!$" commandline1
1874'
1875
1876test_expect_success $PREREQ 'cccmd works with aliases' '
1877 clean_fake_sendmail &&
1878 echo "alias sbd someone@example.org" >.mailrc &&
1879 test_config sendemail.aliasesfile ".mailrc" &&
1880 test_config sendemail.aliasfiletype mailrc &&
1881 git format-patch --stdout -1 >cccmd.patch &&
1882 echo cccmd--sbd >>cccmd.patch &&
1883 git send-email \
1884 --from="Example <nobody@example.com>" \
1885 --cc-cmd=./cccmd-sed \
1886 --smtp-server="$(pwd)/fake.sendmail" \
1887 cccmd.patch \
1888 2>errors >out &&
1889 grep "^!someone@example\.org!$" commandline1
1890'
1891
1892do_xmailer_test () {
1893 expected=$1 params=$2 &&
1894 git format-patch -1 &&
1895 git send-email \
1896 --from="Example <nobody@example.com>" \
1897 --to=someone@example.com \
1898 --smtp-server="$(pwd)/fake.sendmail" \
1899 $params \
1900 0001-*.patch \
1901 2>errors >out &&
1902 { grep '^X-Mailer:' out || :; } >mailer &&
1903 test_line_count = $expected mailer
1904}
1905
1906test_expect_success $PREREQ '--[no-]xmailer without any configuration' '
1907 do_xmailer_test 1 "--xmailer" &&
1908 do_xmailer_test 0 "--no-xmailer"
1909'
1910
1911test_expect_success $PREREQ '--[no-]xmailer with sendemail.xmailer=true' '
1912 test_config sendemail.xmailer true &&
1913 do_xmailer_test 1 "" &&
1914 do_xmailer_test 0 "--no-xmailer" &&
1915 do_xmailer_test 1 "--xmailer"
1916'
1917
1918test_expect_success $PREREQ '--[no-]xmailer with sendemail.xmailer=false' '
1919 test_config sendemail.xmailer false &&
1920 do_xmailer_test 0 "" &&
1921 do_xmailer_test 0 "--no-xmailer" &&
1922 do_xmailer_test 1 "--xmailer"
1923'
1924
1925test_expect_success $PREREQ 'setup expected-list' '
1926 git send-email \
1927 --dry-run \
1928 --from="Example <from@example.com>" \
1929 --to="To 1 <to1@example.com>" \
1930 --to="to2@example.com" \
1931 --to="to3@example.com" \
1932 --cc="Cc 1 <cc1@example.com>" \
1933 --cc="Cc2 <cc2@example.com>" \
1934 --bcc="bcc1@example.com" \
1935 --bcc="bcc2@example.com" \
1936 0001-add-master.patch | replace_variable_fields \
1937 >expected-list
1938'
1939
1940test_expect_success $PREREQ 'use email list in --cc --to and --bcc' '
1941 git send-email \
1942 --dry-run \
1943 --from="Example <from@example.com>" \
1944 --to="To 1 <to1@example.com>, to2@example.com" \
1945 --to="to3@example.com" \
1946 --cc="Cc 1 <cc1@example.com>, Cc2 <cc2@example.com>" \
1947 --bcc="bcc1@example.com, bcc2@example.com" \
1948 0001-add-master.patch | replace_variable_fields \
1949 >actual-list &&
1950 test_cmp expected-list actual-list
1951'
1952
1953test_expect_success $PREREQ 'aliases work with email list' '
1954 echo "alias to2 to2@example.com" >.mutt &&
1955 echo "alias cc1 Cc 1 <cc1@example.com>" >>.mutt &&
1956 test_config sendemail.aliasesfile ".mutt" &&
1957 test_config sendemail.aliasfiletype mutt &&
1958 git send-email \
1959 --dry-run \
1960 --from="Example <from@example.com>" \
1961 --to="To 1 <to1@example.com>, to2, to3@example.com" \
1962 --cc="cc1, Cc2 <cc2@example.com>" \
1963 --bcc="bcc1@example.com, bcc2@example.com" \
1964 0001-add-master.patch | replace_variable_fields \
1965 >actual-list &&
1966 test_cmp expected-list actual-list
1967'
1968
1969test_expect_success $PREREQ 'leading and trailing whitespaces are removed' '
1970 echo "alias to2 to2@example.com" >.mutt &&
1971 echo "alias cc1 Cc 1 <cc1@example.com>" >>.mutt &&
1972 test_config sendemail.aliasesfile ".mutt" &&
1973 test_config sendemail.aliasfiletype mutt &&
1974 TO1=$(echo "QTo 1 <to1@example.com>" | q_to_tab) &&
1975 TO2=$(echo "QZto2" | qz_to_tab_space) &&
1976 CC1=$(echo "cc1" | append_cr) &&
1977 BCC1=$(echo "Q bcc1@example.com Q" | q_to_nul) &&
1978 git send-email \
1979 --dry-run \
1980 --from=" Example <from@example.com>" \
1981 --to="$TO1" \
1982 --to="$TO2" \
1983 --to=" to3@example.com " \
1984 --cc="$CC1" \
1985 --cc="Cc2 <cc2@example.com>" \
1986 --bcc="$BCC1" \
1987 --bcc="bcc2@example.com" \
1988 0001-add-master.patch | replace_variable_fields \
1989 >actual-list &&
1990 test_cmp expected-list actual-list
1991'
1992
1993test_expect_success $PREREQ 'invoke hook' '
1994 mkdir -p .git/hooks &&
1995
1996 write_script .git/hooks/sendemail-validate <<-\EOF &&
1997 # test that we have the correct environment variable, pwd, and
1998 # argument
1999 case "$GIT_DIR" in
2000 *.git)
2001 true
2002 ;;
2003 *)
2004 false
2005 ;;
2006 esac &&
2007 test -f 0001-add-master.patch &&
2008 grep "add master" "$1"
2009 EOF
2010
2011 mkdir subdir &&
2012 (
2013 # Test that it works even if we are not at the root of the
2014 # working tree
2015 cd subdir &&
2016 git send-email \
2017 --from="Example <nobody@example.com>" \
2018 --to=nobody@example.com \
2019 --smtp-server="$(pwd)/../fake.sendmail" \
2020 ../0001-add-master.patch &&
2021
2022 # Verify error message when a patch is rejected by the hook
2023 sed -e "s/add master/x/" ../0001-add-master.patch >../another.patch &&
2024 git send-email \
2025 --from="Example <nobody@example.com>" \
2026 --to=nobody@example.com \
2027 --smtp-server="$(pwd)/../fake.sendmail" \
2028 ../another.patch 2>err
2029 test_i18ngrep "rejected by sendemail-validate hook" err
2030 )
2031'
2032
2033test_expect_success $PREREQ 'test that send-email works outside a repo' '
2034 nongit git send-email \
2035 --from="Example <nobody@example.com>" \
2036 --to=nobody@example.com \
2037 --smtp-server="$(pwd)/fake.sendmail" \
2038 "$(pwd)/0001-add-master.patch"
2039'
2040
2041test_done