~/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:2815: 'shopt' got invalid option 'checkwinsize'
ble/term.sh: updating tput cache for TERM=xterm... 
ble/term.sh: updating tput cache for TERM=xterm... done
osh warning: The 'RETURN' hook isn't implemented
real	8.264
user	7.959
sys	0.178
real	0.973
user	0.205
sys	0.019
    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 --lib


DONE Running out/ble.osh --lib


Running lib/test-main.sh

lib/test-main.sh:25: set -o posix; f2;                 ret=$?; set +o posix
--- 1086.ret.expect	2025-03-01 23:56:57.546141708 +0000
+++ 1086.ret.result	2025-03-01 23:56:57.546141708 +0000
@@ -1 +1 @@
-0
+1

lib/test-main.sh:57: ! ble/bin#has ble_test_dummy_4
--- 1090.exit.expect	2025-03-01 23:56:57.763140177 +0000
+++ 1090.exit.result	2025-03-01 23:56:57.763140177 +0000
@@ -1 +1 @@
-0
+1

lib/test-main.sh:88: 
    ble/util/readlink f.txt
    [[ $ret != /* ]] && ret=${PWD%/}/$ret
--- 1093.ret.expect	2025-03-01 23:56:57.889139287 +0000
+++ 1093.ret.result	2025-03-01 23:56:57.889139287 +0000
@@ -1 +1 @@
-/tmp/blesh/1000/999.test/1093.d/ab/cd/ef/file.txt
+/tmp/blesh/1000/999.test/1093.d/ef/file.txt

lib/test-main.sh:110: 
    path=phys.link/1.txt
    ble/util/readlink/.resolve-physical-directory
    declare -p path PWD >&2
    [[ $path == */phys.dir/1.txt && $PWD == "$pwd" ]]
--- 1093.exit.expect	2025-03-01 23:56:58.098137812 +0000
+++ 1093.exit.result	2025-03-01 23:56:58.098137812 +0000
@@ -1 +1 @@
-0
+1
<STDERR>
declare -- path=/tmp/blesh/1000/999.test/1093.d/1.txt
declare -x PWD=/tmp/blesh/1000/999.test/1093.d
</STDERR>

lib/test-main.sh:131: [[ ${value//$pattern/$'\n'} == $'\n'hello$'\n' ]]
--- 1126.exit.expect	2025-03-01 23:56:58.186137191 +0000
+++ 1126.exit.result	2025-03-01 23:56:58.187137184 +0000
@@ -1 +1 @@
-0
+1

 82.7% [section] ble/main: 24/29 (5 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
--- 1137.ret.expect	2025-03-01 23:56:59.627127414 +0000
+++ 1137.ret.result	2025-03-01 23:56:59.627127414 +0000
@@ -1 +1 @@
-i
+

lib/test-util.sh:191: ble/variable#get-attr x; ret=$attr
--- 1137.ret.expect	2025-03-01 23:56:59.660127199 +0000
+++ 1137.ret.result	2025-03-01 23:56:59.661127193 +0000
@@ -1 +1 @@
-x
+

lib/test-util.sh:192: ble/variable#get-attr r; ret=$attr
--- 1137.ret.expect	2025-03-01 23:56:59.694126978 +0000
+++ 1137.ret.result	2025-03-01 23:56:59.695126971 +0000
@@ -1 +1 @@
-r
+

lib/test-util.sh:195: ble/variable#get-attr u; ret=$attr
--- 1137.ret.expect	2025-03-01 23:56:59.740126679 +0000
+++ 1137.ret.result	2025-03-01 23:56:59.741126672 +0000
@@ -1 +1 @@
-u
+

lib/test-util.sh:196: ble/variable#get-attr l; ret=$attr
--- 1137.ret.expect	2025-03-01 23:56:59.775126451 +0000
+++ 1137.ret.result	2025-03-01 23:56:59.776126444 +0000
@@ -1 +1 @@
-l
+

lib/test-util.sh:197: ble/variable#get-attr c; ret=$attr
--- 1137.ret.expect	2025-03-01 23:56:59.811126217 +0000
+++ 1137.ret.result	2025-03-01 23:56:59.811126217 +0000
@@ -1 +1 @@
-c
+

lib/test-util.sh:203: ble/variable#has-attr i i
--- 1137.exit.expect	2025-03-01 23:56:59.857125918 +0000
+++ 1137.exit.result	2025-03-01 23:56:59.857125918 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:204: ble/variable#has-attr x x
--- 1137.exit.expect	2025-03-01 23:56:59.890125703 +0000
+++ 1137.exit.result	2025-03-01 23:56:59.891125697 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:205: ble/variable#has-attr r r
--- 1137.exit.expect	2025-03-01 23:56:59.924125482 +0000
+++ 1137.exit.result	2025-03-01 23:56:59.924125482 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:212: ble/variable#has-attr u u
--- 1137.exit.expect	2025-03-01 23:57:00.015124890 +0000
+++ 1137.exit.result	2025-03-01 23:57:00.015124890 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:213: ble/variable#has-attr l l
--- 1137.exit.expect	2025-03-01 23:57:00.049124669 +0000
+++ 1137.exit.result	2025-03-01 23:57:00.049124669 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:214: ble/variable#has-attr c c
--- 1137.exit.expect	2025-03-01 23:57:00.083124448 +0000
+++ 1137.exit.result	2025-03-01 23:57:00.083124448 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:226: ble/is-inttype i
--- 1137.exit.expect	2025-03-01 23:57:00.174123856 +0000
+++ 1137.exit.result	2025-03-01 23:57:00.174123856 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:228: ble/is-readonly r
--- 1137.exit.expect	2025-03-01 23:57:00.221123550 +0000
+++ 1137.exit.result	2025-03-01 23:57:00.222123544 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:231: ble/is-transformed u
--- 1137.exit.expect	2025-03-01 23:57:00.272123219 +0000
+++ 1137.exit.result	2025-03-01 23:57:00.272123219 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:232: ble/is-transformed l
--- 1137.exit.expect	2025-03-01 23:57:00.308122984 +0000
+++ 1137.exit.result	2025-03-01 23:57:00.309122978 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:233: ble/is-transformed c
--- 1137.exit.expect	2025-03-01 23:57:00.343122757 +0000
+++ 1137.exit.result	2025-03-01 23:57:00.344122750 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:251: is-global v0
--- 1172.exit.expect	2025-03-01 23:57:00.410122321 +0000
+++ 1172.exit.result	2025-03-01 23:57:00.410122321 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:252: is-global v1
--- 1172.exit.expect	2025-03-01 23:57:00.451122055 +0000
+++ 1172.exit.result	2025-03-01 23:57:00.451122055 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:257: ble/variable#is-global v0
--- 1172.exit.expect	2025-03-01 23:57:00.545121443 +0000
+++ 1172.exit.result	2025-03-01 23:57:00.546121437 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:258: ble/variable#is-global v1
--- 1172.exit.expect	2025-03-01 23:57:00.585121183 +0000
+++ 1172.exit.result	2025-03-01 23:57:00.586121177 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:263: ble/variable#is-global v0u
--- 1172.exit.expect	2025-03-01 23:57:00.683120546 +0000
+++ 1172.exit.result	2025-03-01 23:57:00.683120546 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:265: ble/variable#is-global v1u
--- 1172.exit.expect	2025-03-01 23:57:00.724120279 +0000
+++ 1172.exit.result	2025-03-01 23:57:00.724120279 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:597: ble/string#split-lines a ""  ; status
--- 1220.stdout.expect	2025-03-01 23:57:02.850106452 +0000
+++ 1220.stdout.result	2025-03-01 23:57:02.851106445 +0000
@@ -1 +1 @@
-1:()
+0:()

lib/test-util.sh:599: ble/string#split-lines a "
"  ; status
--- 1220.stdout.expect	2025-03-01 23:57:02.898106140 +0000
+++ 1220.stdout.result	2025-03-01 23:57:02.898106140 +0000
@@ -1 +1 @@
-2:( )
+0:()

lib/test-util.sh:600: ble/string#split-lines a "1
"  ; status
--- 1220.stdout.expect	2025-03-01 23:57:02.932105919 +0000
+++ 1220.stdout.result	2025-03-01 23:57:02.932105919 +0000
@@ -1 +1 @@
-2:(1 )
+1:(1)

lib/test-util.sh:601: ble/string#split-lines a "
2"  ; status
--- 1220.stdout.expect	2025-03-01 23:57:02.966105697 +0000
+++ 1220.stdout.result	2025-03-01 23:57:02.966105697 +0000
@@ -1 +1 @@
-2:( 2)
+0:()

lib/test-util.sh:602: ble/string#split-lines a "1

3"  ; status
--- 1220.stdout.expect	2025-03-01 23:57:03.000105476 +0000
+++ 1220.stdout.result	2025-03-01 23:57:03.000105476 +0000
@@ -1 +1 @@
-3:(1  3)
+1:(1)

lib/test-util.sh:782: ble/string#quote-command echo hello world
--- 1238.ret.expect	2025-03-01 23:57:04.772093951 +0000
+++ 1238.ret.result	2025-03-01 23:57:04.772093951 +0000
@@ -1 +1 @@
-echo 'hello' 'world'
+echo hello world

lib/test-util.sh:784: ble/string#quote-command echo "'test'"
--- 1238.ret.expect	2025-03-01 23:57:04.818093652 +0000
+++ 1238.ret.result	2025-03-01 23:57:04.819093646 +0000
@@ -1 +1 @@
-echo ''\''test'\'''
+echo $'\'test\''

lib/test-util.sh:786: ble/string#quote-command echo a{1..4}
--- 1238.ret.expect	2025-03-01 23:57:04.865093346 +0000
+++ 1238.ret.result	2025-03-01 23:57:04.865093346 +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
--- 1238.stdout.expect	2025-03-01 23:57:04.924092963 +0000
+++ 1238.stdout.result	2025-03-01 23:57:04.925092956 +0000
@@ -1 +1 @@
-echo 'hello' 'world'
+echo hello world

lib/test-util.sh:792: ble/util/print-quoted-command echo "'test'"
--- 1238.stdout.expect	2025-03-01 23:57:04.973092644 +0000
+++ 1238.stdout.result	2025-03-01 23:57:04.974092638 +0000
@@ -1 +1 @@
-echo ''\''test'\'''
+echo $'\'test\''

lib/test-util.sh:794: ble/util/print-quoted-command echo a{1..4}
--- 1238.stdout.expect	2025-03-01 23:57:05.020092339 +0000
+++ 1238.stdout.result	2025-03-01 23:57:05.020092339 +0000
@@ -1 +1 @@
-echo 'a1' 'a2' 'a3' 'a4'
+echo a1 a2 a3 a4

lib/test-util.sh:843: ble/util/strlen α
--- 1253.ret.expect	2025-  ble/function#advice/original:f1
  ^~~
[ eval arg at line 334 of out/ble.osh ]:1

    builtin eval -- "$1"; local ext=$?
            ^~~~
out/ble.osh:334: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
  ble/function#advice/original:f1
  ^~~
[ eval arg at line 334 of out/ble.osh ]:1

    builtin eval -- "$1"; local ext=$?
            ^~~~
out/ble.osh:334: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
  ble/function#advice/original:f1
  ^~~
[ eval arg at line 334 of out/ble.osh ]:1

    builtin eval -- "$1"; local ext=$?
            ^~~~
out/ble.osh:334: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
  ble/function#advice/original:f1
  ^~~
[ eval arg at line 334 of out/ble.osh ]:1

    builtin eval -- "$1"; local ext=$?
            ^~~~
out/ble.osh:334: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
03-01 23:57:05.696087942 +0000
+++ 1253.ret.result	2025-03-01 23:57:05.696087942 +0000
@@ -1 +1 @@
-2
+1

lib/test-util.sh:844: ble/util/strlen αβγ
--- 1253.ret.expect	2025-03-01 23:57:05.732087708 +0000
+++ 1253.ret.result	2025-03-01 23:57:05.732087708 +0000
@@ -1 +1 @@
-6
+3

lib/test-util.sh:845: ble/util/strlen あ
--- 1253.ret.expect	2025-03-01 23:57:05.767087480 +0000
+++ 1253.ret.result	2025-03-01 23:57:05.768087473 +0000
@@ -1 +1 @@
-3
+1

lib/test-util.sh:846: ble/util/strlen あいう
--- 1253.ret.expect	2025-03-01 23:57:05.804087240 +0000
+++ 1253.ret.result	2025-03-01 23:57:05.805087233 +0000
@@ -1 +1 @@
-9
+3

lib/test-util.sh:847: ble/util/strlen aα
--- 1253.ret.expect	2025-03-01 23:57:05.841086999 +0000
+++ 1253.ret.result	2025-03-01 23:57:05.841086999 +0000
@@ -1 +1 @@
-3
+2

lib/test-util.sh:848: ble/util/strlen aαあ
--- 1253.ret.expect	2025-03-01 23:57:05.877086765 +0000
+++ 1253.ret.result	2025-03-01 23:57:05.878086758 +0000
@@ -1 +1 @@
-6
+3

lib/test-util.sh:852: ble/util/strlen α
--- 1253.ret.expect	2025-03-01 23:57:05.925086453 +0000
+++ 1253.ret.result	2025-03-01 23:57:05.926086446 +0000
@@ -1 +1 @@
-2
+1

lib/test-util.sh:853: ble/util/strlen あ
--- 1253.ret.expect	2025-03-01 23:57:05.961086218 +0000
+++ 1253.ret.result	2025-03-01 23:57:05.961086218 +0000
@@ -1 +1 @@
-3
+1

lib/test-util.sh:885: ble/util/substr あいう 0 3
--- 1270.ret.expect	2025-03-01 23:57:06.329083825 +0000
+++ 1270.ret.result	2025-03-01 23:57:06.329083825 +0000
@@ -1 +1 @@
-あ
+あいう

lib/test-util.sh:886: ble/util/substr あいう 3 6
--- 1270.ret.expect	2025-03-01 23:57:06.364083597 +0000
+++ 1270.ret.result	2025-03-01 23:57:06.365083591 +0000
@@ -1 +1 @@
-いう
+

lib/test-util.sh:1243: ble/util/mapfile a < <(echo); status
--- 1280.stdout.expect	2025-03-01 23:57:11.020053043 +0000
+++ 1280.stdout.result	2025-03-01 23:57:11.021053037 +0000
@@ -1 +1 @@
-1:()
+0:()

lib/test-util.sh:1244: ble/util/mapfile a < <(echo;echo); status
--- 1280.stdout.expect	2025-03-01 23:57:11.057052800 +0000
+++ 1280.stdout.result	2025-03-01 23:57:11.058052794 +0000
@@ -1 +1 @@
-2:( )
+0:()

lib/test-util.sh:1245: ble/util/mapfile a < <(echo a;echo;echo b); status
--- 1280.stdout.expect	2025-03-01 23:57:11.096052544 +0000
+++ 1280.stdout.result	2025-03-01 23:57:11.096052544 +0000
@@ -1 +1 @@
-3:(a  b)
+1:(a)

lib/test-util.sh:1263: ble/util/assign-array a echo; status
--- 1280.stdout.expect	2025-03-01 23:57:11.236051624 +0000
+++ 1280.stdout.result	2025-03-01 23:57:11.236051624 +0000
@@ -1 +1 @@
-1:()
+0:()

lib/test-util.sh:1266: ble/util/assign-array a "echo; echo; echo"; status
--- 1280.stdout.expect	2025-03-01 23:57:11.310051138 +0000
+++ 1280.stdout.result	2025-03-01 23:57:11.311051131 +0000
@@ -1 +1 @@
-3:(  )
+0:()

lib/test-util.sh:1267: ble/util/assign-array a "echo 1; echo; echo 2"; status
--- 1280.stdout.expect	2025-03-01 23:57:11.346050901 +0000
+++ 1280.stdout.result	2025-03-01 23:57:11.347050895 +0000
@@ -1 +1 @@
-3:(1  2)
+1:(1)

lib/test-util.sh:1364: f1
--- 1364.stdout.expect	2025-03-01 23:57:12.400043976 +0000
+++ 1364.stdout.result	2025-03-01 23:57:12.401043970 +0000
@@ -1,2 +1 @@
 pre
-original
<STDERR>
    ble/function#advice/original:"${ADVICE_WORDS[@]}"
    ^~~
out/ble.osh:5028: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
</STDERR>

lib/test-util.sh:1366: f1
--- 1364.stdout.expect	2025-03-01 23:57:12.474043490 +0000
+++ 1364.stdout.result	2025-03-01 23:57:12.474043490 +0000
@@ -1,3 +1,2 @@
 pre
-original
 post
<STDERR>
    ble/function#advice/original:"${ADVICE_WORDS[@]}"
    ^~~
out/ble.osh:5028: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
</STDERR>

lib/test-util.sh:1368: f1
--- 1364.stdout.expect	2025-03-01 23:57:12.547043011 +0000
+++ 1364.stdout.result	2025-03-01 23:57:12.547043011 +0000
@@ -1,3 +1,2 @@
 A
-original
 post
<STDERR>
    ble/function#advice/original:"${ADVICE_WORDS[@]}"
    ^~~
out/ble.osh:5028: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
</STDERR>

lib/test-util.sh:1370: f1
--- 1364.stdout.expect	2025-03-01 23:57:12.620042531 +0000
+++ 1364.st  ble/function#advice/original:f1
  ^~~
[ eval arg at line 334 of out/ble.osh ]:1

    builtin eval -- "$1"; local ext=$?
            ^~~~
out/ble.osh:334: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
  ble/function#advice/original:f1
  ^~~
[ eval arg at line 334 of out/ble.osh ]:1

    builtin eval -- "$1"; local ext=$?
            ^~~~
out/ble.osh:334: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
  ble/function#push/0:echo
  ^~~
[ eval arg at line 334 of out/ble.osh ]:1

    builtin eval -- "$1"; local ext=$?
            ^~~~
out/ble.osh:334: 'ble/function#push/0:echo' not found (OILS-ERR-100)
  ble/function#push/0:echo
  ^~~
[ eval arg at line 334 of out/ble.osh ]:1

    builtin eval -- "$1"; local ext=$?
            ^~~~
out/ble.osh:334: 'ble/function#push/0:echo' not found (OILS-ERR-100)
  ble/function#push/0:echo
  ^~~
[ eval arg at line 334 of out/ble.osh ]:1

    builtin eval -- "$1"; local ext=$?
            ^~~~
out/ble.osh:334: '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.
dout.result	2025-03-01 23:57:12.620042531 +0000
@@ -1,3 +1,2 @@
 A
-original
 B
<STDERR>
    ble/function#advice/original:"${ADVICE_WORDS[@]}"
    ^~~
out/ble.osh:5028: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
</STDERR>

lib/test-util.sh:1372: f1
--- 1364.stdout.expect	2025-03-01 23:57:12.696042032 +0000
+++ 1364.stdout.result	2025-03-01 23:57:12.696042032 +0000
@@ -1,5 +1,4 @@
 A
 [
-original
 ]
 B
<STDERR>
    ble/function#advice/original:"${ADVICE_WORDS[@]}"
    ^~~
out/ble.osh:5028: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
</STDERR>

lib/test-util.sh:1378: f1
--- 1364.stdout.expect	2025-03-01 23:57:12.771041539 +0000
+++ 1364.stdout.result	2025-03-01 23:57:12.772041532 +0000
@@ -1,5 +1,4 @@
 A
 [
-original quick
 ]
 B
<STDERR>
    ble/function#advice/original:"${ADVICE_WORDS[@]}"
    ^~~
out/ble.osh:5028: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
</STDERR>

lib/test-util.sh:1381: f1
--- 1364.stdout.expect	2025-03-01 23:57:12.824041191 +0000
+++ 1364.stdout.result	2025-03-01 23:57:12.824041191 +0000
@@ -1 +1 @@
-original
+
--- 1364.exit.expect	2025-03-01 23:57:12.844041059 +0000
+++ 1364.exit.result	2025-03-01 23:57:12.844041059 +0000
@@ -1 +1 @@
-0
+127
<STDERR>
    ble/function#advice/original:"${ADVICE_WORDS[@]}"
    ^~~
out/ble.osh:5028: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
</STDERR>

lib/test-util.sh:1382: f1 1
--- 1364.stdout.expect	2025-03-01 23:57:12.891040750 +0000
+++ 1364.stdout.result	2025-03-01 23:57:12.891040750 +0000
@@ -1 +1 @@
-original 1
+
--- 1364.exit.expect	2025-03-01 23:57:12.911040619 +0000
+++ 1364.exit.result	2025-03-01 23:57:12.912040612 +0000
@@ -1 +1 @@
-0
+127
<STDERR>
    ble/function#advice/original:"${ADVICE_WORDS[@]}"
    ^~~
out/ble.osh:5028: 'ble/function#advice/original:f1' not found (OILS-ERR-100)
</STDERR>

lib/test-util.sh:1395: echo 1 2 3
--- 1385.stdout.expect	2025-03-01 23:57:13.040039771 +0000
+++ 1385.stdout.result	2025-03-01 23:57:13.041039765 +0000
@@ -1,3 +1,3 @@
 A
-(1 2 3)
+1 2 3
 Z

lib/test-util.sh:1397: echo 1 2 3
--- 1385.stdout.expect	2025-03-01 23:57:13.090039443 +0000
+++ 1385.stdout.result	2025-03-01 23:57:13.090039443 +0000
@@ -1,5 +1,3 @@
 [
-A
-(1 2 3)
-Z
+1 2 3
 ]

lib/test-util.sh:1400: echo 1 2 3
--- 1385.stdout.expect	2025-03-01 23:57:13.139039121 +0000
+++ 1385.stdout.result	2025-03-01 23:57:13.140039114 +0000
@@ -1,3 +1 @@
-A
-(1 2 3)
-Z
+1 2 3

lib/test-util.sh:1402: echo 1 2 3
--- 1385.stdout.expect	2025-03-01 23:57:13.178038865 +0000
+++ 1385.stdout.result	2025-03-01 23:57:13.178038865 +0000
@@ -1 +1 @@
-(1 2 3)
+1 2 3

lib/test-util.sh:1404: echo 1 2 3
--- 1385.stdout.expect	2025-03-01 23:57:13.217038608 +0000
+++ 1385.stdout.result	2025-03-01 23:57:13.218038602 +0000
@@ -1 +1 @@
-[1 2 3]
+1 2 3

lib/test-util.sh:1405: ble/is-function echo
--- 1385.exit.expect	2025-03-01 23:57:13.252038379 +0000
+++ 1385.exit.result	2025-03-01 23:57:13.253038372 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:1406: ble/function#pop echo
--- 1385.exit.expect	2025-03-01 23:57:13.288038142 +0000
+++ 1385.exit.result	2025-03-01 23:57:13.289038135 +0000
@@ -1 +1 @@
-0
+1
<STDERR>
ble/function#pop: echo is not a function.
</STDERR>

lib/test-util.sh:1443: ble/util/sprintf ret "[%#.2g]" 27
--- 1401.ret.expect	2025-03-01 23:57:13.555036388 +0000
+++ 1401.ret.result	2025-03-01 23:57:13.556036381 +0000
@@ -1 +1 @@
-[27.]
+[1b]
<STDERR>
  [%#.2g]
    ^
[ printf arg at line 5263 of out/ble.osh ]:1
</STDERR>

lib/test-util.sh:1444: ble/util/sprintf ret "[%#.2f]" 27
--- 1401.ret.expect	2025-03-01 23:57:13.591036151 +0000
+++ 1401.ret.result	2025-03-01 23:57:13.591036151 +0000
@@ -1 +1 @@
-[27.00]
+[1b]
<STDERR>
  [%#.2f]
    ^
[ printf arg at line 5263 of out/ble.osh ]:1
</STDERR>

lib/test-util.sh:1482: ble/alias#expand aaa1
--- 1407.ret.expect	2025-03-01 23:57:13.816034673 +0000
+++ 1407.ret.result	2025-03-01 23:57:13.816034673 +0000
@@ -1 +1 @@
-aaa2 world
+aaa1

lib/test-util.sh:1484: ble/alias#expand aaa2
--- 1407.ret.expect	2025-03-01 23:57:13.849034456 +0000
+++ 1407.ret.result	2025-03-01 23:57:13.8500344    elif [[ -t ${!1} ]]; then
               ^~
out/ble.osh:5825: fatal: Invalid file descriptor ''
  ble/function#push/0:ble/util/msleep
  ^~~
[ eval arg at line 334 of out/ble.osh ]:1

    builtin eval -- "$1"; local ext=$?
            ^~~~
out/ble.osh:334: 'ble/function#push/0:ble/util/msleep' not found (OILS-ERR-100)
49 +0000
@@ -1 +1 @@
-aaa3 hello
+aaa2

lib/test-util.sh:1485: ble/alias#expand aaa1
--- 1407.ret.expect	2025-03-01 23:57:13.883034233 +0000
+++ 1407.ret.result	2025-03-01 23:57:13.883034233 +0000
@@ -1 +1 @@
-aaa2 world
+aaa1

lib/test-util.sh:1487: ble/alias#expand aaa3
--- 1407.ret.expect	2025-03-01 23:57:13.918034003 +0000
+++ 1407.ret.result	2025-03-01 23:57:13.918034003 +0000
@@ -1 +1 @@
-aaa4
+aaa3

lib/test-util.sh:1488: ble/alias#expand aaa2
--- 1407.ret.expect	2025-03-01 23:57:13.951033786 +0000
+++ 1407.ret.result	2025-03-01 23:57:13.952033779 +0000
@@ -1 +1 @@
-aaa3 hello
+aaa2

lib/test-util.sh:1489: ble/alias#expand aaa1
--- 1407.ret.expect	2025-03-01 23:57:13.986033556 +0000
+++ 1407.ret.result	2025-03-01 23:57:13.986033556 +0000
@@ -1 +1 @@
-aaa2 world
+aaa1

lib/test-util.sh:1491: ble/alias#expand aaa4
--- 1407.ret.expect	2025-03-01 23:57:14.020033333 +0000
+++ 1407.ret.result	2025-03-01 23:57:14.020033333 +0000
@@ -1 +1 @@
-echo
+aaa4

lib/test-util.sh:1492: ble/alias#expand aaa3
--- 1407.ret.expect	2025-03-01 23:57:14.053033116 +0000
+++ 1407.ret.result	2025-03-01 23:57:14.054033109 +0000
@@ -1 +1 @@
-aaa4
+aaa3

lib/test-util.sh:1493: ble/alias#expand aaa2
--- 1407.ret.expect	2025-03-01 23:57:14.087032893 +0000
+++ 1407.ret.result	2025-03-01 23:57:14.087032893 +0000
@@ -1 +1 @@
-aaa3 hello
+aaa2

lib/test-util.sh:1494: ble/alias#expand aaa1
--- 1407.ret.expect	2025-03-01 23:57:14.120032675 +0000
+++ 1407.ret.result	2025-03-01 23:57:14.121032669 +0000
@@ -1 +1 @@
-aaa2 world
+aaa1

lib/test-util.sh:1619: [[ ! ${v0+set} ]]
--- 1481.exit.expect	2025-03-01 23:57:15.090026331 +0000
+++ 1481.exit.result	2025-03-01 23:57:15.090026331 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:1620: status v1
--- 1481.stdout.expect	2025-03-01 23:57:15.124026113 +0000
+++ 1481.stdout.result	2025-03-01 23:57:15.125026107 +0000
@@ -1 +1 @@
-1:(123)
+1:(2)

lib/test-util.sh:1621: status v2
--- 1481.stdout.expect	2025-03-01 23:57:15.159025890 +0000
+++ 1481.stdout.result	2025-03-01 23:57:15.160025883 +0000
@@ -1 +1 @@
-3:(1 2 3)
+1:(3)

lib/test-util.sh:1622: status v3
--- 1481.stdout.expect	2025-03-01 23:57:15.215025532 +0000
+++ 1481.stdout.result	2025-03-01 23:57:15.215025532 +0000
@@ -1 +1 @@
-1:(bbb)
+3:(bbb)

lib/test-util.sh:1623: status v4
--- 1481.stdout.expect	2025-03-01 23:57:15.250025308 +0000
+++ 1481.stdout.result	2025-03-01 23:57:15.250025308 +0000
@@ -1 +1 @@
-1:(ccc)
+1:(5)

lib/test-util.sh:1635: ble/util/print-global-definitions value
--- 1481.stdout.expect	2025-03-01 23:57:15.324024835 +0000
+++ 1481.stdout.result	2025-03-01 23:57:15.325024829 +0000
@@ -1 +1 @@
-declare value='hello '\''world'\'''
+declare value; builtin unset -v value

lib/test-util.sh:1672: shopt -q failglob
--- 1498.exit.expect	2025-03-01 23:57:15.619022950 +0000
+++ 1498.exit.result	2025-03-01 23:57:15.620022944 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:1673: shopt -q nullglob
--- 1498.exit.expect	2025-03-01 23:57:15.652022739 +0000
+++ 1498.exit.result	2025-03-01 23:57:15.652022739 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:1674: shopt -q extglob
--- 1498.exit.expect	2025-03-01 23:57:15.685022529 +0000
+++ 1498.exit.result	2025-03-01 23:57:15.686022522 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:1685: ble-measure -q "ble/util/msleep 100"; echo "$ret usec" >&2; ((msec=ret/1000,90<=msec&&msec<=120))
--- 1508.exit.expect	2025-03-01 23:57:15.946020864 +0000
+++ 1508.exit.result	2025-03-01 23:57:15.946020864 +0000
@@ -1 +1 @@
-0
+1
<STDERR>
0 usec
</STDERR>

lib/test-util.sh:1686: ble-measure -q "ble/util/sleep 0.1"; echo "$ret usec" >&2; ((msec=ret/1000,90<=msec&&msec<=120))
--- 1508.exit.expect	2025-03-01 23:57:16.105019845 +0000
+++ 1508.exit.result	2025-03-01 23:57:16.106019839 +0000
@@ -1 +1 @@
-0
+1
<STDERR>
0 usec
</STDERR>

lib/test-util.sh:1694: ble/util/conditional-sync 'ble/bin/sleep 10' '((time<1000))' 100
--- 1515.stdout.expect	2025-03-01 23:57:26.196955330 +0000
+++ 1515.stdout.result	2025-03-01 23:57:26.196955330 +0000
@@ -1,10 +1 @@
 100
-200
-300
-400
-500
-600
-700
-800
-900
-1000
<STDERR>
[%1] PID 1517 Started
[%1] PID 1517 Done
[%1] PID 1531 Started
[%2] PID 1533 Started
    set -m; ble/bin/sleep 10 & pid3=$!; set +m
        ^~
lib/test-util.sh:1704: 'set' got invalid flag '-m'
[%3] PID 1535 Started
    set -m; ble/bin/sleep 10 & pid3=$!; set +m
                                            ^
lib/test-util.sh:1704: 'set' got invalid flag '-m'
  ble/function#push/0:ble/util/idle/IS_IDLE
  ^~~
[ eval arg at line 334 of out/ble.osh ]:1

    builtin eval -- "$1"; local ext=$?
            ^~~~
out/ble.osh:334: 'ble/function#push/0:ble/util/idle/IS_IDLE' not found (OILS-ERR-100)
  ble/function#push/0:ble/util/.test-utf8-locale
  ^~~
[ eval arg at line 334 of out/ble.osh ]:1

    builtin eval -- "$1"; local ext=$?
            ^~~~
out/ble.osh:334: 'ble/function#push/0:ble/util/.test-utf8-locale' not found (OILS-ERR-100)
real	53.795
user	0.605
sys	0.130
real	0.609
user	0.088
sys	0.011
</STDERR>

lib/test-util.sh:1696: ble/util/conditional-sync 'ble/bin/sleep 10' '((time<1000))' 100 progressive-weight
--- 1515.stdout.expect	2025-03-01 23:57:36.261887668 +0000
+++ 1515.stdout.result	2025-03-01 23:57:36.261887668 +0000
@@ -1,16 +1 @@
 1
-3
-7
-15
-31
-63
-127
-227
-327
-427
-527
-627
-727
-827
-927
-1027
<STDERR>
[%1] PID 1522 Started
[%1] PID 1522 Done
</STDERR>

lib/test-util.sh:1698: ble/util/conditional-sync 'ble/bin/sleep 10' 'true' 100 timeout=10
--- 1515.exit.expect	2025-03-01 23:57:46.318820052 +0000
+++ 1515.exit.result	2025-03-01 23:57:46.319820046 +0000
@@ -1 +1 @@
-142
+0
<STDERR>
[%1] PID 1527 Started
[%1] PID 1527 Done
</STDERR>

lib/test-util.sh:1713: kill -0 "$pid1"
--- 1515.exit.expect	2025-03-01 23:57:46.468819060 +0000
+++ 1515.exit.result	2025-03-01 23:57:46.469819053 +0000
@@ -1 +1 @@
-1
+0

lib/test-util.sh:1714: kill -0 "$pid2"
--- 1515.exit.expect	2025-03-01 23:57:46.509818788 +0000
+++ 1515.exit.result	2025-03-01 23:57:46.509818788 +0000
@@ -1 +1 @@
-1
+0

lib/test-util.sh:1715: kill -0 "$pid3"
--- 1515.exit.expect	2025-03-01 23:57:46.548818530 +0000
+++ 1515.exit.result	2025-03-01 23:57:46.549818524 +0000
@@ -1 +1 @@
-1
+0

lib/test-util.sh:1740: ble/util/get-pager ret
--- 1569.ret.expect	2025-03-01 23:57:46.822816717 +0000
+++ 1569.ret.result	2025-03-01 23:57:46.822816717 +0000
@@ -1 +1 @@
-less
+pager

lib/test-util.sh:1763: ble/util/buffer.flush
--- 1574.stdout.expect	2025-03-01 23:57:46.905816168 +0000
+++ 1574.stdout.result	2025-03-01 23:57:46.905816168 +0000
@@ -1 +1 @@
-helloworld
+

lib/test-util.sh:1767: ble/util/buffer.flush
--- 1574.stdout.expect	2025-03-01 23:57:46.952815857 +0000
+++ 1574.stdout.result	2025-03-01 23:57:46.953815850 +0000
@@ -1,2 +1 @@
-hello
-world
+

lib/test-util.sh:2016: ble/util/c2s 956; [[ $ret != μ ]]
--- 1587.exit.expect	2025-03-01 23:57:48.473806030 +0000
+++ 1587.exit.result	2025-03-01 23:57:48.473806030 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:2017: ble/util/c2s 12354; [[ $ret != あ ]]
--- 1587.exit.expect	2025-03-01 23:57:48.509805797 +0000
+++ 1587.exit.result	2025-03-01 23:57:48.510805791 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:2047: ble/util/chars2s
--- 1593.ret.expect	2025-03-01 23:57:48.810803853 +0000
+++ 1593.ret.result	2025-03-01 23:57:48.811803847 +0000
@@ -1 +1 @@
-
+12354
<STDERR>
  \\U%08x
        ^
[ printf arg at line 11674 of out/ble.osh ]:1
</STDERR>

lib/test-util.sh:2064: ble/util/keyseq2chars 'b\C-@c'; ret="${ret[*]}"
--- 1596.ret.expect	2025-03-01 23:57:49.852797123 +0000
+++ 1596.ret.result	2025-03-01 23:57:49.853797117 +0000
@@ -1 +1 @@
-98 0 99
+98 0

lib/test-util.sh:2064: ble/util/keyseq2chars 'b\C-ac'; ret="${ret[*]}"
--- 1596.ret.expect	2025-03-01 23:57:49.956796452 +0000
+++ 1596.ret.result	2025-03-01 23:57:49.957796445 +0000
@@ -1 +1 @@
-98 1 99
+98 1

lib/test-util.sh:2064: ble/util/keyseq2chars 'b\C-zc'; ret="${ret[*]}"
--- 1596.ret.expect	2025-03-01 23:57:50.061795773 +0000
+++ 1596.ret.result	2025-03-01 23:57:50.062795767 +0000
@@ -1 +1 @@
-98 26 99
+98 26

lib/test-util.sh:2064: ble/util/keyseq2chars 'b\C-]c'; ret="${ret[*]}"
--- 1596.ret.expect	2025-03-01 23:57:50.166795095 +0000
+++ 1596.ret.result	2025-03-01 23:57:50.166795095 +0000
@@ -1 +1 @@
-98 29 99
+98 29

lib/test-util.sh:2064: ble/util/keyseq2chars 'b\C-^c'; ret="${ret[*]}"
--- 1596.ret.expect	2025-03-01 23:57:50.275794391 +0000
+++ 1596.ret.result	2025-03-01 23:57:50.275794391 +0000
@@ -1 +1 @@
-98 30 99
+98 30

lib/test-util.sh:2064: ble/util/keyseq2chars 'b\C-_c'; ret="${ret[*]}"
--- 1596.ret.expect	2025-03-01 23:57:50.385793681 +0000
+++ 1596.ret.result	2025-03-01 23:57:50.386793674 +0000
@@ -1 +1 @@
-98 31 99
+98 31

lib/test-util.sh:2064: ble/util/keyseq2chars 'b\M-\C-@c'; ret="${ret[*]}"
--- 1596.ret.expect	2025-03-01 23:57:50.494792977 +0000
+++ 1596.ret.result	2025-03-01 23:57:50.494792977 +0000
@@ -1 +1 @@
-98 27 0 99
+98 27 0

 91.3% [section] ble/util: 1129/1236 (107 fail, 0 crash, 8 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