~/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	7.986
user	7.685
sys	0.174
real	0.949
user	0.198
sys	0.023
    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-02 07:18:32.753712180 +0000
+++ 1086.ret.result	2025-03-02 07:18:32.754712183 +0000
@@ -1 +1 @@
-0
+1

lib/test-main.sh:57: ! ble/bin#has ble_test_dummy_4
--- 1090.exit.expect	2025-03-02 07:18:32.966712910 +0000
+++ 1090.exit.result	2025-03-02 07:18:32.966712910 +0000
@@ -1 +1 @@
-0
+1

lib/test-main.sh:88: 
    ble/util/readlink f.txt
    [[ $ret != /* ]] && ret=${PWD%/}/$ret
--- 1093.ret.expect	2025-03-02 07:18:33.088713328 +0000
+++ 1093.ret.result	2025-03-02 07:18:33.089713332 +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-02 07:18:33.289714018 +0000
+++ 1093.exit.result	2025-03-02 07:18:33.290714021 +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-02 07:18:33.375714313 +0000
+++ 1126.exit.result	2025-03-02 07:18:33.376714316 +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-02 07:18:34.782719137 +0000
+++ 1137.ret.result	2025-03-02 07:18:34.783719141 +0000
@@ -1 +1 @@
-i
+

lib/test-util.sh:191: ble/variable#get-attr x; ret=$attr
--- 1137.ret.expect	2025-03-02 07:18:34.815719251 +0000
+++ 1137.ret.result	2025-03-02 07:18:34.816719254 +0000
@@ -1 +1 @@
-x
+

lib/test-util.sh:192: ble/variable#get-attr r; ret=$attr
--- 1137.ret.expect	2025-03-02 07:18:34.848719364 +0000
+++ 1137.ret.result	2025-03-02 07:18:34.848719364 +0000
@@ -1 +1 @@
-r
+

lib/test-util.sh:195: ble/variable#get-attr u; ret=$attr
--- 1137.ret.expect	2025-03-02 07:18:34.891719511 +0000
+++ 1137.ret.result	2025-03-02 07:18:34.892719515 +0000
@@ -1 +1 @@
-u
+

lib/test-util.sh:196: ble/variable#get-attr l; ret=$attr
--- 1137.ret.expect	2025-03-02 07:18:34.924719624 +0000
+++ 1137.ret.result	2025-03-02 07:18:34.925719628 +0000
@@ -1 +1 @@
-l
+

lib/test-util.sh:197: ble/variable#get-attr c; ret=$attr
--- 1137.ret.expect	2025-03-02 07:18:34.957719738 +0000
+++ 1137.ret.result	2025-03-02 07:18:34.957719738 +0000
@@ -1 +1 @@
-c
+

lib/test-util.sh:203: ble/variable#has-attr i i
--- 1137.exit.expect	2025-03-02 07:18:35.000719885 +0000
+++ 1137.exit.result	2025-03-02 07:18:35.000719885 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:204: ble/variable#has-attr x x
--- 1137.exit.expect	2025-03-02 07:18:35.032719995 +0000
+++ 1137.exit.result	2025-03-02 07:18:35.032719995 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:205: ble/variable#has-attr r r
--- 1137.exit.expect	2025-03-02 07:18:35.064720104 +0000
+++ 1137.exit.result	2025-03-02 07:18:35.064720104 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:212: ble/variable#has-attr u u
--- 1137.exit.expect	2025-03-02 07:18:35.153720410 +0000
+++ 1137.exit.result	2025-03-02 07:18:35.154720413 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:213: ble/variable#has-attr l l
--- 1137.exit.expect	2025-03-02 07:18:35.186720523 +0000
+++ 1137.exit.result	2025-03-02 07:18:35.187720526 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:214: ble/variable#has-attr c c
--- 1137.exit.expect	2025-03-02 07:18:35.219720636 +0000
+++ 1137.exit.result	2025-03-02 07:18:35.219720636 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:226: ble/is-inttype i
--- 1137.exit.expect	2025-03-02 07:18:35.308720941 +0000
+++ 1137.exit.result	2025-03-02 07:18:35.308720941 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:228: ble/is-readonly r
--- 1137.exit.expect	2025-03-02 07:18:35.352721092 +0000
+++ 1137.exit.result	2025-03-02 07:18:35.353721095 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:231: ble/is-transformed u
--- 1137.exit.expect	2025-03-02 07:18:35.397721246 +0000
+++ 1137.exit.result	2025-03-02 07:18:35.397721246 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:232: ble/is-transformed l
--- 1137.exit.expect	2025-03-02 07:18:35.429721356 +0000
+++ 1137.exit.result	2025-03-02 07:18:35.429721356 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:233: ble/is-transformed c
--- 1137.exit.expect	2025-03-02 07:18:35.461721466 +0000
+++ 1137.exit.result	2025-03-02 07:18:35.462721469 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:251: is-global v0
--- 1172.exit.expect	2025-03-02 07:18:35.523721679 +0000
+++ 1172.exit.result	2025-03-02 07:18:35.524721682 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:252: is-global v1
--- 1172.exit.expect	2025-03-02 07:18:35.562721812 +0000
+++ 1172.exit.result	2025-03-02 07:18:35.562721812 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:257: ble/variable#is-global v0
--- 1172.exit.expect	2025-03-02 07:18:35.653722124 +0000
+++ 1172.exit.result	2025-03-02 07:18:35.653722124 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:258: ble/variable#is-global v1
--- 1172.exit.expect	2025-03-02 07:18:35.691722255 +0000
+++ 1172.exit.result	2025-03-02 07:18:35.692722258 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:263: ble/variable#is-global v0u
--- 1172.exit.expect	2025-03-02 07:18:35.783722570 +0000
+++ 1172.exit.result	2025-03-02 07:18:35.783722570 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:265: ble/variable#is-global v1u
--- 1172.exit.expect	2025-03-02 07:18:35.821722700 +0000
+++ 1172.exit.result	2025-03-02 07:18:35.821722700 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:597: ble/string#split-lines a ""  ; status
--- 1220.stdout.expect	2025-03-02 07:18:37.908729200 +0000
+++ 1220.stdout.result	2025-03-02 07:18:37.909729203 +0000
@@ -1 +1 @@
-1:()
+0:()

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

lib/test-util.sh:600: ble/string#split-lines a "1
"  ; status
--- 1220.stdout.expect	2025-03-02 07:18:37.988729448 +0000
+++ 1220.stdout.result	2025-03-02 07:18:37.989729451 +0000
@@ -1 +1 @@
-2:(1 )
+1:(1)

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

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

3"  ; status
--- 1220.stdout.expect	2025-03-02 07:18:38.055729655 +0000
+++ 1220.stdout.result	2025-03-02 07:18:38.056729658 +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-02 07:18:39.793735033 +0000
+++ 1238.ret.result	2025-03-02 07:18:39.793735033 +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-02 07:18:39.838735173 +0000
+++ 1238.ret.result	2025-03-02 07:18:39.838735173 +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-02 07:18:39.883735312 +0000
+++ 1238.ret.result	2025-03-02 07:18:39.883735312 +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-02 07:18:39.942735495 +0000
+++ 1238.stdout.result	2025-03-02 07:18:39.942735495 +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-02 07:18:39.988735637 +0000
+++ 1238.stdout.result	2025-03-02 07:18:39.989735640 +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-02 07:18:40.035735782 +0000
+++ 1238.stdout.result	2025-03-02 07:18:40.035735782 +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-02 07:18:40.696737828 +0000
+++ 1253.ret.result	2025-03-02 07:18:40.696737828 +0000
@@ -1 +1 @@
-2
+1

lib/test-util.sh:844: ble/util/strlen αβγ
--- 1253.ret.expect	2025-03-02 07:18:40.729737930 +0000
+++ 1253.ret.result	2025-03-02 07:18:40.729737930 +0000
@@ -1 +1 @@
-6
+3

lib/test-util.sh:845: ble/util/strlen あ
--- 1253.ret.expect	2025-03-02 07:18:40.762738032 +0000
+++ 1253.ret.result	2025-03-02 07:18:40.762738032 +0000
@@ -1 +1 @@
-3
+1

lib/test-util.sh:846: ble/util/strlen あいう
--- 1253.ret.expect	2025-03-02 07:18:40.795738134 +0000
+++ 1253.ret.result	2025-03-02 07:18:40.795738134 +0000
@@ -1 +1 @@
-9
+3

lib/test-util.sh:847: ble/util/strlen aα
--- 1253.ret.expect	2025-03-02 07:18:40.828738236 +0000
+++ 1253.ret.result	2025-03-02 07:18:40.828738236 +0000
@@ -1 +1 @@
-3
+2

lib/test-util.sh:848: ble/util/strlen aαあ
--- 1253.ret.expect	2025-03-02 07:18:40.861738339 +0000
+++ 1253.ret.result	2025-03-02 07:18:40.861738339 +0000
@@ -1 +1 @@
-6
+3

lib/test-util.sh:852: ble/util/strlen α
--- 1253.ret.expect	2025-03-02 07:18:40.905738475 +0000
+++ 1253.ret.result	2025-03-02 07:18:40.906738478 +0000
@@ -1 +1 @@
-2
+1

lib/test-util.sh:853: ble/util/strlen あ
--- 1253.ret.expect	2025-03-02 07:18:40.938738577 +0000
+++ 1253.ret.result	2025-03-02 07:18:40.939738580 +0000
@@ -1 +1 @@
-3
+1

lib/test-util.sh:885: ble/util/substr あいう 0 3
--- 1270.ret.expect	2025-03-02 07:18:41.286739654 +0000
+++ 1270.ret.result	2025-03-02 07:18:41.286739654 +0000
@@ -1 +1 @@
-あ
+あいう

lib/test-util.sh:886: ble/util/substr あいう 3 6
--- 1270.ret.expect	2025-03-02 07:18:41.319739756 +0000
+++ 1270.ret.result	2025-03-02 07:18:41.320739759 +0000
@@ -1 +1 @@
-いう
+

lib/test-util.sh:1243: ble/util/mapfile a < <(echo); status
--- 1280.stdout.expect	2025-03-02 07:18:45.952753762 +0000
+++ 1280.stdout.result	2025-03-02 07:18:45.952753762 +0000
@@ -1 +1 @@
-1:()
+0:()

lib/test-util.sh:1244: ble/util/mapfile a < <(echo;echo); status
--- 1280.stdout.expect	2025-03-02 07:18:45.989753870 +0000
+++ 1280.stdout.result	2025-03-02 07:18:45.990753873 +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-02 07:18:46.026753979 +0000
+++ 1280.stdout.result	2025-03-02 07:18:46.027753982 +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-02 07:18:46.167754392 +0000
+++ 1280.stdout.result	2025-03-02 07:18:46.167754392 +0000
@@ -1 +1 @@
-1:()
+0:()

lib/test-util.sh:1266: ble/util/assign-array a "echo; echo; echo"; status
--- 1280.stdout.expect	2025-03-02 07:18:46.235754591 +0000
+++ 1280.stdout.result	2025-03-02 07:18:46.236754594 +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-02 07:18:46.271754696 +0000
+++ 1280.stdout.result	2025-03-02 07:18:46.271754696 +0000
@@ -1 +1 @@
-3:(1  2)
+1:(1)

lib/test-util.sh:1364: f1
--- 1364.stdout.expect	2025-03-02 07:18:47.284757663 +0000
+++ 1364.stdout.result	2025-03-02 07:18:47.284757663 +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-02 07:18:47.355757871 +0000
+++ 1364.stdout.result	2025-03-02 07:18:47.355757871 +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-02 07:18:47.426758079 +0000
+++ 1364.stdout.result	2025-03-02 07:18:47.426758079 +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-02 07:18:47.496758284 +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-02 07:18:47.497758287 +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-02 07:18:47.570758501 +0000
+++ 1364.stdout.result	2025-03-02 07:18:47.570758501 +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-02 07:18:47.645758721 +0000
+++ 1364.stdout.result	2025-03-02 07:18:47.645758721 +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-02 07:18:47.699758879 +0000
+++ 1364.stdout.result	2025-03-02 07:18:47.699758879 +0000
@@ -1 +1 @@
-original
+
--- 1364.exit.expect	2025-03-02 07:18:47.718758934 +0000
+++ 1364.exit.result	2025-03-02 07:18:47.718758934 +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-02 07:18:47.763759066 +0000
+++ 1364.stdout.result	2025-03-02 07:18:47.764759069 +0000
@@ -1 +1 @@
-original 1
+
--- 1364.exit.expect	2025-03-02 07:18:47.783759125 +0000
+++ 1364.exit.result	2025-03-02 07:18:47.783759125 +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-02 07:18:47.908759491 +0000
+++ 1385.stdout.result	2025-03-02 07:18:47.908759491 +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-02 07:18:47.954759625 +0000
+++ 1385.stdout.result	2025-03-02 07:18:47.955759628 +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-02 07:18:48.000759760 +0000
+++ 1385.stdout.result	2025-03-02 07:18:48.001759763 +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-02 07:18:48.036759866 +0000
+++ 1385.stdout.result	2025-03-02 07:18:48.036759866 +0000
@@ -1 +1 @@
-(1 2 3)
+1 2 3

lib/test-util.sh:1404: echo 1 2 3
--- 1385.stdout.expect	2025-03-02 07:18:48.071759968 +0000
+++ 1385.stdout.result	2025-03-02 07:18:48.072759971 +0000
@@ -1 +1 @@
-[1 2 3]
+1 2 3

lib/test-util.sh:1405: ble/is-function echo
--- 1385.exit.expect	2025-03-02 07:18:48.104760065 +0000
+++ 1385.exit.result	2025-03-02 07:18:48.105760068 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:1406: ble/function#pop echo
--- 1385.exit.expect	2025-03-02 07:18:48.139760167 +0000
+++ 1385.exit.result	2025-03-02 07:18:48.140760170 +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-02 07:18:48.399760929 +0000
+++ 1401.ret.result	2025-03-02 07:18:48.400760932 +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-02 07:18:48.434761031 +0000
+++ 1401.ret.result	2025-03-02 07:18:48.435761034 +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-02 07:18:48.654761676 +0000
+++ 1407.ret.result	2025-03-02 07:18:48.655761678 +0000
@@ -1 +1 @@
-aaa2 world
+aaa1

lib/test-util.sh:1484: ble/alias#expand aaa2
--- 1407.ret.expect	2025-03-02 07:18:48.687761772 +0000
+++ 1407.ret.result	2025-03-02 07:18:48.6887617    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)
75 +0000
@@ -1 +1 @@
-aaa3 hello
+aaa2

lib/test-util.sh:1485: ble/alias#expand aaa1
--- 1407.ret.expect	2025-03-02 07:18:48.721761872 +0000
+++ 1407.ret.result	2025-03-02 07:18:48.722761875 +0000
@@ -1 +1 @@
-aaa2 world
+aaa1

lib/test-util.sh:1487: ble/alias#expand aaa3
--- 1407.ret.expect	2025-03-02 07:18:48.754761968 +0000
+++ 1407.ret.result	2025-03-02 07:18:48.755761971 +0000
@@ -1 +1 @@
-aaa4
+aaa3

lib/test-util.sh:1488: ble/alias#expand aaa2
--- 1407.ret.expect	2025-03-02 07:18:48.787762065 +0000
+++ 1407.ret.result	2025-03-02 07:18:48.787762065 +0000
@@ -1 +1 @@
-aaa3 hello
+aaa2

lib/test-util.sh:1489: ble/alias#expand aaa1
--- 1407.ret.expect	2025-03-02 07:18:48.820762162 +0000
+++ 1407.ret.result	2025-03-02 07:18:48.821762165 +0000
@@ -1 +1 @@
-aaa2 world
+aaa1

lib/test-util.sh:1491: ble/alias#expand aaa4
--- 1407.ret.expect	2025-03-02 07:18:48.854762261 +0000
+++ 1407.ret.result	2025-03-02 07:18:48.854762261 +0000
@@ -1 +1 @@
-echo
+aaa4

lib/test-util.sh:1492: ble/alias#expand aaa3
--- 1407.ret.expect	2025-03-02 07:18:48.888762361 +0000
+++ 1407.ret.result	2025-03-02 07:18:48.888762361 +0000
@@ -1 +1 @@
-aaa4
+aaa3

lib/test-util.sh:1493: ble/alias#expand aaa2
--- 1407.ret.expect	2025-03-02 07:18:48.921762458 +0000
+++ 1407.ret.result	2025-03-02 07:18:48.922762460 +0000
@@ -1 +1 @@
-aaa3 hello
+aaa2

lib/test-util.sh:1494: ble/alias#expand aaa1
--- 1407.ret.expect	2025-03-02 07:18:48.955762557 +0000
+++ 1407.ret.result	2025-03-02 07:18:48.955762557 +0000
@@ -1 +1 @@
-aaa2 world
+aaa1

lib/test-util.sh:1619: [[ ! ${v0+set} ]]
--- 1481.exit.expect	2025-03-02 07:18:49.916765372 +0000
+++ 1481.exit.result	2025-03-02 07:18:49.916765372 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:1620: status v1
--- 1481.stdout.expect	2025-03-02 07:18:49.950765471 +0000
+++ 1481.stdout.result	2025-03-02 07:18:49.950765471 +0000
@@ -1 +1 @@
-1:(123)
+1:(2)

lib/test-util.sh:1621: status v2
--- 1481.stdout.expect	2025-03-02 07:18:49.986765577 +0000
+++ 1481.stdout.result	2025-03-02 07:18:49.987765580 +0000
@@ -1 +1 @@
-3:(1 2 3)
+1:(3)

lib/test-util.sh:1622: status v3
--- 1481.stdout.expect	2025-03-02 07:18:50.021765679 +0000
+++ 1481.stdout.result	2025-03-02 07:18:50.021765679 +0000
@@ -1 +1 @@
-1:(bbb)
+3:(bbb)

lib/test-util.sh:1623: status v4
--- 1481.stdout.expect	2025-03-02 07:18:50.055765779 +0000
+++ 1481.stdout.result	2025-03-02 07:18:50.055765779 +0000
@@ -1 +1 @@
-1:(ccc)
+1:(5)

lib/test-util.sh:1635: ble/util/print-global-definitions value
--- 1481.stdout.expect	2025-03-02 07:18:50.127765990 +0000
+++ 1481.stdout.result	2025-03-02 07:18:50.127765990 +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-02 07:18:50.413766827 +0000
+++ 1498.exit.result	2025-03-02 07:18:50.413766827 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:1673: shopt -q nullglob
--- 1498.exit.expect	2025-03-02 07:18:50.445766921 +0000
+++ 1498.exit.result	2025-03-02 07:18:50.445766921 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:1674: shopt -q extglob
--- 1498.exit.expect	2025-03-02 07:18:50.477767015 +0000
+++ 1498.exit.result	2025-03-02 07:18:50.478767018 +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-02 07:18:50.735767770 +0000
+++ 1508.exit.result	2025-03-02 07:18:50.736767773 +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-02 07:18:50.891768224 +0000
+++ 1508.exit.result	2025-03-02 07:18:50.891768224 +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-02 07:19:00.971797537 +0000
+++ 1515.stdout.result	2025-03-02 07:19:00.971797537 +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.261
user	0.586
sys	0.131
real	0.601
user	0.087
sys	0.009
</STDERR>

lib/test-util.sh:1696: ble/util/conditional-sync 'ble/bin/sleep 10' '((time<1000))' 100 progressive-weight
--- 1515.stdout.expect	2025-03-02 07:19:11.033800612 +0000
+++ 1515.stdout.result	2025-03-02 07:19:11.034800614 +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-02 07:19:21.089827741 +0000
+++ 1515.exit.result	2025-03-02 07:19:21.090827744 +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-02 07:19:21.232828104 +0000
+++ 1515.exit.result	2025-03-02 07:19:21.232828104 +0000
@@ -1 +1 @@
-1
+0

lib/test-util.sh:1714: kill -0 "$pid2"
--- 1515.exit.expect	2025-03-02 07:19:21.270828201 +0000
+++ 1515.exit.result	2025-03-02 07:19:21.270828201 +0000
@@ -1 +1 @@
-1
+0

lib/test-util.sh:1715: kill -0 "$pid3"
--- 1515.exit.expect	2025-03-02 07:19:21.308828297 +0000
+++ 1515.exit.result	2025-03-02 07:19:21.308828297 +0000
@@ -1 +1 @@
-1
+0

lib/test-util.sh:1740: ble/util/get-pager ret
--- 1569.ret.expect	2025-03-02 07:19:21.564828947 +0000
+++ 1569.ret.result	2025-03-02 07:19:21.565828950 +0000
@@ -1 +1 @@
-less
+pager

lib/test-util.sh:1763: ble/util/buffer.flush
--- 1574.stdout.expect	2025-03-02 07:19:21.646829156 +0000
+++ 1574.stdout.result	2025-03-02 07:19:21.647829158 +0000
@@ -1 +1 @@
-helloworld
+

lib/test-util.sh:1767: ble/util/buffer.flush
--- 1574.stdout.expect	2025-03-02 07:19:21.693829275 +0000
+++ 1574.stdout.result	2025-03-02 07:19:21.693829275 +0000
@@ -1,2 +1 @@
-hello
-world
+

lib/test-util.sh:2016: ble/util/c2s 956; [[ $ret != μ ]]
--- 1587.exit.expect	2025-03-02 07:19:23.203833111 +0000
+++ 1587.exit.result	2025-03-02 07:19:23.203833111 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:2017: ble/util/c2s 12354; [[ $ret != あ ]]
--- 1587.exit.expect	2025-03-02 07:19:23.237833197 +0000
+++ 1587.exit.result	2025-03-02 07:19:23.237833197 +0000
@@ -1 +1 @@
-0
+1

lib/test-util.sh:2047: ble/util/chars2s
--- 1593.ret.expect	2025-03-02 07:19:23.535833954 +0000
+++ 1593.ret.result	2025-03-02 07:19:23.535833954 +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-02 07:19:24.565836487 +0000
+++ 1596.ret.result	2025-03-02 07:19:24.566836490 +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-02 07:19:24.667836731 +0000
+++ 1596.ret.result	2025-03-02 07:19:24.668836734 +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-02 07:19:24.769836975 +0000
+++ 1596.ret.result	2025-03-02 07:19:24.770836978 +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-02 07:19:24.871837219 +0000
+++ 1596.ret.result	2025-03-02 07:19:24.872837222 +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-02 07:19:24.973837464 +0000
+++ 1596.ret.result	2025-03-02 07:19:24.974837466 +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-02 07:19:25.077837712 +0000
+++ 1596.ret.result	2025-03-02 07:19:25.077837712 +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-02 07:19:25.181837961 +0000
+++ 1596.ret.result	2025-03-02 07:19:25.181837961 +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