git-send-email: show all headers when sending mail

As a git newbie, it was confusing to set an In-Reply-To header but then
not see it printed when the git-send-email command was run.

This patch prints all headers that would be sent to sendmail or an SMTP
server instead of only printing From, Subject, Cc, To.  It also removes
the now-extraneous Date header after the "Log says" line.

Added test to t/t9001-send-email.sh.

Signed-off-by: David D. Kilzer <ddkilzer@kilzer.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
David D. Kilzer 2007-11-18 20:14:55 -08:00 committed by Junio C Hamano
parent 5d1d1c1479
commit b7f30e0a97
2 changed files with 39 additions and 2 deletions

View File

@ -643,7 +643,7 @@ X-Mailer: git-send-email $gitversion
if ($quiet) { if ($quiet) {
printf (($dry_run ? "Dry-" : "")."Sent %s\n", $subject); printf (($dry_run ? "Dry-" : "")."Sent %s\n", $subject);
} else { } else {
print (($dry_run ? "Dry-" : "")."OK. Log says:\nDate: $date\n"); print (($dry_run ? "Dry-" : "")."OK. Log says:\n");
if ($smtp_server !~ m#^/#) { if ($smtp_server !~ m#^/#) {
print "Server: $smtp_server\n"; print "Server: $smtp_server\n";
print "MAIL FROM:<$raw_from>\n"; print "MAIL FROM:<$raw_from>\n";
@ -651,7 +651,7 @@ X-Mailer: git-send-email $gitversion
} else { } else {
print "Sendmail: $smtp_server ".join(' ',@sendmail_parameters)."\n"; print "Sendmail: $smtp_server ".join(' ',@sendmail_parameters)."\n";
} }
print "From: $sanitized_sender\nSubject: $subject\nCc: $cc\nTo: $to\n\n"; print $header, "\n";
if ($smtp) { if ($smtp) {
print "Result: ", $smtp->code, ' ', print "Result: ", $smtp->code, ' ',
($smtp->message =~ /\n([^\n]+\n)$/s), "\n"; ($smtp->message =~ /\n([^\n]+\n)$/s), "\n";

View File

@ -41,4 +41,41 @@ test_expect_success \
'Verify commandline' \ 'Verify commandline' \
'diff commandline expected' 'diff commandline expected'
cat >expected-show-all-headers <<\EOF
0001-Second.patch
(mbox) Adding cc: A <author@example.com> from line 'From: A <author@example.com>'
Dry-OK. Log says:
Server: relay.example.com
MAIL FROM:<from@example.com>
RCPT TO:<to@example.com>,<cc@example.com>,<author@example.com>,<bcc@example.com>
From: Example <from@example.com>
To: to@example.com
Cc: cc@example.com, A <author@example.com>
Subject: [PATCH 1/1] Second.
Date: DATE-STRING
Message-Id: MESSAGE-ID-STRING
X-Mailer: X-MAILER-STRING
In-Reply-To: <unique-message-id@example.com>
References: <unique-message-id@example.com>
Result: OK
EOF
test_expect_success 'Show all headers' '
git send-email \
--dry-run \
--from="Example <from@example.com>" \
--to=to@example.com \
--cc=cc@example.com \
--bcc=bcc@example.com \
--in-reply-to="<unique-message-id@example.com>" \
--smtp-server relay.example.com \
$patches |
sed -e "s/^\(Date:\).*/\1 DATE-STRING/" \
-e "s/^\(Message-Id:\).*/\1 MESSAGE-ID-STRING/" \
-e "s/^\(X-Mailer:\).*/\1 X-MAILER-STRING/" \
>actual-show-all-headers &&
diff -u expected-show-all-headers actual-show-all-headers
'
test_done test_done