git-bisect: call the found commit "*the* first bad commit"
[git] / t / t9001-send-email.sh
1 #!/bin/sh
2
3 test_description='git send-email'
4 . ./test-lib.sh
5
6 if ! test_have_prereq PERL; then
7         say 'skipping git send-email tests, perl not available'
8         test_done
9 fi
10
11 PROG='git send-email'
12 test_expect_success \
13     'prepare reference tree' \
14     'echo "1A quick brown fox jumps over the" >file &&
15      echo "lazy dog" >>file &&
16      git add file &&
17      GIT_AUTHOR_NAME="A" git commit -a -m "Initial."'
18
19 test_expect_success \
20     'Setup helper tool' \
21     '(echo "#!$SHELL_PATH"
22       echo shift
23       echo output=1
24       echo "while test -f commandline\$output; do output=\$((\$output+1)); done"
25       echo for a
26       echo do
27       echo "  echo \"!\$a!\""
28       echo "done >commandline\$output"
29       echo "cat > msgtxt\$output"
30       ) >fake.sendmail &&
31      chmod +x ./fake.sendmail &&
32      git add fake.sendmail &&
33      GIT_AUTHOR_NAME="A" git commit -a -m "Second."'
34
35 clean_fake_sendmail() {
36         rm -f commandline* msgtxt*
37 }
38
39 test_expect_success 'Extract patches' '
40     patches=`git format-patch -s --cc="One <one@example.com>" --cc=two@example.com -n HEAD^1`
41 '
42
43 # Test no confirm early to ensure remaining tests will not hang
44 test_no_confirm () {
45         rm -f no_confirm_okay
46         echo n | \
47                 GIT_SEND_EMAIL_NOTTY=1 \
48                 git send-email \
49                 --from="Example <from@example.com>" \
50                 --to=nobody@example.com \
51                 --smtp-server="$(pwd)/fake.sendmail" \
52                 $@ \
53                 $patches > stdout &&
54                 test_must_fail grep "Send this email" stdout &&
55                 > no_confirm_okay
56 }
57
58 # Exit immediately to prevent hang if a no-confirm test fails
59 check_no_confirm () {
60         test -f no_confirm_okay || {
61                 say 'No confirm test failed; skipping remaining tests to prevent hanging'
62                 test_done
63         }
64 }
65
66 test_expect_success 'No confirm with --suppress-cc' '
67         test_no_confirm --suppress-cc=sob
68 '
69 check_no_confirm
70
71 test_expect_success 'No confirm with --confirm=never' '
72         test_no_confirm --confirm=never
73 '
74 check_no_confirm
75
76 # leave sendemail.confirm set to never after this so that none of the
77 # remaining tests prompt unintentionally.
78 test_expect_success 'No confirm with sendemail.confirm=never' '
79         git config sendemail.confirm never &&
80         test_no_confirm --compose --subject=foo
81 '
82 check_no_confirm
83
84 test_expect_success '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
88 cat >expected <<\EOF
89 !nobody@example.com!
90 !author@example.com!
91 !one@example.com!
92 !two@example.com!
93 EOF
94 test_expect_success \
95     'Verify commandline' \
96     'test_cmp expected commandline1'
97
98 cat >expected-show-all-headers <<\EOF
99 0001-Second.patch
100 (mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
101 (mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
102 (mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
103 Dry-OK. Log says:
104 Server: relay.example.com
105 MAIL FROM:<from@example.com>
106 RCPT TO:<to@example.com>,<cc@example.com>,<author@example.com>,<one@example.com>,<two@example.com>,<bcc@example.com>
107 From: Example <from@example.com>
108 To: to@example.com
109 Cc: cc@example.com, A <author@example.com>, One <one@example.com>, two@example.com
110 Subject: [PATCH 1/1] Second.
111 Date: DATE-STRING
112 Message-Id: MESSAGE-ID-STRING
113 X-Mailer: X-MAILER-STRING
114 In-Reply-To: <unique-message-id@example.com>
115 References: <unique-message-id@example.com>
116
117 Result: OK
118 EOF
119
120 test_expect_success 'Show all headers' '
121         git send-email \
122                 --dry-run \
123                 --suppress-cc=sob \
124                 --from="Example <from@example.com>" \
125                 --to=to@example.com \
126                 --cc=cc@example.com \
127                 --bcc=bcc@example.com \
128                 --in-reply-to="<unique-message-id@example.com>" \
129                 --smtp-server relay.example.com \
130                 $patches |
131         sed     -e "s/^\(Date:\).*/\1 DATE-STRING/" \
132                 -e "s/^\(Message-Id:\).*/\1 MESSAGE-ID-STRING/" \
133                 -e "s/^\(X-Mailer:\).*/\1 X-MAILER-STRING/" \
134                 >actual-show-all-headers &&
135         test_cmp expected-show-all-headers actual-show-all-headers
136 '
137
138 test_expect_success 'Prompting works' '
139         clean_fake_sendmail &&
140         (echo "Example <from@example.com>"
141          echo "to@example.com"
142          echo ""
143         ) | GIT_SEND_EMAIL_NOTTY=1 git send-email \
144                 --smtp-server="$(pwd)/fake.sendmail" \
145                 $patches \
146                 2>errors &&
147                 grep "^From: Example <from@example.com>$" msgtxt1 &&
148                 grep "^To: to@example.com$" msgtxt1
149 '
150
151 test_expect_success 'cccmd works' '
152         clean_fake_sendmail &&
153         cp $patches cccmd.patch &&
154         echo cccmd--cccmd@example.com >>cccmd.patch &&
155         {
156           echo "#!$SHELL_PATH"
157           echo sed -n -e s/^cccmd--//p \"\$1\"
158         } > cccmd-sed &&
159         chmod +x cccmd-sed &&
160         git send-email \
161                 --from="Example <nobody@example.com>" \
162                 --to=nobody@example.com \
163                 --cc-cmd=./cccmd-sed \
164                 --smtp-server="$(pwd)/fake.sendmail" \
165                 cccmd.patch \
166                 &&
167         grep ^Cc:.*cccmd@example.com msgtxt1
168 '
169
170 z8=zzzzzzzz
171 z64=$z8$z8$z8$z8$z8$z8$z8$z8
172 z512=$z64$z64$z64$z64$z64$z64$z64$z64
173 test_expect_success 'reject long lines' '
174         clean_fake_sendmail &&
175         cp $patches longline.patch &&
176         echo $z512$z512 >>longline.patch &&
177         test_must_fail git send-email \
178                 --from="Example <nobody@example.com>" \
179                 --to=nobody@example.com \
180                 --smtp-server="$(pwd)/fake.sendmail" \
181                 $patches longline.patch \
182                 2>errors &&
183         grep longline.patch errors
184 '
185
186 test_expect_success 'no patch was sent' '
187         ! test -e commandline1
188 '
189
190 test_expect_success 'Author From: in message body' '
191         clean_fake_sendmail &&
192         git send-email \
193                 --from="Example <nobody@example.com>" \
194                 --to=nobody@example.com \
195                 --smtp-server="$(pwd)/fake.sendmail" \
196                 $patches &&
197         sed "1,/^$/d" < msgtxt1 > msgbody1
198         grep "From: A <author@example.com>" msgbody1
199 '
200
201 test_expect_success 'Author From: not in message body' '
202         clean_fake_sendmail &&
203         git send-email \
204                 --from="A <author@example.com>" \
205                 --to=nobody@example.com \
206                 --smtp-server="$(pwd)/fake.sendmail" \
207                 $patches &&
208         sed "1,/^$/d" < msgtxt1 > msgbody1
209         ! grep "From: A <author@example.com>" msgbody1
210 '
211
212 test_expect_success 'allow long lines with --no-validate' '
213         git send-email \
214                 --from="Example <nobody@example.com>" \
215                 --to=nobody@example.com \
216                 --smtp-server="$(pwd)/fake.sendmail" \
217                 --novalidate \
218                 $patches longline.patch \
219                 2>errors
220 '
221
222 test_expect_success 'Invalid In-Reply-To' '
223         clean_fake_sendmail &&
224         git send-email \
225                 --from="Example <nobody@example.com>" \
226                 --to=nobody@example.com \
227                 --in-reply-to=" " \
228                 --smtp-server="$(pwd)/fake.sendmail" \
229                 $patches
230                 2>errors
231         ! grep "^In-Reply-To: < *>" msgtxt1
232 '
233
234 test_expect_success 'Valid In-Reply-To when prompting' '
235         clean_fake_sendmail &&
236         (echo "From Example <from@example.com>"
237          echo "To Example <to@example.com>"
238          echo ""
239         ) | env GIT_SEND_EMAIL_NOTTY=1 git send-email \
240                 --smtp-server="$(pwd)/fake.sendmail" \
241                 $patches 2>errors &&
242         ! grep "^In-Reply-To: < *>" msgtxt1
243 '
244
245 test_expect_success 'setup fake editor' '
246         (echo "#!$SHELL_PATH" &&
247          echo "echo fake edit >>\"\$1\""
248         ) >fake-editor &&
249         chmod +x fake-editor
250 '
251
252 test_set_editor "$(pwd)/fake-editor"
253
254 test_expect_success '--compose works' '
255         clean_fake_sendmail &&
256         git send-email \
257         --compose --subject foo \
258         --from="Example <nobody@example.com>" \
259         --to=nobody@example.com \
260         --smtp-server="$(pwd)/fake.sendmail" \
261         $patches \
262         2>errors
263 '
264
265 test_expect_success 'first message is compose text' '
266         grep "^fake edit" msgtxt1
267 '
268
269 test_expect_success 'second message is patch' '
270         grep "Subject:.*Second" msgtxt2
271 '
272
273 cat >expected-suppress-sob <<\EOF
274 0001-Second.patch
275 (mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
276 (mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
277 (mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
278 Dry-OK. Log says:
279 Server: relay.example.com
280 MAIL FROM:<from@example.com>
281 RCPT TO:<to@example.com>,<cc@example.com>,<author@example.com>,<one@example.com>,<two@example.com>
282 From: Example <from@example.com>
283 To: to@example.com
284 Cc: cc@example.com, A <author@example.com>, One <one@example.com>, two@example.com
285 Subject: [PATCH 1/1] Second.
286 Date: DATE-STRING
287 Message-Id: MESSAGE-ID-STRING
288 X-Mailer: X-MAILER-STRING
289
290 Result: OK
291 EOF
292
293 test_suppression () {
294         git send-email \
295                 --dry-run \
296                 --suppress-cc=$1 ${2+"--suppress-cc=$2"} \
297                 --from="Example <from@example.com>" \
298                 --to=to@example.com \
299                 --smtp-server relay.example.com \
300                 $patches |
301         sed     -e "s/^\(Date:\).*/\1 DATE-STRING/" \
302                 -e "s/^\(Message-Id:\).*/\1 MESSAGE-ID-STRING/" \
303                 -e "s/^\(X-Mailer:\).*/\1 X-MAILER-STRING/" \
304                 >actual-suppress-$1${2+"-$2"} &&
305         test_cmp expected-suppress-$1${2+"-$2"} actual-suppress-$1${2+"-$2"}
306 }
307
308 test_expect_success 'sendemail.cc set' '
309         git config sendemail.cc cc@example.com &&
310         test_suppression sob
311 '
312
313 cat >expected-suppress-sob <<\EOF
314 0001-Second.patch
315 (mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
316 (mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
317 (mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
318 Dry-OK. Log says:
319 Server: relay.example.com
320 MAIL FROM:<from@example.com>
321 RCPT TO:<to@example.com>,<author@example.com>,<one@example.com>,<two@example.com>
322 From: Example <from@example.com>
323 To: to@example.com
324 Cc: A <author@example.com>, One <one@example.com>, two@example.com
325 Subject: [PATCH 1/1] Second.
326 Date: DATE-STRING
327 Message-Id: MESSAGE-ID-STRING
328 X-Mailer: X-MAILER-STRING
329
330 Result: OK
331 EOF
332
333 test_expect_success 'sendemail.cc unset' '
334         git config --unset sendemail.cc &&
335         test_suppression sob
336 '
337
338 cat >expected-suppress-cccmd <<\EOF
339 0001-Second.patch
340 (mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
341 (mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
342 (mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
343 (body) Adding cc: C O Mitter <committer@example.com> from line 'Signed-off-by: C O Mitter <committer@example.com>'
344 Dry-OK. Log says:
345 Server: relay.example.com
346 MAIL FROM:<from@example.com>
347 RCPT TO:<to@example.com>,<author@example.com>,<one@example.com>,<two@example.com>,<committer@example.com>
348 From: Example <from@example.com>
349 To: to@example.com
350 Cc: A <author@example.com>, One <one@example.com>, two@example.com, C O Mitter <committer@example.com>
351 Subject: [PATCH 1/1] Second.
352 Date: DATE-STRING
353 Message-Id: MESSAGE-ID-STRING
354 X-Mailer: X-MAILER-STRING
355
356 Result: OK
357 EOF
358
359 test_expect_success 'sendemail.cccmd' '
360         echo echo cc-cmd@example.com > cccmd &&
361         chmod +x cccmd &&
362         git config sendemail.cccmd ./cccmd &&
363         test_suppression cccmd
364 '
365
366 cat >expected-suppress-all <<\EOF
367 0001-Second.patch
368 Dry-OK. Log says:
369 Server: relay.example.com
370 MAIL FROM:<from@example.com>
371 RCPT TO:<to@example.com>
372 From: Example <from@example.com>
373 To: to@example.com
374 Subject: [PATCH 1/1] Second.
375 Date: DATE-STRING
376 Message-Id: MESSAGE-ID-STRING
377 X-Mailer: X-MAILER-STRING
378
379 Result: OK
380 EOF
381
382 test_expect_success '--suppress-cc=all' '
383         test_suppression all
384 '
385
386 cat >expected-suppress-body <<\EOF
387 0001-Second.patch
388 (mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
389 (mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
390 (mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
391 (cc-cmd) Adding cc: cc-cmd@example.com from: './cccmd'
392 Dry-OK. Log says:
393 Server: relay.example.com
394 MAIL FROM:<from@example.com>
395 RCPT TO:<to@example.com>,<author@example.com>,<one@example.com>,<two@example.com>,<cc-cmd@example.com>
396 From: Example <from@example.com>
397 To: to@example.com
398 Cc: A <author@example.com>, One <one@example.com>, two@example.com, cc-cmd@example.com
399 Subject: [PATCH 1/1] Second.
400 Date: DATE-STRING
401 Message-Id: MESSAGE-ID-STRING
402 X-Mailer: X-MAILER-STRING
403
404 Result: OK
405 EOF
406
407 test_expect_success '--suppress-cc=body' '
408         test_suppression body
409 '
410
411 cat >expected-suppress-body-cccmd <<\EOF
412 0001-Second.patch
413 (mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
414 (mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
415 (mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
416 Dry-OK. Log says:
417 Server: relay.example.com
418 MAIL FROM:<from@example.com>
419 RCPT TO:<to@example.com>,<author@example.com>,<one@example.com>,<two@example.com>
420 From: Example <from@example.com>
421 To: to@example.com
422 Cc: A <author@example.com>, One <one@example.com>, two@example.com
423 Subject: [PATCH 1/1] Second.
424 Date: DATE-STRING
425 Message-Id: MESSAGE-ID-STRING
426 X-Mailer: X-MAILER-STRING
427
428 Result: OK
429 EOF
430
431 test_expect_success '--suppress-cc=body --suppress-cc=cccmd' '
432         test_suppression body cccmd
433 '
434
435 cat >expected-suppress-sob <<\EOF
436 0001-Second.patch
437 (mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
438 (mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
439 (mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
440 Dry-OK. Log says:
441 Server: relay.example.com
442 MAIL FROM:<from@example.com>
443 RCPT TO:<to@example.com>,<author@example.com>,<one@example.com>,<two@example.com>
444 From: Example <from@example.com>
445 To: to@example.com
446 Cc: A <author@example.com>, One <one@example.com>, two@example.com
447 Subject: [PATCH 1/1] Second.
448 Date: DATE-STRING
449 Message-Id: MESSAGE-ID-STRING
450 X-Mailer: X-MAILER-STRING
451
452 Result: OK
453 EOF
454
455 test_expect_success '--suppress-cc=sob' '
456         git config --unset sendemail.cccmd
457         test_suppression sob
458 '
459
460 cat >expected-suppress-bodycc <<\EOF
461 0001-Second.patch
462 (mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
463 (mbox) Adding cc: One <one@example.com> from line 'Cc: One <one@example.com>, two@example.com'
464 (mbox) Adding cc: two@example.com from line 'Cc: One <one@example.com>, two@example.com'
465 (body) Adding cc: C O Mitter <committer@example.com> from line 'Signed-off-by: C O Mitter <committer@example.com>'
466 Dry-OK. Log says:
467 Server: relay.example.com
468 MAIL FROM:<from@example.com>
469 RCPT TO:<to@example.com>,<author@example.com>,<one@example.com>,<two@example.com>,<committer@example.com>
470 From: Example <from@example.com>
471 To: to@example.com
472 Cc: A <author@example.com>, One <one@example.com>, two@example.com, C O Mitter <committer@example.com>
473 Subject: [PATCH 1/1] Second.
474 Date: DATE-STRING
475 Message-Id: MESSAGE-ID-STRING
476 X-Mailer: X-MAILER-STRING
477
478 Result: OK
479 EOF
480
481 test_expect_success '--suppress-cc=bodycc' '
482         test_suppression bodycc
483 '
484
485 cat >expected-suppress-cc <<\EOF
486 0001-Second.patch
487 (mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
488 (body) Adding cc: C O Mitter <committer@example.com> from line 'Signed-off-by: C O Mitter <committer@example.com>'
489 Dry-OK. Log says:
490 Server: relay.example.com
491 MAIL FROM:<from@example.com>
492 RCPT TO:<to@example.com>,<author@example.com>,<committer@example.com>
493 From: Example <from@example.com>
494 To: to@example.com
495 Cc: A <author@example.com>, C O Mitter <committer@example.com>
496 Subject: [PATCH 1/1] Second.
497 Date: DATE-STRING
498 Message-Id: MESSAGE-ID-STRING
499 X-Mailer: X-MAILER-STRING
500
501 Result: OK
502 EOF
503
504 test_expect_success '--suppress-cc=cc' '
505         test_suppression cc
506 '
507
508 test_confirm () {
509         echo y | \
510                 GIT_SEND_EMAIL_NOTTY=1 \
511                 git send-email \
512                 --from="Example <nobody@example.com>" \
513                 --to=nobody@example.com \
514                 --smtp-server="$(pwd)/fake.sendmail" \
515                 $@ $patches > stdout &&
516         grep "Send this email" stdout
517 }
518
519 test_expect_success '--confirm=always' '
520         test_confirm --confirm=always --suppress-cc=all
521 '
522
523 test_expect_success '--confirm=auto' '
524         test_confirm --confirm=auto
525 '
526
527 test_expect_success '--confirm=cc' '
528         test_confirm --confirm=cc
529 '
530
531 test_expect_success '--confirm=compose' '
532         test_confirm --confirm=compose --compose
533 '
534
535 test_expect_success 'confirm by default (due to cc)' '
536         CONFIRM=$(git config --get sendemail.confirm) &&
537         git config --unset sendemail.confirm &&
538         test_confirm
539         ret="$?"
540         git config sendemail.confirm ${CONFIRM:-never}
541         test $ret = "0"
542 '
543
544 test_expect_success 'confirm by default (due to --compose)' '
545         CONFIRM=$(git config --get sendemail.confirm) &&
546         git config --unset sendemail.confirm &&
547         test_confirm --suppress-cc=all --compose
548         ret="$?"
549         git config sendemail.confirm ${CONFIRM:-never}
550         test $ret = "0"
551 '
552
553 test_expect_success 'confirm detects EOF (inform assumes y)' '
554         CONFIRM=$(git config --get sendemail.confirm) &&
555         git config --unset sendemail.confirm &&
556         rm -fr outdir &&
557         git format-patch -2 -o outdir &&
558         GIT_SEND_EMAIL_NOTTY=1 \
559                 git send-email \
560                         --from="Example <nobody@example.com>" \
561                         --to=nobody@example.com \
562                         --smtp-server="$(pwd)/fake.sendmail" \
563                         outdir/*.patch < /dev/null
564         ret="$?"
565         git config sendemail.confirm ${CONFIRM:-never}
566         test $ret = "0"
567 '
568
569 test_expect_success 'confirm detects EOF (auto causes failure)' '
570         CONFIRM=$(git config --get sendemail.confirm) &&
571         git config sendemail.confirm auto &&
572         GIT_SEND_EMAIL_NOTTY=1 &&
573         export GIT_SEND_EMAIL_NOTTY &&
574                 test_must_fail git send-email \
575                         --from="Example <nobody@example.com>" \
576                         --to=nobody@example.com \
577                         --smtp-server="$(pwd)/fake.sendmail" \
578                         $patches < /dev/null
579         ret="$?"
580         git config sendemail.confirm ${CONFIRM:-never}
581         test $ret = "0"
582 '
583
584 test_expect_success 'confirm doesnt loop forever' '
585         CONFIRM=$(git config --get sendemail.confirm) &&
586         git config sendemail.confirm auto &&
587         GIT_SEND_EMAIL_NOTTY=1 &&
588         export GIT_SEND_EMAIL_NOTTY &&
589                 yes "bogus" | test_must_fail git send-email \
590                         --from="Example <nobody@example.com>" \
591                         --to=nobody@example.com \
592                         --smtp-server="$(pwd)/fake.sendmail" \
593                         $patches
594         ret="$?"
595         git config sendemail.confirm ${CONFIRM:-never}
596         test $ret = "0"
597 '
598
599 test_expect_success 'utf8 Cc is rfc2047 encoded' '
600         clean_fake_sendmail &&
601         rm -fr outdir &&
602         git format-patch -1 -o outdir --cc="àéìöú <utf8@example.com>" &&
603         git send-email \
604         --from="Example <nobody@example.com>" \
605         --to=nobody@example.com \
606         --smtp-server="$(pwd)/fake.sendmail" \
607         outdir/*.patch &&
608         grep "^Cc:" msgtxt1 |
609         grep "=?UTF-8?q?=C3=A0=C3=A9=C3=AC=C3=B6=C3=BA?= <utf8@example.com>"
610 '
611
612 test_expect_success '--compose adds MIME for utf8 body' '
613         clean_fake_sendmail &&
614         (echo "#!$SHELL_PATH" &&
615          echo "echo utf8 body: àéìöú >>\"\$1\""
616         ) >fake-editor-utf8 &&
617         chmod +x fake-editor-utf8 &&
618           GIT_EDITOR="\"$(pwd)/fake-editor-utf8\"" \
619           git send-email \
620           --compose --subject foo \
621           --from="Example <nobody@example.com>" \
622           --to=nobody@example.com \
623           --smtp-server="$(pwd)/fake.sendmail" \
624           $patches &&
625         grep "^utf8 body" msgtxt1 &&
626         grep "^Content-Type: text/plain; charset=UTF-8" msgtxt1
627 '
628
629 test_expect_success '--compose respects user mime type' '
630         clean_fake_sendmail &&
631         (echo "#!$SHELL_PATH" &&
632          echo "(echo MIME-Version: 1.0"
633          echo " echo Content-Type: text/plain\\; charset=iso-8859-1"
634          echo " echo Content-Transfer-Encoding: 8bit"
635          echo " echo Subject: foo"
636          echo " echo "
637          echo " echo utf8 body: àéìöú) >\"\$1\""
638         ) >fake-editor-utf8-mime &&
639         chmod +x fake-editor-utf8-mime &&
640           GIT_EDITOR="\"$(pwd)/fake-editor-utf8-mime\"" \
641           git send-email \
642           --compose --subject foo \
643           --from="Example <nobody@example.com>" \
644           --to=nobody@example.com \
645           --smtp-server="$(pwd)/fake.sendmail" \
646           $patches &&
647         grep "^utf8 body" msgtxt1 &&
648         grep "^Content-Type: text/plain; charset=iso-8859-1" msgtxt1 &&
649         ! grep "^Content-Type: text/plain; charset=UTF-8" msgtxt1
650 '
651
652 test_expect_success '--compose adds MIME for utf8 subject' '
653         clean_fake_sendmail &&
654           GIT_EDITOR="\"$(pwd)/fake-editor\"" \
655           git send-email \
656           --compose --subject utf8-sübjëct \
657           --from="Example <nobody@example.com>" \
658           --to=nobody@example.com \
659           --smtp-server="$(pwd)/fake.sendmail" \
660           $patches &&
661         grep "^fake edit" msgtxt1 &&
662         grep "^Subject: =?UTF-8?q?utf8-s=C3=BCbj=C3=ABct?=" msgtxt1
663 '
664
665 test_expect_success 'detects ambiguous reference/file conflict' '
666         echo master > master &&
667         git add master &&
668         git commit -m"add master" &&
669         test_must_fail git send-email --dry-run master 2>errors &&
670         grep disambiguate errors
671 '
672
673 test_expect_success 'feed two files' '
674         rm -fr outdir &&
675         git format-patch -2 -o outdir &&
676         git send-email \
677         --dry-run \
678         --from="Example <nobody@example.com>" \
679         --to=nobody@example.com \
680         outdir/000?-*.patch 2>errors >out &&
681         grep "^Subject: " out >subjects &&
682         test "z$(sed -n -e 1p subjects)" = "zSubject: [PATCH 1/2] Second." &&
683         test "z$(sed -n -e 2p subjects)" = "zSubject: [PATCH 2/2] add master"
684 '
685
686 test_expect_success 'in-reply-to but no threading' '
687         git send-email \
688                 --dry-run \
689                 --from="Example <nobody@example.com>" \
690                 --to=nobody@example.com \
691                 --in-reply-to="<in-reply-id@example.com>" \
692                 --nothread \
693                 $patches |
694         grep "In-Reply-To: <in-reply-id@example.com>"
695 '
696
697 test_expect_success 'no in-reply-to and no threading' '
698         git send-email \
699                 --dry-run \
700                 --from="Example <nobody@example.com>" \
701                 --to=nobody@example.com \
702                 --nothread \
703                 $patches $patches >stdout &&
704         ! grep "In-Reply-To: " stdout
705 '
706
707 test_expect_success 'threading but no chain-reply-to' '
708         git send-email \
709                 --dry-run \
710                 --from="Example <nobody@example.com>" \
711                 --to=nobody@example.com \
712                 --thread \
713                 --nochain-reply-to \
714                 $patches $patches >stdout &&
715         grep "In-Reply-To: " stdout
716 '
717
718 test_done