зеркало из https://github.com/microsoft/git.git
Merge branch 'dd/send-email-config'
Stop when "sendmail.*" configuration variables are defined, which could be a mistaken attempt to define "sendemail.*" variables. * dd/send-email-config: git-send-email: die if sendmail.* config is set
This commit is contained in:
Коммит
a00bda2b2f
|
@ -61,3 +61,8 @@ sendemail.smtpBatchSize::
|
|||
sendemail.smtpReloginDelay::
|
||||
Seconds wait before reconnecting to smtp server.
|
||||
See also the `--relogin-delay` option of linkgit:git-send-email[1].
|
||||
|
||||
sendemail.forbidSendmailVariables::
|
||||
To avoid common misconfiguration mistakes, linkgit:git-send-email[1]
|
||||
will abort with a warning if any configuration options for "sendmail"
|
||||
exist. Set this variable to bypass the check.
|
||||
|
|
|
@ -250,6 +250,7 @@ my $chain_reply_to = 0;
|
|||
my $use_xmailer = 1;
|
||||
my $validate = 1;
|
||||
my $target_xfer_encoding = 'auto';
|
||||
my $forbid_sendmail_variables = 1;
|
||||
|
||||
my %config_bool_settings = (
|
||||
"thread" => \$thread,
|
||||
|
@ -263,6 +264,7 @@ my %config_bool_settings = (
|
|||
"multiedit" => \$multiedit,
|
||||
"annotate" => \$annotate,
|
||||
"xmailer" => \$use_xmailer,
|
||||
"forbidsendmailvariables" => \$forbid_sendmail_variables,
|
||||
);
|
||||
|
||||
my %config_settings = (
|
||||
|
@ -478,6 +480,12 @@ unless ($rc) {
|
|||
usage();
|
||||
}
|
||||
|
||||
if ($forbid_sendmail_variables && (scalar Git::config_regexp("^sendmail[.]")) != 0) {
|
||||
die __("fatal: found configuration options for 'sendmail'\n" .
|
||||
"git-send-email is configured with the sendemail.* options - note the 'e'.\n" .
|
||||
"Set sendemail.forbidSendmailVariables to false to disable this check.\n");
|
||||
}
|
||||
|
||||
die __("Cannot run git format-patch from outside a repository\n")
|
||||
if $format_patch and not $repo;
|
||||
|
||||
|
|
26
perl/Git.pm
26
perl/Git.pm
|
@ -723,6 +723,32 @@ sub config_int {
|
|||
return scalar _config_common({'kind' => '--int'}, @_);
|
||||
}
|
||||
|
||||
=item config_regexp ( RE )
|
||||
|
||||
Retrieve the list of configuration key names matching the regular
|
||||
expression C<RE>. The return value is a list of strings matching
|
||||
this regex.
|
||||
|
||||
=cut
|
||||
|
||||
sub config_regexp {
|
||||
my ($self, $regex) = _maybe_self(@_);
|
||||
try {
|
||||
my @cmd = ('config', '--name-only', '--get-regexp', $regex);
|
||||
unshift @cmd, $self if $self;
|
||||
my @matches = command(@cmd);
|
||||
return @matches;
|
||||
} catch Git::Error::Command with {
|
||||
my $E = shift;
|
||||
if ($E->value() == 1) {
|
||||
my @matches = ();
|
||||
return @matches;
|
||||
} else {
|
||||
throw $E;
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
# Common subroutine to implement bulk of what the config* family of methods
|
||||
# do. This currently wraps command('config') so it is not so fast.
|
||||
sub _config_common {
|
||||
|
|
|
@ -2142,4 +2142,33 @@ test_expect_success $PREREQ 'test that send-email works outside a repo' '
|
|||
"$(pwd)/0001-add-master.patch"
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ 'test that sendmail config is rejected' '
|
||||
test_config sendmail.program sendmail &&
|
||||
test_must_fail git send-email \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
HEAD^ 2>err &&
|
||||
test_i18ngrep "found configuration options for '"'"sendmail"'"'" err
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ 'test that sendmail config rejection is specific' '
|
||||
test_config resendmail.program sendmail &&
|
||||
git send-email \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
HEAD^
|
||||
'
|
||||
|
||||
test_expect_success $PREREQ 'test forbidSendmailVariables behavior override' '
|
||||
test_config sendmail.program sendmail &&
|
||||
test_config sendemail.forbidSendmailVariables false &&
|
||||
git send-email \
|
||||
--from="Example <nobody@example.com>" \
|
||||
--to=nobody@example.com \
|
||||
--smtp-server="$(pwd)/fake.sendmail" \
|
||||
HEAD^
|
||||
'
|
||||
|
||||
test_done
|
||||
|
|
Загрузка…
Ссылка в новой задаче