ash: add tests for failures of the exec and command builtins
authorRon Yorston <rmy@pobox.com>
Fri, 30 Oct 2015 19:05:55 +0000 (19:05 +0000)
committerDenys Vlasenko <vda.linux@googlemail.com>
Fri, 30 Oct 2015 21:19:06 +0000 (22:19 +0100)
The exec builtin should return an exit status of 127 if the command
can't be found.  It doesn't:  it returns 2.

If the command builtin is used to source a script that runs a second
script that doesn't exist ash should issue an error.  Instead it seg
faults.

Signed-off-by: Ron Yorston <rmy@pobox.com>
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
shell/ash_test/ash-misc/command2.right [new file with mode: 0644]
shell/ash_test/ash-misc/command2.tests [new file with mode: 0755]
shell/ash_test/ash-misc/exec.right [new file with mode: 0644]
shell/ash_test/ash-misc/exec.tests [new file with mode: 0755]

diff --git a/shell/ash_test/ash-misc/command2.right b/shell/ash_test/ash-misc/command2.right
new file mode 100644 (file)
index 0000000..8d2165f
--- /dev/null
@@ -0,0 +1,2 @@
+test1
+./command2.tests: ./test1.sh: line 1: ./test2.sh: Permission denied
diff --git a/shell/ash_test/ash-misc/command2.tests b/shell/ash_test/ash-misc/command2.tests
new file mode 100755 (executable)
index 0000000..9d9de9a
--- /dev/null
@@ -0,0 +1,6 @@
+echo "echo test1; ./test2.sh" >test1.sh
+echo "echo test2" >test2.sh
+
+command . ./test1.sh
+
+rm -f test1.sh test2.sh
diff --git a/shell/ash_test/ash-misc/exec.right b/shell/ash_test/ash-misc/exec.right
new file mode 100644 (file)
index 0000000..1741a38
--- /dev/null
@@ -0,0 +1,2 @@
+./exec.tests: exec: line 2: ./test1.sh: not found
+127
diff --git a/shell/ash_test/ash-misc/exec.tests b/shell/ash_test/ash-misc/exec.tests
new file mode 100755 (executable)
index 0000000..624915d
--- /dev/null
@@ -0,0 +1,3 @@
+rm -f test1.sh
+(exec ./test1.sh)
+echo $?