Using binary in _tmp/native-tar-test ~/oil/_tmp/native-tar-test/oils-for-unix-0.25.0 ~/oil _build/oils.sh: Building oils-for-unix: _bin/cxx-opt-sh/oils-for-unix PWD = /home/uke/oil/_tmp/native-tar-test/oils-for-unix-0.25.0 cxx = cxx variant = opt translator = mycpp skip_rebuild = true _build/oils.sh: SKIPPING build because _bin/cxx-opt-sh/oils-for-unix exists ~/oil Exported OSH=/home/uke/oil/_tmp/native-tar-test/oils-for-unix-0.25.0/_bin/cxx-opt-sh/osh ~/oil/_clone/ble.sh ~/oil ble.sh: insane environment: $USER is empty. ble.sh: modified USER=uke ble.sh: suspicious environment: $LANG is empty. shopt -s checkwinsize ^~~~~ out/ble.osh:2403: 'shopt' got invalid option 'checkwinsize' ble/term.sh: updating tput cache for TERM=xterm... mawk: line 37: regular expression compile failed (missing operand) ^('[^']*'|\$'([^\\']|\\.)*'|\$?"([^\\"]|\\.)*"|\\.|[^[:space:]"'`;&|()])* ble/term.sh: updating tput cache for TERM=xterm... done osh warning: The 'RETURN' hook isn't implemented real 0.402 user 0.258 sys 0.053 real 0.140 user 0.007 sys 0.005 declare -i i=1 ^~~~~~~ lib/test-util.sh:175: 'declare' doesn't implement flag -i (shopt --set ignore_flags_not_impl) declare -u u=a ^~~~~~~ lib/test-util.sh:181: Warning: OSH doesn't implement flags -l or -u (shopt --set ignore_flags_not_impl) declare -l l=B ^~~~~~~ lib/test-util.sh:182: Warning: OSH doesn't implement flags -l or -u (shopt --set ignore_flags_not_impl) declare -c c=c ^~ lib/test-util.sh:183: 'declare' doesn't accept flag -c Running out/ble.osh DONE Running out/ble.osh Running lib/test-main.sh lib/test-main.sh:58: ble/util/readlink f.txt [[ $ret != /* ]] && ret=${PWD%/}/$ret --- 2419.ret.expect 2025-01-02 16:33:33.299859915 +0000 +++ 2419.ret.result 2025-01-02 16:33:33.299859915 +0000 @@ -1 +1 @@ -/tmp/blesh/1000/2344.test/2419.d/ab/cd/ef/file.txt +/tmp/blesh/1000/2344.test/2419.d/ef/file.txt lib/test-main.sh:80: path=phys.link/1.txt ble/util/readlink/.resolve-physical-directory declare -p path PWD >&2 [[ $path == */phys.dir/1.txt && $PWD == "$pwd" ]] --- 2419.exit.expect 2025-01-02 16:33:33.355859878 +0000 +++ 2419.exit.result 2025-01-02 16:33:33.355859878 +0000 @@ -1 +1 @@ -0 +1 declare -- path=/tmp/blesh/1000/2344.test/2419.d/1.txt declare -x PWD=/tmp/blesh/1000/2344.test/2419.d lib/test-main.sh:101: [[ ${value//$pattern/$'\n'} == $'\n'hello$'\n' ]] --- 2452.exit.expect 2025-01-02 16:33:33.375859866 +0000 +++ 2452.exit.result 2025-01-02 16:33:33.375859866 +0000 @@ -1 +1 @@ -0 +1 84.2% [section] ble/main: 16/19 (3 fail, 0 crash, 0 skip) DONE Running lib/test-main.sh Running lib/test-util.sh lib/test-util.sh:190: ble/variable#get-attr i; ret=$attr --- 2463.ret.expect 2025-01-02 16:33:33.555859748 +0000 +++ 2463.ret.result 2025-01-02 16:33:33.555859748 +0000 @@ -1 +1 @@ -i + lib/test-util.sh:191: ble/variable#get-attr x; ret=$attr --- 2463.ret.expect 2025-01-02 16:33:33.559859746 +0000 +++ 2463.ret.result 2025-01-02 16:33:33.559859746 +0000 @@ -1 +1 @@ -x + lib/test-util.sh:192: ble/variable#get-attr r; ret=$attr --- 2463.ret.expect 2025-01-02 16:33:33.567859740 +0000 +++ 2463.ret.result 2025-01-02 16:33:33.567859740 +0000 @@ -1 +1 @@ -r + lib/test-util.sh:195: ble/variable#get-attr u; ret=$attr --- 2463.ret.expect 2025-01-02 16:33:33.575859735 +0000 +++ 2463.ret.result 2025-01-02 16:33:33.575859735 +0000 @@ -1 +1 @@ -u + lib/test-util.sh:196: ble/variable#get-attr l; ret=$attr --- 2463.ret.expect 2025-01-02 16:33:33.583859729 +0000 +++ 2463.ret.result 2025-01-02 16:33:33.583859729 +0000 @@ -1 +1 @@ -l + lib/test-util.sh:197: ble/variable#get-attr c; ret=$attr --- 2463.ret.expect 2025-01-02 16:33:33.591859725 +0000 +++ 2463.ret.result 2025-01-02 16:33:33.591859725 +0000 @@ -1 +1 @@ -c + lib/test-util.sh:203: ble/variable#has-attr i i --- 2463.exit.expect 2025-01-02 16:33:33.599859719 +0000 +++ 2463.exit.result 2025-01-02 16:33:33.599859719 +0000 @@ -1 +1 @@ -0 +1 lib/test-util.sh:204: ble/variable#has-attr x x --- 2463.exit.expect 2025-01-02 16:33:33.631859698 +0000 +++ 2463.exit.result 2025-01-02 16:33:33.635859695 +0000 @@ -1 +1 @@ -0 +1 lib/test-util.sh:205: ble/variable#has-attr r r --- 2463.exit.expect 2025-01-02 16:33:33.643859690 +0000 +++ 2463.exit.result 2025-01-02 16:33:33.643859690 +0000 @@ -1 +1 @@ -0 +1 lib/test-util.sh:212: ble/variable#has-attr u u --- 2463.exit.expect 2025-01-02 16:33:33.651859685 +0000 +++ 2463.exit.result 2025-01-02 16:33:33.651859685 +0000 @@ -1 +1 @@ -0 +1 lib/test-util.sh:213: ble/variable#has-attr l l --- 2463.exit.expect 2025-01-02 16:33:33.659859680 +0000 +++ 2463.exit.result 2025-01-02 16:33:33.659859680 +0000 @@ -1 +1 @@ -0 +1 lib/test-util.sh:214: ble/variable#has-attr c c --- 2463.exit.expect 2025-01-02 16:33:33.667859674 +0000 +++ 2463.exit.result 2025-01-02 16:33:33.667859674 +0000 @@ -1 +1 @@ -0 +1 lib/test-util.sh:226: ble/is-inttype i --- 2463.exit.expect 2025-01-02 16:33:33.675859670 +0000 +++ 2463.exit.result 2025-01-02 16:33:33.675859670 +0000 @@ -1 +1 @@ -0 +1 lib/test-util.sh:228: ble/is-readonly r --- 2463.exit.expect 2025-01-02 16:33:33.683859664 +0000 +++ 2463.exit.result 2025-01-02 16:33:33.683859664 +0000 @@ -1 +1 @@ -0 +1 lib/test-util.sh:231: ble/is-transformed u --- 2463.exit.expect 2025-01-02 16:33:33.691859660 +0000 +++ 2463.exit.result 2025-01-02 16:33:33.691859660 +0000 @@ -1 +1 @@ -0 +1 lib/test-util.sh:232: ble/is-transformed l --- 2463.exit.expect 2025-01-02 16:33:33.699859654 +0000 +++ 2463.exit.result 2025-01-02 16:33:33.699859654 +0000 @@ -1 +1 @@ -0 +1 lib/test-util.sh:233: ble/is-transformed c --- 2463.exit.expect 2025-01-02 16:33:33.707859649 +0000 +++ 2463.exit.result 2025-01-02 16:33:33.707859649 +0000 @@ -1 +1 @@ -0 +1 lib/test-util.sh:251: is-global v0 --- 2498.exit.expect 2025-01-02 16:33:33.723859639 +0000 +++ 2498.exit.result 2025-01-02 16:33:33.723859639 +0000 @@ -1 +1 @@ -0 +1 lib/test-util.sh:252: is-global v1 --- 2498.exit.expect 2025-01-02 16:33:33.731859633 +0000 +++ 2498.exit.result 2025-01-02 16:33:33.731859633 +0000 @@ -1 +1 @@ -0 +1 lib/test-util.sh:257: ble/variable#is-global v0 --- 2498.exit.expect 2025-01-02 16:33:33.755859618 +0000 +++ 2498.exit.result 2025-01-02 16:33:33.755859618 +0000 @@ -1 +1 @@ -0 +1 lib/test-util.sh:258: ble/variable#is-global v1 --- 2498.exit.expect 2025-01-02 16:33:33.763859612 +0000 +++ 2498.exit.result 2025-01-02 16:33:33.763859612 +0000 @@ -1 +1 @@ -0 +1 lib/test-util.sh:263: ble/variable#is-global v0u --- 2498.exit.expect 2025-01-02 16:33:33.787859596 +0000 +++ 2498.exit.result 2025-01-02 16:33:33.787859596 +0000 @@ -1 +1 @@ -0 +1 lib/test-util.sh:265: ble/variable#is-global v1u --- 2498.exit.expect 2025-01-02 16:33:33.823859573 +0000 +++ 2498.exit.result 2025-01-02 16:33:33.823859573 +0000 @@ -1 +1 @@ -0 +1 lib/test-util.sh:597: ble/string#split-lines a "" ; status --- 2546.stdout.expect 2025-01-02 16:33:34.331859241 +0000 +++ 2546.stdout.result 2025-01-02 16:33:34.331859241 +0000 @@ -1 +1 @@ -1:() +0:() lib/test-util.sh:599: ble/string#split-lines a " " ; status --- 2546.stdout.expect 2025-01-02 16:33:34.339859235 +0000 +++ 2546.stdout.result 2025-01-02 16:33:34.339859235 +0000 @@ -1 +1 @@ -2:( ) +0:() lib/test-util.sh:600: ble/string#split-lines a "1 " ; status --- 2546.stdout.expect 2025-01-02 16:33:34.347859231 +0000 +++ 2546.stdout.result 2025-01-02 16:33:34.347859231 +0000 @@ -1 +1 @@ -2:(1 ) +1:(1) lib/test-util.sh:601: ble/string#split-lines a " 2" ; status --- 2546.stdout.expect 2025-01-02 16:33:34.355859225 +0000 +++ 2546.stdout.result 2025-01-02 16:33:34.355859225 +0000 @@ -1 +1 @@ -2:( 2) +0:() lib/test-util.sh:602: ble/string#split-lines a "1 3" ; status --- 2546.stdout.expect 2025-01-02 16:33:34.363859220 +0000 +++ 2546.stdout.result 2025-01-02 16:33:34.363859220 +0000 @@ -1 +1 @@ -3:(1 3) +1:(1) lib/test-util.sh:782: ble/string#quote-command echo hello world --- 2564.ret.expect 2025-01-02 16:33:34.751858966 +0000 +++ 2564.ret.result 2025-01-02 16:33:34.751858966 +0000 @@ -1 +1 @@ -echo 'hello' 'world' +echo hello world lib/test-util.sh:784: ble/string#quote-command echo "'test'" --- 2564.ret.expect 2025-01-02 16:33:34.763858959 +0000 +++ 2564.ret.result 2025-01-02 16:33:34.763858959 +0000 @@ -1 +1 @@ -echo ''\''test'\''' +echo $'\'test\'' lib/test-util.sh:786: ble/string#quote-command echo a{1..4} --- 2564.ret.expect 2025-01-02 16:33:34.799858936 +0000 +++ 2564.ret.result 2025-01-02 16:33:34.799858936 +0000 @@ -1 +1 @@ -echo 'a1' 'a2' 'a3' 'a4' +echo a1 a2 a3 a4 lib/test-util.sh:790: ble/util/print-quoted-command echo hello world --- 2564.stdout.expect 2025-01-02 16:33:34.807858930 +0000 +++ 2564.stdout.result 2025-01-02 16:33:34.807858930 +0000 @@ -1 +1 @@ -echo 'hello' 'world' +echo hello world lib/test-util.sh:792: ble/util/print-quoted-command echo "'test'" --- 2564.stdout.expect 2025-01-02 16:33:34.815858926 +0000 +++ 2564.stdout.result 2025-01-02 16:33:34.815858926 +0000 @@ -1 +1 @@ -echo ''\''test'\''' +echo $'\'test\'' lib/test-util.sh:794: ble/util/print-quoted-command echo a{1..4} --- 2564.stdout.expect 2025-01-02 16:33:34.827858917 +0000 +++ 2564.stdout.result 2025-01-02 16:33:34.827858917 +0000 @@ -1 +1 @@ -echo 'a1' 'a2' 'a3' 'a4' +echo a1 a2 a3 a4 lib/test-util.sh:843: ble/util/strlen α --- 2579.ret.expect 2025-01-02 16:33:34.919858857 +0000 +++ 2579.ret.result 2025-01-02 16:33:34.919858857 +0000 @@ -1 +1 @@ -2 +1 lib/test-util.sh:844: ble/util/strlen αβγ --- 2579.ret.expect 2025-01-02 16:33:34.927858852 +0000 +++ 2579.ret.result 2025-01-02 16:33:34.927858852 +0000 @@ -1 +1 @@ -6 +3 lib/test-util.sh:845: ble/util/strlen あ --- 2579.ret.expect 2025-01-02 16:33:34.991858810 +0000 +++ 2579.ret.result 2 ble/function#advice/original:f1 ^~~ [ eval arg at line 4396 of out/ble.osh ]:1 builtin eval -- "$1"; local ext=$? ^~~~ out/ble.osh:4396: 'ble/function#advice/original:f1' not found (OILS-ERR-100) ble/function#advice/original:f1 ^~~ [ eval arg at line 4396 of out/ble.osh ]:1 builtin eval -- "$1"; local ext=$? ^~~~ out/ble.osh:4396: 'ble/function#advice/original:f1' not found (OILS-ERR-100) ble/function#advice/original:f1 ^~~ [ eval arg at line 4396 of out/ble.osh ]:1 builtin eval -- "$1"; local ext=$? ^~~~ out/ble.osh:4396: 'ble/function#advice/original:f1' not found (OILS-ERR-100) 025-01-02 16:33:34.991858810 +0000 @@ -1 +1 @@ -3 +1 lib/test-util.sh:846: ble/util/strlen あいう --- 2579.ret.expect 2025-01-02 16:33:34.999858804 +0000 +++ 2579.ret.result 2025-01-02 16:33:34.999858804 +0000 @@ -1 +1 @@ -9 +3 lib/test-util.sh:847: ble/util/strlen aα --- 2579.ret.expect 2025-01-02 16:33:35.007858799 +0000 +++ 2579.ret.result 2025-01-02 16:33:35.007858799 +0000 @@ -1 +1 @@ -3 +2 lib/test-util.sh:848: ble/util/strlen aαあ --- 2579.ret.expect 2025-01-02 16:33:35.011858798 +0000 +++ 2579.ret.result 2025-01-02 16:33:35.015858794 +0000 @@ -1 +1 @@ -6 +3 lib/test-util.sh:852: ble/util/strlen α --- 2579.ret.expect 2025-01-02 16:33:35.019858791 +0000 +++ 2579.ret.result 2025-01-02 16:33:35.019858791 +0000 @@ -1 +1 @@ -2 +1 lib/test-util.sh:853: ble/util/strlen あ --- 2579.ret.expect 2025-01-02 16:33:35.027858787 +0000 +++ 2579.ret.result 2025-01-02 16:33:35.027858787 +0000 @@ -1 +1 @@ -3 +1 lib/test-util.sh:885: ble/util/substr あいう 0 3 --- 2596.ret.expect 2025-01-02 16:33:35.091858745 +0000 +++ 2596.ret.result 2025-01-02 16:33:35.091858745 +0000 @@ -1 +1 @@ -あ +あいう lib/test-util.sh:886: ble/util/substr あいう 3 6 --- 2596.ret.expect 2025-01-02 16:33:35.095858743 +0000 +++ 2596.ret.result 2025-01-02 16:33:35.095858743 +0000 @@ -1 +1 @@ -いう + lib/test-util.sh:887: ble/util/substr あいう 0 1 --- 2596.ret.expect 2025-01-02 16:33:35.103858737 +0000 +++ 2596.ret.result 2025-01-02 16:33:35.103858737 +0000 @@ -1 +1 @@ - +あ lib/test-util.sh:888: ble/util/substr あいう 1 2 --- 2596.ret.expect 2025-01-02 16:33:35.111858732 +0000 +++ 2596.ret.result 2025-01-02 16:33:35.111858732 +0000 @@ -1 +1 @@ - +いう lib/test-util.sh:889: ble/util/substr あいう 1 4 --- 2596.ret.expect 2025-01-02 16:33:35.115858729 +0000 +++ 2596.ret.result 2025-01-02 16:33:35.115858729 +0000 @@ -1 +1 @@ - +いう lib/test-util.sh:890: ble/util/substr あいう 7 5 --- 2596.ret.expect 2025-01-02 16:33:35.123858724 +0000 +++ 2596.ret.result 2025-01-02 16:33:35.123858724 +0000 @@ -1 +1 @@ - + lib/test-util.sh:1239: ble/util/mapfile a < <(echo); status --- 2614.stdout.expect 2025-01-02 16:33:35.759858308 +0000 +++ 2614.stdout.result 2025-01-02 16:33:35.759858308 +0000 @@ -1 +1 @@ -1:() +0:() lib/test-util.sh:1240: ble/util/mapfile a < <(echo;echo); status --- 2614.stdout.expect 2025-01-02 16:33:35.771858301 +0000 +++ 2614.stdout.result 2025-01-02 16:33:35.771858301 +0000 @@ -1 +1 @@ -2:( ) +0:() lib/test-util.sh:1241: ble/util/mapfile a < <(echo a;echo;echo b); status --- 2614.stdout.expect 2025-01-02 16:33:35.779858295 +0000 +++ 2614.stdout.result 2025-01-02 16:33:35.779858295 +0000 @@ -1 +1 @@ -3:(a b) +1:(a) lib/test-util.sh:1259: ble/util/assign-array a echo; status --- 2614.stdout.expect 2025-01-02 16:33:35.799858282 +0000 +++ 2614.stdout.result 2025-01-02 16:33:35.799858282 +0000 @@ -1 +1 @@ -1:() +0:() lib/test-util.sh:1262: ble/util/assign-array a "echo; echo; echo"; status --- 2614.stdout.expect 2025-01-02 16:33:35.811858274 +0000 +++ 2614.stdout.result 2025-01-02 16:33:35.811858274 +0000 @@ -1 +1 @@ -3:( ) +0:() lib/test-util.sh:1263: ble/util/assign-array a "echo 1; echo; echo 2"; status --- 2614.stdout.expect 2025-01-02 16:33:35.819858269 +0000 +++ 2614.stdout.result 2025-01-02 16:33:35.819858269 +0000 @@ -1 +1 @@ -3:(1 2) +1:(1) lib/test-util.sh:1360: f1 --- 2698.stdout.expect 2025-01-02 16:33:36.131858066 +0000 +++ 2698.stdout.result 2025-01-02 16:33:36.131858066 +0000 @@ -1,2 +1 @@ pre -original ble/function#advice/original:"${ADVICE_WORDS[@]}" ^~~ out/ble.osh:4505: 'ble/function#advice/original:f1' not found (OILS-ERR-100) lib/test-util.sh:1362: f1 --- 2698.stdout.expect 2025-01-02 16:33:36.143858058 +0000 +++ 2698.stdout.result 2025-01-02 16:33:36.143858058 +0000 @@ -1,3 +1,2 @@ pre -original post ble/function#advice/original:"${ADVICE_WORDS[@]}" ^~~ out/ble.osh:4505: 'ble/function#advice/original:f1' not found (OILS-ERR-100) lib/test-util.sh:1364: f1 --- 2698.stdout.expect 2025-01-02 16:33:36.151858053 +0000 ++ ble/function#advice/original:f1 ^~~ [ eval arg at line 4396 of out/ble.osh ]:1 builtin eval -- "$1"; local ext=$? ^~~~ out/ble.osh:4396: 'ble/function#advice/original:f1' not found (OILS-ERR-100) ble/function#advice/original:f1 ^~~ [ eval arg at line 4396 of out/ble.osh ]:1 builtin eval -- "$1"; local ext=$? ^~~~ out/ble.osh:4396: 'ble/function#advice/original:f1' not found (OILS-ERR-100) ble/function#advice/original:f1 ^~~ [ eval arg at line 4396 of out/ble.osh ]:1 builtin eval -- "$1"; local ext=$? ^~~~ out/ble.osh:4396: 'ble/function#advice/original:f1' not found (OILS-ERR-100) ble/function#push/0:echo ^~~ [ eval arg at line 4396 of out/ble.osh ]:1 builtin eval -- "$1"; local ext=$? ^~~~ out/ble.osh:4396: 'ble/function#push/0:echo' not found (OILS-ERR-100) ble/function#push/0:echo ^~~ [ eval arg at line 4396 of out/ble.osh ]:1 builtin eval -- "$1"; local ext=$? ^~~~ out/ble.osh:4396: 'ble/function#push/0:echo' not found (OILS-ERR-100) ble/function#push/0:echo ^~~ [ eval arg at line 4396 of out/ble.osh ]:1 builtin eval -- "$1"; local ext=$? ^~~~ out/ble.osh:4396: 'ble/function#push/0:echo' not found (OILS-ERR-100) ble/function#pop: echo is not a function. ble/function#pop: echo is not a function. + 2698.stdout.result 2025-01-02 16:33:36.151858053 +0000 @@ -1,3 +1,2 @@ A -original post ble/function#advice/original:"${ADVICE_WORDS[@]}" ^~~ out/ble.osh:4505: 'ble/function#advice/original:f1' not found (OILS-ERR-100) lib/test-util.sh:1366: f1 --- 2698.stdout.expect 2025-01-02 16:33:36.163858045 +0000 +++ 2698.stdout.result 2025-01-02 16:33:36.163858045 +0000 @@ -1,3 +1,2 @@ A -original B ble/function#advice/original:"${ADVICE_WORDS[@]}" ^~~ out/ble.osh:4505: 'ble/function#advice/original:f1' not found (OILS-ERR-100) lib/test-util.sh:1368: f1 --- 2698.stdout.expect 2025-01-02 16:33:36.171858039 +0000 +++ 2698.stdout.result 2025-01-02 16:33:36.171858039 +0000 @@ -1,5 +1,4 @@ A [ -original ] B ble/function#advice/original:"${ADVICE_WORDS[@]}" ^~~ out/ble.osh:4505: 'ble/function#advice/original:f1' not found (OILS-ERR-100) lib/test-util.sh:1374: f1 --- 2698.stdout.expect 2025-01-02 16:33:36.179858034 +0000 +++ 2698.stdout.result 2025-01-02 16:33:36.179858034 +0000 @@ -1,5 +1,4 @@ A [ -original quick ] B ble/function#advice/original:"${ADVICE_WORDS[@]}" ^~~ out/ble.osh:4505: 'ble/function#advice/original:f1' not found (OILS-ERR-100) lib/test-util.sh:1377: f1 --- 2698.stdout.expect 2025-01-02 16:33:36.187858029 +0000 +++ 2698.stdout.result 2025-01-02 16:33:36.187858029 +0000 @@ -1 +1 @@ -original + --- 2698.exit.expect 2025-01-02 16:33:36.191858026 +0000 +++ 2698.exit.result 2025-01-02 16:33:36.195858024 +0000 @@ -1 +1 @@ -0 +127 ble/function#advice/original:"${ADVICE_WORDS[@]}" ^~~ out/ble.osh:4505: 'ble/function#advice/original:f1' not found (OILS-ERR-100) lib/test-util.sh:1378: f1 1 --- 2698.stdout.expect 2025-01-02 16:33:36.199858021 +0000 +++ 2698.stdout.result 2025-01-02 16:33:36.199858021 +0000 @@ -1 +1 @@ -original 1 + --- 2698.exit.expect 2025-01-02 16:33:36.207858016 +0000 +++ 2698.exit.result 2025-01-02 16:33:36.207858016 +0000 @@ -1 +1 @@ -0 +127 ble/function#advice/original:"${ADVICE_WORDS[@]}" ^~~ out/ble.osh:4505: 'ble/function#advice/original:f1' not found (OILS-ERR-100) lib/test-util.sh:1391: echo 1 2 3 --- 2719.stdout.expect 2025-01-02 16:33:36.255857984 +0000 +++ 2719.stdout.result 2025-01-02 16:33:36.255857984 +0000 @@ -1,3 +1,3 @@ A -(1 2 3) +1 2 3 Z lib/test-util.sh:1393: echo 1 2 3 --- 2719.stdout.expect 2025-01-02 16:33:36.263857979 +0000 +++ 2719.stdout.result 2025-01-02 16:33:36.263857979 +0000 @@ -1,5 +1,3 @@ [ -A -(1 2 3) -Z +1 2 3 ] lib/test-util.sh:1396: echo 1 2 3 --- 2719.stdout.expect 2025-01-02 16:33:36.271857974 +0000 +++ 2719.stdout.result 2025-01-02 16:33:36.271857974 +0000 @@ -1,3 +1 @@ -A -(1 2 3) -Z +1 2 3 lib/test-util.sh:1398: echo 1 2 3 --- 2719.stdout.expect 2025-01-02 16:33:36.279857969 +0000 +++ 2719.stdout.result 2025-01-02 16:33:36.279857969 +0000 @@ -1 +1 @@ -(1 2 3) +1 2 3 lib/test-util.sh:1400: echo 1 2 3 --- 2719.stdout.expect 2025-01-02 16:33:36.283857967 +0000 +++ 2719.stdout.result 2025-01-02 16:33:36.283857967 +0000 @@ -1 +1 @@ -[1 2 3] +1 2 3 lib/test-util.sh:1401: ble/is-function echo --- 2719.exit.expect 2025-01-02 16:33:36.291857961 +0000 +++ 2719.exit.result 2025-01-02 16:33:36.291857961 +0000 @@ -1 +1 @@ -0 +1 lib/test-util.sh:1402: ble/function#pop echo --- 2719.exit.expect 2025-01-02 16:33:36.299857956 +0000 +++ 2719.exit.result 2025-01-02 16:33:36.299857956 +0000 @@ -1 +1 @@ -0 +1 ble/function#pop: echo is not a function. lib/test-util.sh:1439: ble/util/sprintf ret "[%#.2g]" 27 --- 2735.ret.expect 2025-01-02 16:33:36.391857896 +0000 +++ 2735.ret.result 2025-01-02 16:33:36.391857896 +0000 @@ -1 +1 @@ -[27.] +[1b] [%#.2g] ^ [ printf arg at line 4690 of out/ble.osh ]:1 lib/test-util.sh:1440: ble/util/sprintf ret "[%#.2f]" 27 --- 2735.ret.expect 2025-01-02 16:33:36.399857891 +0000 +++ 2735.ret.result 2025-01-02 16:33:36.399857891 +0000 @@ -1 +1 @@ -[27.00] +[1b] [%#.2f] ^ [ printf arg at line 4690 of out/ble.osh ]:1 lib/test-util.sh:1478: ble/alias#expand aaa1 --- 2741.ret.expect 2025-01-02 16:33:36.487857833 +0000 +++ 2741.ret.result 2025-01-02 16:33:36.487857833 +0000 @@ -1 +1 @@ -aaa2 world +aaa1 lib/test-util.sh:1480: ble/alias#expand aaa2 --- 2741.ret.expect 2025-01-02 16:33:36.495857828 +0000 +++ 2741.ret.result 2025-01-02 16:33:36.495857828 +0000 @@ -1 +1 @@ -aaa3 hello +aaa2 lib/test-util.sh:1481: ble/alias#expand aaa1 --- 2741.ret.expect 2025-01-02 16:33:36.503857822 +0000 +++ 2741.ret.result 2025-01-02 16:33:36.503857822 +0000 @@ -1 +1 @@ -aaa2 world +aaa1 lib/test-util.sh:1483: ble/alias#expand aaa3 --- 2741.ret.expect 2025-01-02 16:33:36.507857820 +0000 +++ 2741.ret.result 2025-01-02 16:33:36.507857820 +0000 @@ -1 +1 @@ -aaa4 +aaa3 lib/test-util.sh:1484: ble/alias#expand aaa2 --- 2741.ret.expect 2025-01-02 16:33:36.515857815 +0000 +++ 2741.ret.result 2025-01-02 16:33:36.515857815 +0000 @@ -1 +1 @@ -aaa3 hello +aaa2 lib/test-util.sh:1485: ble/alias#expand aaa1 --- 2741.ret.expect 2025-01-02 16:33:36.523857809 +0000 +++ 2741.ret.result 2025-01-02 16:33:36.523857809 +0000 @@ -1 +1 @@ -aaa2 world +aaa1 lib/test-util.sh:1487: ble/alias#expand aaa4 --- 2741.ret.expect 2025-01-02 16:33:36.527857807 +0000 +++ 2741.ret.result 2025-01-02 16:33:36.531857805 +0000 @@ -1 +1 @@ -echo +aaa4 lib/test-util.sh:1488: ble/alias#expand aaa3 --- 2741.ret.expect 2025-01-02 16:33:36.535857801 +0000 +++ 2741.ret.result 2025-01-02 16:33:36.535857801 +0000 @@ -1 +1 @@ -aaa4 +aaa3 lib/test-util.sh:1489: ble/alias#expand aaa2 --- 2741.ret.expect 2025-01-02 16:33:36.543857796 +0000 +++ 2741.ret.result 2025-01-02 16:33:36.543857796 +0000 @@ -1 +1 @@ -aaa3 hello +aaa2 lib/test-util.sh:1490: ble/alias#expand aaa1 --- 2741.ret.expect 2025-01-02 16:33:36.547857794 +0000 +++ 2741.ret.result 2025-01-02 16:33:36.547857794 +0000 @@ -1 +1 @@ -aaa2 world +aaa1 lib/test-util.sh:1582: declare -p v2a xv2a | cat -v >&2; [[ $v2a == $xv2a ]] --- 2780.exit.expect 2025-01-02 16:33:36.731857674 +0000 +++ 2780.exit.result 2025-01-02 16:33:36.731857674 +0000 @@ -1 +1 @@ -0 +1 declare -- xv2a=a lib/test-util.sh:1582: declare -p v2b xv2b | cat -v >&2; [[ $v2b == $xv2b ]] --- 2780.exit.expect 2025-01-02 16:33:36.743857666 +0000 +++ 2780.exit.result 2025-01-02 16:33:36.743857666 +0000 @@ -1 +1 @@ -0 +1 declare -- xv2b=ab lib/test-util.sh:1582: declare -p v3a xv3a | cat -v >&2; [[ $v3a == $xv3a ]] --- 2780.exit.expect 2025-01-02 16:33:36.751857660 +0000 +++ 2780.exit.result 2025-01-02 16:33:36.751857660 +0000 @@ -1 +1 @@ -0 +1 declare -- xv3a=' ' lib/test-util.sh:1582: declare -p v3b xv3b | cat -v >&2; [[ $v3b == $xv3b ]] --- 2780.exit.expect 2025-01-02 16:33:36.763857653 +0000 +++ 2780.exit.result 2025-01-02 16:33:36.763857653 +0000 @@ -1 +1 @@ -0 +1 declare -- xv3b='a b' lib/test-util.sh:1582: declare -p v4a xv4a | cat -v >&2; [[ $v4a == $xv4a ]] --- 2780.exit.expect 2025-01-02 16:33:36.771857647 +0000 +++ 2780.exit.result 2025-01-02 16:33:36.771857647 +0000 @@ -1 +1 @@ -0 +1 declare -- xv4a=$'\n' lib/test-util.sh:1582: declare -p v4b xv4b | cat -v >&2; [[ $v4b == $xv4b ]] --- 2780.exit.expect 2025-01-02 16:33:36.779857643 +0000 +++ 2780.exit.result 2025-01-02 16:33:36.779857643 +0000 @@ -1 +1 @@ -0 +1 declare -- xv4b=$'a\nb' lib/test-util.sh:1582: declare -p v5a xv5a | cat -v >&2; [[ $v5a == $xv5a ]] --- 2780.exit.expect 2025-01-02 16:33:36.791857634 +0000 +++ 2780.exit.result 2025-01-02 16:33:36.791857634 +0000 @@ -1 +1 @@ -0 +1 declare -- xv5a=$'\r' lib/test-util.sh:1582: declare -p v5b xv5b | cat -v >&2; [[ $v5b == $xv5b ]] --- 2780.exit.expect 2025-01-02 16:33:36.799857629 +0000 +++ 2780.exit.result 2025-01-02 16:33:36.799857629 +0000 @@ -1 +1 @@ -0 +1 declare -- xv5b=$'a\rb' lib/test-util.sh:1582: declare -p v6a xv6a | cat -v >&2; [[ $v6a == $xv6a ]] --- 2780.exit.expect 2025-01-02 16:33:36.811857622 +0000 +++ 2780.exit.result 2025-01-02 16:33:36.811857622 +0000 @@ -1 +1 @@ -0 +1 declare -- xv6a=$'\u0001' lib/test-util.sh:1582: declare -p v6b xv6b | cat -v >&2; [[ $v6b == $xv6b ]] --- 2780.exit.expect 2025-01-02 16:33:36.819857616 +0000 +++ 2780.exit.result 2025-01-02 16:33:36.819857616 +0000 @@ -1 +1 @@ -0 +1 declare -- xv6b=$'a\u0001b' lib/test-util.sh:1582: declare -p v7a xv7a | cat -v >&2; [[ $v7a == $xv7a ]] --- 2780.exit.expect 2025-01-02 16:33:36.831857608 +0000 +++ 2780.exit.result 2025-01-02 16:33:36.831857608 +0000 @@ -1 +1 @@ -0 +1 declare -- xv7a=$'\u0002' lib/test-util.sh:1582: declare -p v7b xv7b | cat -v >&2; [[ $v7b == $xv7b ]] --- 2780.exit.expect 2025-01-02 16:33:36.839857603 +0000 +++ 2780.exit.result 2025-01-02 16:33:36.839857603 +0000 @@ -1 +1 @@ -0 +1 declare -- xv7b=$'a\u0002b' lib/test-util.sh:1582: declare -p v8a xv8a | cat -v >&2; [[ $v8a == $xv8a ]] --- 2780.exit.expect 2025-01-02 16:33:36.851857595 +0000 +++ 2780.exit.result 2025-01-02 16:33:36.851857595 +0000 @@ -1 +1 @@ -0 +1 declare -- xv8a='^?' lib/test-util.sh:1582: declare -p v8b xv8b | cat -v >&2; [[ $v8b == $xv8b ]] --- 2780.exit.expect 2025-01-02 16:33:36.859857590 +0000 +++ 2780.exit.result 2025-01-02 16:33:36.859857590 +0000 @@ -1 +1 @@ -0 +1 declare -- xv8b='a^?b' lib/test-util.sh:1604: status a1 --- 2780.ret.expect 2025-01-02 16:33:36.871857582 +0000 +++ 2780.ret.result 2025-01-02 16:33:36.871857582 +0000 @@ -1 +1 @@ -1:() +0:() lib/test-util.sh:1604: status a2 --- 2780.ret.expect 2025-01-02 16:33:36.879857578 +0000 +++ 2780.ret.result 2025-01-02 16:33:36.879857578 +0000 @@ -1 +1 @@ -2:(a ab) +0:() lib/test-util.sh:1604: status a3 --- 2780.ret.expect 2025-01-02 16:33:36.887857572 +0000 +++ 2780.ret.result 2025-01-02 16:33:36.887857572 +0000 @@ -1 +1 @@ -2:( a b) +0:() lib/test-util.sh:1604: status a4 --- 2780.ret.expect 2025-01-02 16:33:36.891857569 +0000 +++ 2780.ret.result 2025-01-02 16:33:36.895857567 +0000 @@ -1,3 +1 @@ -2:( - a -b) +0:() lib/test-util.sh:1604: status a5 --- 2780.ret.expect 2025-01-02 16:33:36.899857564 +0000 +++ 2780.ret.result 2025-01-02 16:33:36.899857564 +0000 @@ -1 +1 @@ -2:( a b) +0:() lib/test-util.sh:1604: status a6 --- 2780.ret.expect 2025-01-02 16:33:36.907857559 +0000 +++ 2780.ret.result 2025-01-02 16:33:36.907857559 +0000 @@ -1 +1 @@ -2:( ab) +0:() lib/test-util.sh:1604: status a7 --- 2780.ret.expect 2025-01-02 16:33:36.915857553 +0000 +++ 2780.ret.result 2025-01-02 16:33:36.915857553 +0000 @@ -1 +1 @@ -2:( ab) +0:() lib/test-util.sh:1604: status a8 --- 2780.ret.expect 2025-01-02 16:33:36.919857551 +0000 +++ 2780.ret.result 2025-01-02 16:33:36.919857551 +0000 @@ -1 +1 @@ -2:( ab) +0:() lib/test-util.sh:1615: [[ ! ${v0+set} ]] --- 2861.exit.expect 2025-01-02 16:33:36.939857538 +0000 +++ 2861.exit.result 2025-01-02 16:33:36.939857538 +0000 @@ -1 +1 @@ -0 +1 lib/test-util.sh:1616: status v1 --- 2861.stdout.expect 2025-01-02 16:33:36.947857532 +0000 +++ 2861.stdout.result 2025-01-02 16:33:36.947857532 +0000 @@ -1 +1 @@ -1:(123) +1:(2) lib/test-util.sh:1617: status v2 --- 2861.stdout.expect 2025-01-02 16:33:36.955857527 +0000 +++ 2861.stdout.result 2025-01-02 16:33:36.955857527 +0000 @@ -1 +1 @@ -3:(1 2 3) +1:(3) lib/test-util.sh:1618: status v3 --- 2861.stdout.expect 2025-01-02 16:33:36.959857525 +0000 +++ 2861.stdout.result 2025-01-02 16:33:36.963857522 +0000 @@ -1 +1 @@ -1:(bbb) +3:(bbb) lib/test-util.sh:1619: status v4 --- 2861.stdout.expect 2025-01-02 16:33:36.967857519 +0000 +++ 2861.stdout.result 2025-01-02 16:33:36.967857519 +0000 @@ -1 +1 @@ -1:(ccc) +1:(5) lib/test-util.sh:1631: ble/util/print-global-definitions value --- 2861.stdout.expect 2025-01-02 16:33:36.983857509 +0000 +++ 2861.stdout.result 2025-01-02 16:33:36.983857509 +0000 @@ -1 +1 @@ -declare value='hello '\''world'\''' +declare value; builtin unset -v value lib/test-util.sh:1668: shopt -q failglob --- 2878.exit.expect 2025-01-02 16:33:37.019857485 +0000 +++ 2878.exit.result 2025-01-02 16:33:37.019857485 +0000 @@ -1 +1 @@ -0 +1 lib/test-util.sh:1669: shopt -q nullglob --- 2878. ble/function#push/0:ble/util/msleep ^~~ [ eval arg at line 4396 of out/ble.osh ]:1 builtin eval -- "$1"; local ext=$? ^~~~ out/ble.osh:4396: 'ble/function#push/0:ble/util/msleep' not found (OILS-ERR-100) [%1] PID 2911 Started [%2] PID 2913 Started set -m; ble/bin/sleep 10 & pid3=$!; set +m ^~ lib/test-util.sh:1700: 'set' got invalid flag '-m' [%3] PID 2915 Started set -m; ble/bin/sleep 10 & pid3=$!; set +m ^ lib/test-util.sh:1700: 'set' got invalid flag '-m' exit.expect 2025-01-02 16:33:37.027857481 +0000 +++ 2878.exit.result 2025-01-02 16:33:37.027857481 +0000 @@ -1 +1 @@ -0 +1 lib/test-util.sh:1670: shopt -q extglob --- 2878.exit.expect 2025-01-02 16:33:37.031857477 +0000 +++ 2878.exit.result 2025-01-02 16:33:37.031857477 +0000 @@ -1 +1 @@ -0 +1 lib/test-util.sh:1681: ble-measure -q "ble/util/msleep 100"; echo "$ret usec" >&2; ((msec=ret/1000,90<=msec&&msec<=120)) --- 2888.exit.expect 2025-01-02 16:33:37.167857386 +0000 +++ 2888.exit.result 2025-01-02 16:33:37.167857386 +0000 @@ -1 +1 @@ -0 +1 0 usec lib/test-util.sh:1682: ble-measure -q "ble/util/sleep 0.1"; echo "$ret usec" >&2; ((msec=ret/1000,90<=msec&&msec<=120)) --- 2888.exit.expect 2025-01-02 16:33:37.279857317 +0000 +++ 2888.exit.result 2025-01-02 16:33:37.279857317 +0000 @@ -1 +1 @@ -0 +1 0 usec lib/test-util.sh:1690: ble/util/conditional-sync 'ble/bin/sleep 10' '((time<1000))' 100 --- 2895.stdout.expect 2025-01-02 16:33:47.295848542 +0000 +++ 2895.stdout.result 2025-01-02 16:33:47.295848542 +0000 @@ -1,10 +1 @@ 100 -200 -300 -400 -500 -600 -700 -800 -900 -1000 [%1] PID 2897 Started [%1] PID 2897 Done lib/test-util.sh:1692: ble/util/conditional-sync 'ble/bin/sleep 10' '((time<1000))' 100 progressive-weight --- 2895.stdout.expect 2025-01-02 16:33:57.315838068 +0000 +++ 2895.stdout.result 2025-01-02 16:33:57.315838068 +0000 @@ -1,16 +1 @@ 1 -3 -7 -15 -31 -63 -127 -227 -327 -427 -527 -627 -727 -827 -927 -1027 [%1] PID 2902 Started [%1] PID 2902 Done lib/test-util.sh:1694: ble/util/conditional-sync 'ble/bin/sleep 10' 'true' 100 timeout=10 --- 2895.exit.expect 2025-01-02 16:34:07.327819772 +0000 +++ 2895.exit.result 2025-01-02 16:34:07.327819772 +0000 @@ -1 +1 @@ -142 +0 [%1] PID 2907 Started [%1] PID 2907 Done lib/test-util.sh:1709: kill -0 "$pid1" --- 2895.exit.expect 2025-01-02 16:34:07.375819735 +0000 +++ 2895.exit.result 2025-01-02 16:34:07.375819735 +0000 @@ -1 +1 @@ -1 +0 lib/test-util.sh:1710: kill -0 "$pid2" --- 2895.exit.expect 2025-01-02 16:34:07.383819729 +0000 +++ 2895.exit.result 2025-01-02 16:34:07.383819729 +0000 @@ -1 +1 @@ -1 +0 lib/test-util.sh:1711: kill -0 "$pid3" --- 2895.exit.expect 2025-01-02 16:34:07.395819720 +0000 +++ 2895.exit.result 2025-01-02 16:34:07.395819720 +0000 @@ -1 +1 @@ -1 +0 lib/test-util.sh:1736: ble/util/get-pager ret --- 2949.ret.expect 2025-01-02 16:34:07.447819680 +0000 +++ 2949.ret.result 2025-01-02 16:34:07.447819680 +0000 @@ -1 +1 @@ -less +pager lib/test-util.sh:1758: ble/util/buffer.flush --- 2954.stdout.expect 2025-01-02 16:34:07.467819665 +0000 +++ 2954.stdout.result 2025-01-02 16:34:07.467819665 +0000 @@ -1 +1 @@ -helloworld + lib/test-util.sh:1762: ble/util/buffer.flush --- 2954.stdout.expect 2025-01-02 16:34:07.475819659 +0000 +++ 2954.stdout.result 2025-01-02 16:34:07.475819659 +0000 @@ -1,2 +1 @@ -hello -world + lib/test-util.sh:1958: ble/util/c2s 956; [[ $ret != μ ]] --- 2960.exit.expect 2025-01-02 16:34:07.535819610 +0000 +++ 2960.exit.result 2025-01-02 16:34:07.539819607 +0000 @@ -1 +1 @@ -0 +1 lib/test-util.sh:1959: ble/util/c2s 12354; [[ $ret != あ ]] --- 2960.exit.expect 2025-01-02 16:34:07.543819604 +0000 +++ 2960.exit.result 2025-01-02 16:34:07.547819600 +0000 @@ -1 +1 @@ -0 +1 lib/test-util.sh:1989: ble/util/chars2s --- 2966.ret.expect 2025-01-02 16:34:07.579819575 +0000 +++ 2966.ret.result 2025-01-02 16:34:07.579819575 +0000 @@ -1 +1 @@ - +12354 \\U%08x ^ [ printf arg at line 10195 of out/ble.osh ]:1 lib/test-util.sh:2006: ble/util/keyseq2chars 'b\C-@c'; ret="${ret[*]}" --- 2969.ret.expect 2025-01-02 16:34:07.699819477 +0000 +++ 2969.ret.result 2025-01-02 16:34:07.699819477 +0000 @@ -1 +1 @@ -98 0 99 +98 0 lib/test-util.sh:2006: ble/util/keyseq2chars 'b\C-ac'; ret="${ret[*]}" --- 2969.ret.expect 2025-01-02 16:34:07.711819468 +0000 +++ 2969.ret.result 2025-01-02 16:34:07.711819468 +0000 @@ -1 +1 @@ -98 1 99 +98 1 lib/test-util.sh:2006: ble/util/keyseq2chars 'b\C-zc'; ret="${ret[*]}" --- 2969.ret.expect 2025-01-real 34.582 user 0.039 sys 0.062 real 0.074 user 0.003 sys 0.001 02 16:34:07.723819458 +0000 +++ 2969.ret.result 2025-01-02 16:34:07.723819458 +0000 @@ -1 +1 @@ -98 26 99 +98 26 lib/test-util.sh:2006: ble/util/keyseq2chars 'b\C-]c'; ret="${ret[*]}" --- 2969.ret.expect 2025-01-02 16:34:07.735819448 +0000 +++ 2969.ret.result 2025-01-02 16:34:07.735819448 +0000 @@ -1 +1 @@ -98 29 99 +98 29 lib/test-util.sh:2006: ble/util/keyseq2chars 'b\C-^c'; ret="${ret[*]}" --- 2969.ret.expect 2025-01-02 16:34:07.767819422 +0000 +++ 2969.ret.result 2025-01-02 16:34:07.767819422 +0000 @@ -1 +1 @@ -98 30 99 +98 30 lib/test-util.sh:2006: ble/util/keyseq2chars 'b\C-_c'; ret="${ret[*]}" --- 2969.ret.expect 2025-01-02 16:34:07.779819413 +0000 +++ 2969.ret.result 2025-01-02 16:34:07.779819413 +0000 @@ -1 +1 @@ -98 31 99 +98 31 lib/test-util.sh:2006: ble/util/keyseq2chars 'b\M-\C-@c'; ret="${ret[*]}" --- 2969.ret.expect 2025-01-02 16:34:07.791819403 +0000 +++ 2969.ret.result 2025-01-02 16:34:07.791819403 +0000 @@ -1 +1 @@ -98 27 0 99 +98 27 0 89.1% [section] ble/util: 1095/1228 (133 fail, 0 crash, 6 skip) DONE Running lib/test-util.sh Running lib/test-decode.sh 100.0% [section] ble/decode: 33/33 (0 fail, 0 crash, 0 skip) DONE Running lib/test-decode.sh ~/oil DONE