status | osh | osh-cpp | |
pass | 2 | 3 | |
ok | 4 | 4 | |
FAIL | 2 | 1 | |
total | 8 | 8 | |
case | osh | osh-cpp | description |
0 | pass | pass | NUL bytes with echo -e |
1 | pass | pass | NUL bytes in printf format |
2 | ok | ok | NUL bytes in printf value (OSH and zsh agree) |
details | details | ||
3 | ok | ok | NUL bytes with echo $'\0' (OSH and zsh agree) |
details | details | ||
4 | FAIL | FAIL | NUL bytes and IFS splitting |
details | details | ||
5 | ok | ok | NUL bytes with test -n |
details | details | ||
6 | FAIL | pass | NUL bytes with test -f |
details | |||
7 | ok | ok | NUL bytes with ${#s} (OSH and zsh agree) |
details | details |
5 passed, 8 OK, 0 not implemented, 0 BUG, 2 failed, 0 timeouts, 0 cases skipped 2 failed under osh
osh | 2 NUL bytes in printf value (OSH and zsh agree) stdout: stderr: |
osh-cpp | 2 NUL bytes in printf value (OSH and zsh agree) stdout: stderr: |
osh | 3 NUL bytes with echo $'\0' (OSH and zsh agree) stdout: stderr: |
osh-cpp | 3 NUL bytes with echo $'\0' (OSH and zsh agree) stdout: stderr: |
osh | 4 NUL bytes and IFS splitting [osh stdout] Expected "[]\n['']\n['ab']\n['ab']\n", got '' [osh status] Expected 0, got 1 [osh stderr] Found 'Traceback (most recent' stdout: stderr: Traceback (most recent call last): File "/home/uke/oil/bin/oils_for_unix.py", line 202, in <module> sys.exit(main(sys.argv)) File "/home/uke/oil/bin/oils_for_unix.py", line 171, in main return AppBundleMain(argv) File "/home/uke/oil/bin/oils_for_unix.py", line 141, in AppBundleMain return shell.Main('osh', arg_r, environ, login_shell, loader, readline) File "/home/uke/oil/core/shell.py", line 1213, in Main cmd_flags=cmd_eval.IsMainProgram) File "/home/uke/oil/core/main_loop.py", line 375, in Batch is_return, is_fatal = cmd_ev.ExecuteAndCatch(node, cmd_flags) File "/home/uke/oil/osh/cmd_eval.py", line 2105, in ExecuteAndCatch status = self._Execute(node) File "/home/uke/oil/osh/cmd_eval.py", line 1904, in _Execute status = self._Dispatch(node, cmd_st) File "/home/uke/oil/osh/cmd_eval.py", line 1631, in _Dispatch status = self._DoSimple(node, cmd_st) File "/home/uke/oil/osh/cmd_eval.py", line 913, in _DoSimple status = self._RunSimpleCommand(cmd_val, cmd_st, run_flags) File "/home/uke/oil/osh/cmd_eval.py", line 574, in _RunSimpleCommand run_flags) File "/home/uke/oil/core/executor.py", line 494, in RunSimpleCommand status = p.RunProcess(self.waiter, trace.External(cmd_val.argv)) File "/home/uke/oil/core/process.py", line 1186, in RunProcess self.StartProcess(why) File "/home/uke/oil/core/process.py", line 1096, in StartProcess self.thunk.Run() File "/home/uke/oil/core/process.py", line 805, in Run self.ext_prog.Exec(self.argv0_path, self.cmd_val, self.environ) File "/home/uke/oil/core/process.py", line 692, in Exec True) File "/home/uke/oil/core/process.py", line 723, in _Exec posix.execve(argv0_path, argv, environ) TypeError: execve() arg 2 must contain only strings Traceback (most recent call last): File "/home/uke/oil/bin/oils_for_unix.py", line 202, in <module> sys.exit(main(sys.argv)) File "/home/uke/oil/bin/oils_for_unix.py", line 171, in main return AppBundleMain(argv) File "/home/uke/oil/bin/oils_for_unix.py", line 141, in AppBundleMain return shell.Main('osh', arg_r, environ, login_shell, loader, readline) File "/home/uke/oil/core/shell.py", line 1213, in Main cmd_flags=cmd_eval.IsMainProgram) File "/home/uke/oil/core/main_loop.py", line 375, in Batch is_return, is_fatal = cmd_ev.ExecuteAndCatch(node, cmd_flags) File "/home/uke/oil/osh/cmd_eval.py", line 2105, in ExecuteAndCatch status = self._Execute(node) File "/home/uke/oil/osh/cmd_eval.py", line 1904, in _Execute status = self._Dispatch(node, cmd_st) File "/home/uke/oil/osh/cmd_eval.py", line 1631, in _Dispatch status = self._DoSimple(node, cmd_st) File "/home/uke/oil/osh/cmd_eval.py", line 913, in _DoSimple status = self._RunSimpleCommand(cmd_val, cmd_st, run_flags) File "/home/uke/oil/osh/cmd_eval.py", line 574, in _RunSimpleCommand run_flags) File "/home/uke/oil/core/executor.py", line 494, in RunSimpleCommand status = p.RunProcess(self.waiter, trace.External(cmd_val.argv)) File "/home/uke/oil/core/process.py", line 1186, in RunProcess self.StartProcess(why) File "/home/uke/oil/core/process.py", line 1096, in StartProcess self.thunk.Run() File "/home/uke/oil/core/process.py", line 805, in Run self.ext_prog.Exec(self.argv0_path, self.cmd_val, self.environ) File "/home/uke/oil/core/process.py", line 692, in Exec True) File "/home/uke/oil/core/process.py", line 723, in _Exec posix.execve(argv0_path, argv, environ) TypeError: execve() arg 2 must contain only strings Traceback (most recent call last): File "/home/uke/oil/bin/oils_for_unix.py", line 202, in <module> sys.exit(main(sys.argv)) File "/home/uke/oil/bin/oils_for_unix.py", line 171, in main return AppBundleMain(argv) File "/home/uke/oil/bin/oils_for_unix.py", line 141, in AppBundleMain return shell.Main('osh', arg_r, environ, login_shell, loader, readline) File "/home/uke/oil/core/shell.py", line 1213, in Main cmd_flags=cmd_eval.IsMainProgram) File "/home/uke/oil/core/main_loop.py", line 375, in Batch is_return, is_fatal = cmd_ev.ExecuteAndCatch(node, cmd_flags) File "/home/uke/oil/osh/cmd_eval.py", line 2105, in ExecuteAndCatch status = self._Execute(node) File "/home/uke/oil/osh/cmd_eval.py", line 1904, in _Execute status = self._Dispatch(node, cmd_st) File "/home/uke/oil/osh/cmd_eval.py", line 1631, in _Dispatch status = self._DoSimple(node, cmd_st) File "/home/uke/oil/osh/cmd_eval.py", line 913, in _DoSimple status = self._RunSimpleCommand(cmd_val, cmd_st, run_flags) File "/home/uke/oil/osh/cmd_eval.py", line 574, in _RunSimpleCommand run_flags) File "/home/uke/oil/core/executor.py", line 494, in RunSimpleCommand status = p.RunProcess(self.waiter, trace.External(cmd_val.argv)) File "/home/uke/oil/core/process.py", line 1186, in RunProcess self.StartProcess(why) File "/home/uke/oil/core/process.py", line 1096, in StartProcess self.thunk.Run() File "/home/uke/oil/core/process.py", line 805, in Run self.ext_prog.Exec(self.argv0_path, self.cmd_val, self.environ) File "/home/uke/oil/core/process.py", line 692, in Exec True) File "/home/uke/oil/core/process.py", line 723, in _Exec posix.execve(argv0_path, argv, environ) TypeError: execve() arg 2 must contain only strings Traceback (most recent call last): File "/home/uke/oil/bin/oils_for_unix.py", line 202, in <module> sys.exit(main(sys.argv)) File "/home/uke/oil/bin/oils_for_unix.py", line 171, in main return AppBundleMain(argv) File "/home/uke/oil/bin/oils_for_unix.py", line 141, in AppBundleMain return shell.Main('osh', arg_r, environ, login_shell, loader, readline) File "/home/uke/oil/core/shell.py", line 1213, in Main cmd_flags=cmd_eval.IsMainProgram) File "/home/uke/oil/core/main_loop.py", line 375, in Batch is_return, is_fatal = cmd_ev.ExecuteAndCatch(node, cmd_flags) File "/home/uke/oil/osh/cmd_eval.py", line 2105, in ExecuteAndCatch status = self._Execute(node) File "/home/uke/oil/osh/cmd_eval.py", line 1904, in _Execute status = self._Dispatch(node, cmd_st) File "/home/uke/oil/osh/cmd_eval.py", line 1631, in _Dispatch status = self._DoSimple(node, cmd_st) File "/home/uke/oil/osh/cmd_eval.py", line 913, in _DoSimple status = self._RunSimpleCommand(cmd_val, cmd_st, run_flags) File "/home/uke/oil/osh/cmd_eval.py", line 574, in _RunSimpleCommand run_flags) File "/home/uke/oil/core/executor.py", line 494, in RunSimpleCommand status = p.RunProcess(self.waiter, trace.External(cmd_val.argv)) File "/home/uke/oil/core/process.py", line 1186, in RunProcess self.StartProcess(why) File "/home/uke/oil/core/process.py", line 1096, in StartProcess self.thunk.Run() File "/home/uke/oil/core/process.py", line 805, in Run self.ext_prog.Exec(self.argv0_path, self.cmd_val, self.environ) File "/home/uke/oil/core/process.py", line 692, in Exec True) File "/home/uke/oil/core/process.py", line 723, in _Exec posix.execve(argv0_path, argv, environ) TypeError: execve() arg 2 must contain only strings |
osh-cpp | 4 NUL bytes and IFS splitting [osh-cpp stdout] Expected "[]\n['']\n['ab']\n['ab']\n", got "['']\n['']\n['a']\n['a']\n" stdout: [''] [''] ['a'] ['a']stderr: |
osh | 5 NUL bytes with test -n stdout: status=1 status=0stderr: |
osh-cpp | 5 NUL bytes with test -n stdout: status=1 status=0stderr: |
osh | 6 NUL bytes with test -f [osh stdout] Expected 'status=1\nstatus=0\nstatus=0\nstatus=1\n', got '' [osh status] Expected 0, got 1 [osh stderr] Found 'Traceback (most recent' stdout: stderr: Traceback (most recent call last): File "/home/uke/oil/bin/oils_for_unix.py", line 202, in <module> sys.exit(main(sys.argv)) File "/home/uke/oil/bin/oils_for_unix.py", line 171, in main return AppBundleMain(argv) File "/home/uke/oil/bin/oils_for_unix.py", line 141, in AppBundleMain return shell.Main('osh', arg_r, environ, login_shell, loader, readline) File "/home/uke/oil/core/shell.py", line 1213, in Main cmd_flags=cmd_eval.IsMainProgram) File "/home/uke/oil/core/main_loop.py", line 375, in Batch is_return, is_fatal = cmd_ev.ExecuteAndCatch(node, cmd_flags) File "/home/uke/oil/osh/cmd_eval.py", line 2105, in ExecuteAndCatch status = self._Execute(node) File "/home/uke/oil/osh/cmd_eval.py", line 1904, in _Execute status = self._Dispatch(node, cmd_st) File "/home/uke/oil/osh/cmd_eval.py", line 1631, in _Dispatch status = self._DoSimple(node, cmd_st) File "/home/uke/oil/osh/cmd_eval.py", line 913, in _DoSimple status = self._RunSimpleCommand(cmd_val, cmd_st, run_flags) File "/home/uke/oil/osh/cmd_eval.py", line 574, in _RunSimpleCommand run_flags) File "/home/uke/oil/core/executor.py", line 452, in RunSimpleCommand return self.RunBuiltin(builtin_id, cmd_val) File "/home/uke/oil/core/executor.py", line 313, in RunBuiltin return self.RunBuiltinProc(builtin_proc, cmd_val) File "/home/uke/oil/core/executor.py", line 323, in RunBuiltinProc status = builtin_proc.Run(cmd_val) File "/home/uke/oil/builtin/bracket_osh.py", line 278, in Run b = bool_ev.EvalB(bool_node) File "/home/uke/oil/osh/sh_expr_eval.py", line 1173, in EvalB return bool_stat.DoUnaryOp(op_id, s) File "/home/uke/oil/osh/bool_stat.py", line 46, in DoUnaryOp st = posix.stat(s) TypeError: stat() argument 1 must be encoded string without null bytes, not str |
osh | 7 NUL bytes with ${#s} (OSH and zsh agree) stdout: empty=0 nul=1stderr: |
osh-cpp | 7 NUL bytes with ${#s} (OSH and zsh agree) stdout: empty=0 nul=1stderr: |