61 passed, 9 OK, 14 not implemented, 10 BUG, 2 failed, 0 timeouts, 0 cases skipped 2 failed under osh
| dash | 0 NUL bytes with echo -e stdout: stderr: |
| zsh | 0 NUL bytes with echo -e stdout: \0 \n 00 0astderr: |
| dash | 1 printf - literal NUL in format string stdout: stderr: |
| zsh | 1 printf - literal NUL in format string stdout: x \0 z 78 00 7a --- x \0 z 78 00 7a --- \0 z 00 7astderr: |
| ash | 1 printf - literal NUL in format string stdout: stderr: |
| dash | 3 printf - NUL byte in value (OSH and zsh agree) stdout: stderr: |
| zsh | 3 printf - NUL byte in value (OSH and zsh agree) stdout: \0 \n 00 0a \0 \n 00 0astderr: |
| osh | 3 printf - NUL byte in value (OSH and zsh agree) stdout: \0 \n 00 0a \0 \n 00 0astderr: |
| dash | 4 NUL bytes with echo $'\0' (OSH and zsh agree) stdout: stderr: |
| zsh | 4 NUL bytes with echo $'\0' (OSH and zsh agree) stdout: \0 \n 00 0astderr: |
| osh | 4 NUL bytes with echo $'\0' (OSH and zsh agree) stdout: \0 \n 00 0astderr: |
| dash | 5 NUL bytes and IFS splitting stdout: stderr: |
| zsh | 5 NUL bytes and IFS splitting stdout: ['', ''] [''] ['a', 'b'] ['a']stderr: |
| dash | 6 NUL bytes with test -n stdout: stderr: |
| zsh | 6 NUL bytes with test -n stdout: status=0 status=0stderr: |
| osh | 6 NUL bytes with test -n stdout: status=1 status=0stderr: |
| dash | 7 NUL bytes with test -f stdout: stderr: |
| ash | 7 NUL bytes with test -f stdout: status=1 status=0 status=1 status=1stderr: |
| osh | 7 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 263, in <module>
sys.exit(main(sys.argv))
File "/home/uke/oil/bin/oils_for_unix.py", line 232, in main
return AppBundleMain(argv)
File "/home/uke/oil/bin/oils_for_unix.py", line 198, in AppBundleMain
bash_compat=(applet == 'bash'))
File "/home/uke/oil/core/shell.py", line 1296, in Main
cmd_flags=cmd_eval.IsMainProgram)
File "/home/uke/oil/core/main_loop.py", line 336, in Batch
was_parsed, status = Batch2(cmd_ev, c_parser, errfmt, cmd_flags=cmd_flags)
File "/home/uke/oil/core/main_loop.py", line 401, in Batch2
is_return, is_fatal = cmd_ev.ExecuteAndCatch(node, cmd_flags)
File "/home/uke/oil/osh/cmd_eval.py", line 2365, in ExecuteAndCatch
status = self._Execute(node)
File "/home/uke/oil/osh/cmd_eval.py", line 2164, in _Execute
status = self._Dispatch(node, cmd_st)
File "/home/uke/oil/osh/cmd_eval.py", line 1891, in _Dispatch
status = self._DoSimple(node, cmd_st)
File "/home/uke/oil/osh/cmd_eval.py", line 1153, in _DoSimple
status = self._RunSimpleCommand(cmd_val, cmd_st, run_flags)
File "/home/uke/oil/osh/cmd_eval.py", line 766, in _RunSimpleCommand
run_flags)
File "/home/uke/oil/core/vm.py", line 235, in RunSimpleCommand
run_flags)
File "/home/uke/oil/core/executor.py", line 577, in _RunSimpleCommand
return self.RunBuiltin(builtin_id, cmd_val)
File "/home/uke/oil/core/vm.py", line 266, in RunBuiltin
return self._RunBuiltinProc(builtin_proc, cmd_val)
File "/home/uke/oil/core/vm.py", line 276, in _RunBuiltinProc
status = builtin_proc.Run(cmd_val)
File "/home/uke/oil/builtin/bracket_osh.py", line 277, in Run
b = bool_ev.EvalB(bool_node)
File "/home/uke/oil/osh/sh_expr_eval.py", line 1184, 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
|
| dash | 8 NUL bytes with ${#s} (OSH and zsh agree) stdout: stderr: |
| zsh | 8 NUL bytes with ${#s} (OSH and zsh agree) stdout: empty=0 nul=1stderr: |
| osh | 8 NUL bytes with ${#s} (OSH and zsh agree) stdout: empty=0 nul=1stderr: |
| zsh | 9 Compare \x00 byte versus \x01 byte - command sub stdout: len=3 2e 01 2e len=3 2e 00 2e len=1 00stderr: |
| zsh | 10 Compare \x00 byte versus \x01 byte - read builtin stdout: len=3 2e 01 2e len=3 2e 00 2e len=1 00stderr: |
| dash | 11 Compare \x00 byte versus \x01 byte - read -n stdout: stderr: |
| mksh | 11 Compare \x00 byte versus \x01 byte - read -n stdout: len=3 2e 01 2e len=1 2e len=0stderr: |
| zsh | 11 Compare \x00 byte versus \x01 byte - read -n stdout: len=0 len=1 2e len=0stderr: |
| dash | 12 Compare \x00 byte versus \x01 byte - mapfile builtin stdout: stderr: |
| mksh | 12 Compare \x00 byte versus \x01 byte - mapfile builtin stdout: stderr: |
| zsh | 12 Compare \x00 byte versus \x01 byte - mapfile builtin stdout: stderr: |
| ash | 12 Compare \x00 byte versus \x01 byte - mapfile builtin stdout: stderr: |
| osh | 12 Compare \x00 byte versus \x01 byte - mapfile builtin [osh stdout] Expected 'len=2\n 2e\n 2e\n' Got 'len=2\n 2e 00 2e\n 2e 00 2e\n' stdout: len=2 2e 00 2e 2e 00 2estderr: |
| zsh | 13 Strip ops # ## % %% with NUL bytes stdout: len=3 00 2e 00 --- len=2 2e 00 len=2 2e 00 len=2 00 2e len=2 00 2estderr: |
| zsh | 14 Issue 2269 Reduction stdout: len=2 00 78 len=1 78 --- len=2 01 78 len=1 78stderr: |
| zsh | 15 Issue 2269 - Do NUL bytes match ? in ${a#?} stdout: escaped that'"'"'s it! that's it! --- writes binary datastderr: len=9 len=8 len=7 len=6 len=5 len=4 len=3 len=2 len=1 len=0 |