Results for ysh-builtin-eval.test.sh

statusyshysh_ALT
pass 2020
FAIL 33
total2323
caseyshysh_ALTdescription
0pass pass eval builtin does not take a literal block - can restore this later
1pass pass Eval a block within a proc
2pass pass Eval block created by calling a proc
3pass pass io->eval(block) can read variables like eval ''
4FAIL FAIL eval should have a sandboxed mode
detailsdetails
5pass pass io->eval with argv bindings
6pass pass eval lines with argv bindings
7pass pass eval lines with var bindings
8pass pass eval with custom dollar0
9pass pass eval with vars bindings
10pass pass dynamic binding names and mutation
11pass pass binding procs in the eval-ed namespace
12pass pass vars initializes the variable frame, but does not remember it
13pass pass eval pos_args must be strings
14pass pass eval with vars follows same scoping as without
15pass pass eval 'mystring' vs. call io->eval(myblock)
16pass pass io->evalToDict() - local and global
17pass pass parseCommand then io->evalToDict() - in global scope
18pass pass parseCommand with syntax error
19FAIL FAIL Dict (&d) { ... } converts frame to dict
detailsdetails
20FAIL FAIL Dict (&d) and setvar
detailsdetails
21pass pass Dict (&d) and setglobal
22pass pass bindings created shvar persist, which is different than evalToDict()
40 passed, 0 OK, 0 not implemented, 0 BUG, 6 failed, 0 timeouts, 0 cases skipped
3 failed under osh

Details on runs that didn't PASS

ysh4 eval should have a sandboxed mode

[ysh stdout] Expected 'TODO\n', got ''

stdout:
stderr: 
    push-frame {
               ^
[ stdin ]:4: fatal: 'push-frame' appears to be external. External commands don't accept typed args (OILS-ERR-200)
ysh_ALT4 eval should have a sandboxed mode

[ysh_ALT stdout] Expected 'TODO\n', got ''

stdout:
stderr: 
    push-frame {
               ^
[ stdin ]:4: fatal: 'push-frame' appears to be external. External commands don't accept typed args (OILS-ERR-200)
ysh19 Dict (&d) { ... } converts frame to dict

[ysh stdout] Expected '', got '(Dict) {"k":"k-block-mutated","k2":"k2-block","k3":"k3","myglobal":"global"}\nk=k-shadowed\nk2=k2-shadowed\n'
[ysh status] Expected 0, got 2

stdout:
(Dict)   {"k":"k-block-mutated","k2":"k2-block","k3":"k3","myglobal":"global"}
k=k-shadowed
k2=k2-shadowed
stderr:
      setvar k2 = 'k2-proc'  # local, so it's checked
             ^~
[ stdin ]:31: setvar couldn't find matching 'var k2' (OILS-ERR-10)
ysh_ALT19 Dict (&d) { ... } converts frame to dict

[ysh_ALT stdout] Expected '', got '(Dict) {"k":"k-block-mutated","k2":"k2-block","k3":"k3","myglobal":"global"}\nk=k-shadowed\nk2=k2-shadowed\n'
[ysh_ALT status] Expected 0, got 2

stdout:
(Dict)   {"k":"k-block-mutated","k2":"k2-block","k3":"k3","myglobal":"global"}
k=k-shadowed
k2=k2-shadowed
stderr:
      setvar k2 = 'k2-proc'  # local, so it's checked
             ^~
[ stdin ]:31: setvar couldn't find matching 'var k2' (OILS-ERR-10)
ysh20 Dict (&d) and setvar

[ysh stdout] Expected '', got 'inside Dict block\n [frame_vars_] __rear__ outer2 outer not_declared\nproc Dict frame after evalToDict\n [frame_vars_] ARGV out block d\nDict outer=xx\n(Dict) {"outer2":"outer2","outer":"zz","not_declared":"yy"}\nafter outer=xx\nafter Dict\n [frame_vars_] ARGV __builtins__ OIL_VERSION OILS_VERSION LIB_OSH LIB_YSH NAN INFINITY IFS UID EUID PPID HOSTNAME OSTYPE OPTIND PS4 COMP_WORDBREAKS TMP REPO_ROOT PYTHONPATH PWD SH LC_ALL PATH LOCALE_ARCHIVE OILS_GC_ON_EXIT SHELLOPTS YSH_HISTFILE Dict outer d\n'

stdout:
inside Dict block
    [frame_vars_] __rear__ outer2 outer not_declared
proc Dict frame after evalToDict
    [frame_vars_] ARGV out block d
Dict outer=xx
(Dict)   {"outer2":"outer2","outer":"zz","not_declared":"yy"}
after outer=xx
after Dict
    [frame_vars_] ARGV __builtins__ OIL_VERSION OILS_VERSION LIB_OSH LIB_YSH NAN INFINITY IFS UID EUID PPID HOSTNAME OSTYPE OPTIND PS4 COMP_WORDBREAKS TMP REPO_ROOT PYTHONPATH PWD SH LC_ALL PATH LOCALE_ARCHIVE OILS_GC_ON_EXIT SHELLOPTS YSH_HISTFILE Dict outer d
stderr:
ysh_ALT20 Dict (&d) and setvar

[ysh_ALT stdout] Expected '', got 'inside Dict block\n [frame_vars_] __rear__ outer2 outer not_declared\nproc Dict frame after evalToDict\n [frame_vars_] ARGV out block d\nDict outer=xx\n(Dict) {"outer2":"outer2","outer":"zz","not_declared":"yy"}\nafter outer=xx\nafter Dict\n [frame_vars_] ARGV __builtins__ OIL_VERSION OILS_VERSION LIB_OSH LIB_YSH NAN INFINITY IFS UID EUID PPID HOSTNAME OSTYPE OPTIND PS4 COMP_WORDBREAKS TMP REPO_ROOT SH PATH LC_ALL LOCALE_ARCHIVE OILS_GC_ON_EXIT SHELLOPTS PWD YSH_HISTFILE Dict outer d\n'

stdout:
inside Dict block
    [frame_vars_] __rear__ outer2 outer not_declared
proc Dict frame after evalToDict
    [frame_vars_] ARGV out block d
Dict outer=xx
(Dict)   {"outer2":"outer2","outer":"zz","not_declared":"yy"}
after outer=xx
after Dict
    [frame_vars_] ARGV __builtins__ OIL_VERSION OILS_VERSION LIB_OSH LIB_YSH NAN INFINITY IFS UID EUID PPID HOSTNAME OSTYPE OPTIND PS4 COMP_WORDBREAKS TMP REPO_ROOT SH PATH LC_ALL LOCALE_ARCHIVE OILS_GC_ON_EXIT SHELLOPTS PWD YSH_HISTFILE Dict outer d
stderr: