Skip to content

Commit

Permalink
t0061: adjust to test-tool transition
Browse files Browse the repository at this point in the history
  • Loading branch information
gitster committed Oct 25, 2018
2 parents 268fbcd + 321fd82 commit f67b980
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 5 deletions.
21 changes: 17 additions & 4 deletions run-command.c
Original file line number Diff line number Diff line change
Expand Up @@ -380,7 +380,7 @@ static void child_err_spew(struct child_process *cmd, struct child_err *cerr)
set_error_routine(old_errfn);
}

static void prepare_cmd(struct argv_array *out, const struct child_process *cmd)
static int prepare_cmd(struct argv_array *out, const struct child_process *cmd)
{
if (!cmd->argv[0])
BUG("command is empty");
Expand All @@ -403,16 +403,22 @@ static void prepare_cmd(struct argv_array *out, const struct child_process *cmd)
/*
* If there are no '/' characters in the command then perform a path
* lookup and use the resolved path as the command to exec. If there
* are no '/' characters or if the command wasn't found in the path,
* have exec attempt to invoke the command directly.
* are '/' characters, we have exec attempt to invoke the command
* directly.
*/
if (!strchr(out->argv[1], '/')) {
char *program = locate_in_PATH(out->argv[1]);
if (program) {
free((char *)out->argv[1]);
out->argv[1] = program;
} else {
argv_array_clear(out);
errno = ENOENT;
return -1;
}
}

return 0;
}

static char **prep_childenv(const char *const *deltaenv)
Expand Down Expand Up @@ -719,6 +725,12 @@ int start_command(struct child_process *cmd)
struct child_err cerr;
struct atfork_state as;

if (prepare_cmd(&argv, cmd) < 0) {
failed_errno = errno;
cmd->pid = -1;
goto end_of_spawn;
}

if (pipe(notify_pipe))
notify_pipe[0] = notify_pipe[1] = -1;

Expand All @@ -729,7 +741,6 @@ int start_command(struct child_process *cmd)
set_cloexec(null_fd);
}

prepare_cmd(&argv, cmd);
childenv = prep_childenv(cmd->env);
atfork_prepare(&as);

Expand Down Expand Up @@ -857,6 +868,8 @@ int start_command(struct child_process *cmd)
argv_array_clear(&argv);
free(childenv);
}
end_of_spawn:

#else
{
int fhin = 0, fhout = 1, fherr = 2;
Expand Down
13 changes: 12 additions & 1 deletion t/t0061-run-command.sh
Original file line number Diff line number Diff line change
Expand Up @@ -13,10 +13,14 @@ cat >hello-script <<-EOF
EOF
>empty

test_expect_success 'start_command reports ENOENT' '
test_expect_success 'start_command reports ENOENT (slash)' '
test-tool run-command start-command-ENOENT ./does-not-exist
'

test_expect_success 'start_command reports ENOENT (no slash)' '
test-tool run-command start-command-ENOENT does-not-exist
'

test_expect_success 'run_command can run a command' '
cat hello-script >hello.sh &&
chmod +x hello.sh &&
Expand All @@ -26,6 +30,13 @@ test_expect_success 'run_command can run a command' '
test_cmp empty err
'

test_expect_success 'run_command is restricted to PATH' '
write_script should-not-run <<-\EOF &&
echo yikes
EOF
test_must_fail test-tool run-command run-command should-not-run
'

test_expect_success !MINGW 'run_command can run a script without a #! line' '
cat >hello <<-\EOF &&
cat hello-script
Expand Down

0 comments on commit f67b980

Please sign in to comment.