Merge branch 'mc/cd-p-pwd' into maint
[git] / t / t9001-send-email.sh
1 #!/bin/sh
2
3 test_description='git send-email'
4 . ./test-lib.sh
5
6 PROG='git send-email'
7 test_expect_success \
8     'prepare reference tree' \
9     'echo "1A quick brown fox jumps over the" >file &&
10      echo "lazy dog" >>file &&
11      git add file &&
12      GIT_AUTHOR_NAME="A" git commit -a -m "Initial."'
13
14 test_expect_success \
15     'Setup helper tool' \
16     '(echo "#!$SHELL_PATH"
17       echo shift
18       echo output=1
19       echo "while test -f commandline\$output; do output=\$((\$output+1)); done"
20       echo for a
21       echo do
22       echo "  echo \"!\$a!\""
23       echo "done >commandline\$output"
24       echo "cat > msgtxt\$output"
25       ) >fake.sendmail &&
26      chmod +x ./fake.sendmail &&
27      git add fake.sendmail &&
28      GIT_AUTHOR_NAME="A" git commit -a -m "Second."'
29
30 clean_fake_sendmail() {
31         rm -f commandline* msgtxt*
32 }
33
34 test_expect_success 'Extract patches' '
35     patches=`git format-patch -n HEAD^1`
36 '
37
38 test_expect_success 'Send patches' '
39      git send-email --from="Example <nobody@example.com>" --to=nobody@example.com --smtp-server="$(pwd)/fake.sendmail" $patches 2>errors
40 '
41
42 cat >expected <<\EOF
43 !nobody@example.com!
44 !author@example.com!
45 EOF
46 test_expect_success \
47     'Verify commandline' \
48     'diff commandline1 expected'
49
50 cat >expected-show-all-headers <<\EOF
51 0001-Second.patch
52 (mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
53 Dry-OK. Log says:
54 Server: relay.example.com
55 MAIL FROM:<from@example.com>
56 RCPT TO:<to@example.com>,<cc@example.com>,<author@example.com>,<bcc@example.com>
57 From: Example <from@example.com>
58 To: to@example.com
59 Cc: cc@example.com, A <author@example.com>
60 Subject: [PATCH 1/1] Second.
61 Date: DATE-STRING
62 Message-Id: MESSAGE-ID-STRING
63 X-Mailer: X-MAILER-STRING
64 In-Reply-To: <unique-message-id@example.com>
65 References: <unique-message-id@example.com>
66
67 Result: OK
68 EOF
69
70 test_expect_success 'Show all headers' '
71         git send-email \
72                 --dry-run \
73                 --from="Example <from@example.com>" \
74                 --to=to@example.com \
75                 --cc=cc@example.com \
76                 --bcc=bcc@example.com \
77                 --in-reply-to="<unique-message-id@example.com>" \
78                 --smtp-server relay.example.com \
79                 $patches |
80         sed     -e "s/^\(Date:\).*/\1 DATE-STRING/" \
81                 -e "s/^\(Message-Id:\).*/\1 MESSAGE-ID-STRING/" \
82                 -e "s/^\(X-Mailer:\).*/\1 X-MAILER-STRING/" \
83                 >actual-show-all-headers &&
84         test_cmp expected-show-all-headers actual-show-all-headers
85 '
86
87 z8=zzzzzzzz
88 z64=$z8$z8$z8$z8$z8$z8$z8$z8
89 z512=$z64$z64$z64$z64$z64$z64$z64$z64
90 test_expect_success 'reject long lines' '
91         clean_fake_sendmail &&
92         cp $patches longline.patch &&
93         echo $z512$z512 >>longline.patch &&
94         test_must_fail git send-email \
95                 --from="Example <nobody@example.com>" \
96                 --to=nobody@example.com \
97                 --smtp-server="$(pwd)/fake.sendmail" \
98                 $patches longline.patch \
99                 2>errors &&
100         grep longline.patch errors
101 '
102
103 test_expect_success 'no patch was sent' '
104         ! test -e commandline1
105 '
106
107 test_expect_success 'allow long lines with --no-validate' '
108         git send-email \
109                 --from="Example <nobody@example.com>" \
110                 --to=nobody@example.com \
111                 --smtp-server="$(pwd)/fake.sendmail" \
112                 --novalidate \
113                 $patches longline.patch \
114                 2>errors
115 '
116
117 test_expect_success 'Invalid In-Reply-To' '
118         clean_fake_sendmail &&
119         git send-email \
120                 --from="Example <nobody@example.com>" \
121                 --to=nobody@example.com \
122                 --in-reply-to=" " \
123                 --smtp-server="$(pwd)/fake.sendmail" \
124                 $patches
125                 2>errors
126         ! grep "^In-Reply-To: < *>" msgtxt1
127 '
128
129 test_expect_success 'Valid In-Reply-To when prompting' '
130         clean_fake_sendmail &&
131         (echo "From Example <from@example.com>"
132          echo "To Example <to@example.com>"
133          echo ""
134         ) | env GIT_SEND_EMAIL_NOTTY=1 git send-email \
135                 --smtp-server="$(pwd)/fake.sendmail" \
136                 $patches 2>errors &&
137         ! grep "^In-Reply-To: < *>" msgtxt1
138 '
139
140 test_expect_success 'setup fake editor' '
141         (echo "#!$SHELL_PATH" &&
142          echo "echo fake edit >>\"\$1\""
143         ) >fake-editor &&
144         chmod +x fake-editor
145 '
146
147 test_set_editor "$(pwd)/fake-editor"
148
149 test_expect_success '--compose works' '
150         clean_fake_sendmail &&
151         echo y | \
152                 GIT_SEND_EMAIL_NOTTY=1 \
153                 git send-email \
154                 --compose --subject foo \
155                 --from="Example <nobody@example.com>" \
156                 --to=nobody@example.com \
157                 --smtp-server="$(pwd)/fake.sendmail" \
158                 $patches \
159                 2>errors
160 '
161
162 test_expect_success 'first message is compose text' '
163         grep "^fake edit" msgtxt1
164 '
165
166 test_expect_success 'second message is patch' '
167         grep "Subject:.*Second" msgtxt2
168 '
169
170 cat >expected-show-all-headers <<\EOF
171 0001-Second.patch
172 (mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
173 Dry-OK. Log says:
174 Server: relay.example.com
175 MAIL FROM:<from@example.com>
176 RCPT TO:<to@example.com>,<cc@example.com>,<author@example.com>
177 From: Example <from@example.com>
178 To: to@example.com
179 Cc: cc@example.com, A <author@example.com>
180 Subject: [PATCH 1/1] Second.
181 Date: DATE-STRING
182 Message-Id: MESSAGE-ID-STRING
183 X-Mailer: X-MAILER-STRING
184
185 Result: OK
186 EOF
187
188 test_expect_success 'sendemail.cc set' '
189         git config sendemail.cc cc@example.com &&
190         git send-email \
191                 --dry-run \
192                 --from="Example <from@example.com>" \
193                 --to=to@example.com \
194                 --smtp-server relay.example.com \
195                 $patches |
196         sed     -e "s/^\(Date:\).*/\1 DATE-STRING/" \
197                 -e "s/^\(Message-Id:\).*/\1 MESSAGE-ID-STRING/" \
198                 -e "s/^\(X-Mailer:\).*/\1 X-MAILER-STRING/" \
199                 >actual-show-all-headers &&
200         test_cmp expected-show-all-headers actual-show-all-headers
201 '
202
203 cat >expected-show-all-headers <<\EOF
204 0001-Second.patch
205 (mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
206 Dry-OK. Log says:
207 Server: relay.example.com
208 MAIL FROM:<from@example.com>
209 RCPT TO:<to@example.com>,<author@example.com>
210 From: Example <from@example.com>
211 To: to@example.com
212 Cc: A <author@example.com>
213 Subject: [PATCH 1/1] Second.
214 Date: DATE-STRING
215 Message-Id: MESSAGE-ID-STRING
216 X-Mailer: X-MAILER-STRING
217
218 Result: OK
219 EOF
220
221 test_expect_success 'sendemail.cc unset' '
222         git config --unset sendemail.cc &&
223         git send-email \
224                 --dry-run \
225                 --from="Example <from@example.com>" \
226                 --to=to@example.com \
227                 --smtp-server relay.example.com \
228                 $patches |
229         sed     -e "s/^\(Date:\).*/\1 DATE-STRING/" \
230                 -e "s/^\(Message-Id:\).*/\1 MESSAGE-ID-STRING/" \
231                 -e "s/^\(X-Mailer:\).*/\1 X-MAILER-STRING/" \
232                 >actual-show-all-headers &&
233         test_cmp expected-show-all-headers actual-show-all-headers
234 '
235
236 test_expect_success '--compose adds MIME for utf8 body' '
237         clean_fake_sendmail &&
238         (echo "#!$SHELL_PATH" &&
239          echo "echo utf8 body: àéìöú >>\"\$1\""
240         ) >fake-editor-utf8 &&
241         chmod +x fake-editor-utf8 &&
242         echo y | \
243           GIT_EDITOR="\"$(pwd)/fake-editor-utf8\"" \
244           GIT_SEND_EMAIL_NOTTY=1 \
245           git send-email \
246           --compose --subject foo \
247           --from="Example <nobody@example.com>" \
248           --to=nobody@example.com \
249           --smtp-server="$(pwd)/fake.sendmail" \
250           $patches &&
251         grep "^utf8 body" msgtxt1 &&
252         grep "^Content-Type: text/plain; charset=utf-8" msgtxt1
253 '
254
255 test_expect_success '--compose respects user mime type' '
256         clean_fake_sendmail &&
257         (echo "#!$SHELL_PATH" &&
258          echo "(echo MIME-Version: 1.0"
259          echo " echo Content-Type: text/plain\\; charset=iso-8859-1"
260          echo " echo Content-Transfer-Encoding: 8bit"
261          echo " echo Subject: foo"
262          echo " echo "
263          echo " echo utf8 body: àéìöú) >\"\$1\""
264         ) >fake-editor-utf8-mime &&
265         chmod +x fake-editor-utf8-mime &&
266         echo y | \
267           GIT_EDITOR="\"$(pwd)/fake-editor-utf8-mime\"" \
268           GIT_SEND_EMAIL_NOTTY=1 \
269           git send-email \
270           --compose --subject foo \
271           --from="Example <nobody@example.com>" \
272           --to=nobody@example.com \
273           --smtp-server="$(pwd)/fake.sendmail" \
274           $patches &&
275         grep "^utf8 body" msgtxt1 &&
276         grep "^Content-Type: text/plain; charset=iso-8859-1" msgtxt1 &&
277         ! grep "^Content-Type: text/plain; charset=utf-8" msgtxt1
278 '
279
280 test_expect_success '--compose adds MIME for utf8 subject' '
281         clean_fake_sendmail &&
282         echo y | \
283           GIT_EDITOR="\"$(pwd)/fake-editor\"" \
284           GIT_SEND_EMAIL_NOTTY=1 \
285           git send-email \
286           --compose --subject utf8-sübjëct \
287           --from="Example <nobody@example.com>" \
288           --to=nobody@example.com \
289           --smtp-server="$(pwd)/fake.sendmail" \
290           $patches &&
291         grep "^fake edit" msgtxt1 &&
292         grep "^Subject: =?utf-8?q?utf8-s=C3=BCbj=C3=ABct?=" msgtxt1
293 '
294
295 test_expect_success 'detects ambiguous reference/file conflict' '
296         echo master > master &&
297         git add master &&
298         git commit -m"add master" &&
299         test_must_fail git send-email --dry-run master 2>errors &&
300         grep disambiguate errors
301 '
302
303 test_expect_success 'feed two files' '
304         rm -fr outdir &&
305         git format-patch -2 -o outdir &&
306         GIT_SEND_EMAIL_NOTTY=1 git send-email \
307         --dry-run \
308         --from="Example <nobody@example.com>" \
309         --to=nobody@example.com \
310         outdir/000?-*.patch 2>errors >out &&
311         grep "^Subject: " out >subjects &&
312         test "z$(sed -n -e 1p subjects)" = "zSubject: [PATCH 1/2] Second." &&
313         test "z$(sed -n -e 2p subjects)" = "zSubject: [PATCH 2/2] add master"
314 '
315
316 test_done