From 6e9250425aa2a062eb5ade1ff6119ab81605c490 Mon Sep 17 00:00:00 2001 From: Mrmaxmeier Date: Mon, 11 Feb 2019 17:10:42 +0100 Subject: [PATCH] src/exec: fix assertion on failed exec redirection Minimal reproducer: `fish -c "exec cat j) { if (j->processes.front()->type == INTERNAL_EXEC) { internal_exec(parser.vars(), j.get(), all_ios); - DIE("this should be unreachable"); + // internal_exec only returns if it failed to set up redirections. + // In case of an successful exec, this code is not reached. + bool status = j->get_flag(job_flag_t::NEGATE) ? 0 : 1; + proc_set_last_status(status); + return false; } // This loop loops over every process_t in the job, starting it as appropriate. This turns out diff --git a/tests/test_exec_fail.err b/tests/test_exec_fail.err new file mode 100644 index 000000000..6a3453fce --- /dev/null +++ b/tests/test_exec_fail.err @@ -0,0 +1,4 @@ + fish: An error occurred while redirecting file 'nosuchfile' +open: No such file or directory + fish: An error occurred while redirecting file 'nosuchfile' +open: No such file or directory diff --git a/tests/test_exec_fail.in b/tests/test_exec_fail.in new file mode 100644 index 000000000..08be53ef4 --- /dev/null +++ b/tests/test_exec_fail.in @@ -0,0 +1,6 @@ +exec cat < nosuchfile +echo "failed: $status" +not exec cat < nosuchfile +echo "neg failed: $status" +exec cat < /dev/null +echo "not reached" diff --git a/tests/test_exec_fail.out b/tests/test_exec_fail.out new file mode 100644 index 000000000..762ca2ce2 --- /dev/null +++ b/tests/test_exec_fail.out @@ -0,0 +1,2 @@ +failed: 1 +neg failed: 0 diff --git a/tests/test_exec_fail.status b/tests/test_exec_fail.status new file mode 100644 index 000000000..573541ac9 --- /dev/null +++ b/tests/test_exec_fail.status @@ -0,0 +1 @@ +0