зеркало из https://github.com/microsoft/git.git
run-command: report exec failure
In 321fd823
("run-command: mark path lookup errors with ENOENT",
2018-10-24), we rewrote the logic to execute a command by looking
in the directories on $PATH; as a side effect, a request to run a
command that is not found on $PATH is noticed even before a child
process is forked to execute it.
We however stopped to report an exec failure in such a case by
mistake. Add a logic to report the error unless silent-exec-failure
is requested, to match the original code.
Reported-by: John Passaro <john.a.passaro@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Родитель
f67b980771
Коммит
e5a329a279
|
@ -728,6 +728,8 @@ fail_pipe:
|
||||||
if (prepare_cmd(&argv, cmd) < 0) {
|
if (prepare_cmd(&argv, cmd) < 0) {
|
||||||
failed_errno = errno;
|
failed_errno = errno;
|
||||||
cmd->pid = -1;
|
cmd->pid = -1;
|
||||||
|
if (!cmd->silent_exec_failure)
|
||||||
|
error_errno("cannot run %s", cmd->argv[0]);
|
||||||
goto end_of_spawn;
|
goto end_of_spawn;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -14,11 +14,13 @@ EOF
|
||||||
>empty
|
>empty
|
||||||
|
|
||||||
test_expect_success 'start_command reports ENOENT (slash)' '
|
test_expect_success 'start_command reports ENOENT (slash)' '
|
||||||
test-tool run-command start-command-ENOENT ./does-not-exist
|
test-tool run-command start-command-ENOENT ./does-not-exist 2>err &&
|
||||||
|
test_i18ngrep "\./does-not-exist" err
|
||||||
'
|
'
|
||||||
|
|
||||||
test_expect_success 'start_command reports ENOENT (no slash)' '
|
test_expect_success 'start_command reports ENOENT (no slash)' '
|
||||||
test-tool run-command start-command-ENOENT does-not-exist
|
test-tool run-command start-command-ENOENT does-not-exist 2>err &&
|
||||||
|
test_i18ngrep "does-not-exist" err
|
||||||
'
|
'
|
||||||
|
|
||||||
test_expect_success 'run_command can run a command' '
|
test_expect_success 'run_command can run a command' '
|
||||||
|
@ -34,7 +36,8 @@ test_expect_success 'run_command is restricted to PATH' '
|
||||||
write_script should-not-run <<-\EOF &&
|
write_script should-not-run <<-\EOF &&
|
||||||
echo yikes
|
echo yikes
|
||||||
EOF
|
EOF
|
||||||
test_must_fail test-tool run-command run-command should-not-run
|
test_must_fail test-tool run-command run-command should-not-run 2>err &&
|
||||||
|
test_i18ngrep "should-not-run" err
|
||||||
'
|
'
|
||||||
|
|
||||||
test_expect_success !MINGW 'run_command can run a script without a #! line' '
|
test_expect_success !MINGW 'run_command can run a script without a #! line' '
|
||||||
|
|
Загрузка…
Ссылка в новой задаче