Data-Sah-JS v0.87 Perl 5 v5.14.4 x86_64-linux-ld

Status
Fail
From
Andreas J. König (ANDK)
Dist
Data-Sah-JS v0.87
Platform
Perl 5 v5.14.4 x86_64-linux-ld
Date
2020-01-27 11:46:21
ID
a38c99b4-40fa-11ea-a2f0-f6850a6384ad
This distribution has been tested as part of the CPAN Testers
project, supporting the Perl programming language.  See
http://wiki.cpantesters.org/ for more information or email
questions to cpan-testers-discuss@perl.org


--
Dear perlancar,

This is a computer-generated report for Data-Sah-JS-0.87
on perl 5.14.4, created by CPAN-Reporter-1.2018.

Thank you for uploading your work to CPAN.  However, there was a problem
testing your distribution.

If you think this report is invalid, please consult the CPAN Testers Wiki
for suggestions on how to avoid getting FAIL reports for missing library
or binary dependencies, unsupported operating systems, and so on:

http://wiki.cpantesters.org/wiki/CPANAuthorNotes

Sections of this report:

    * Tester comments
    * Program output
    * Prerequisites
    * Environment and other context

------------------------------
TESTER COMMENTS
------------------------------

Additional comments from tester:

this report is from an automated smoke testing program
and was not reviewed by a human for accuracy

------------------------------
PROGRAM OUTPUT
------------------------------

Output from '/usr/bin/make test':

PERL_DL_NONLAZY=1 "/home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/bin/perl" "-MExtUtils::Command::MM" "-MTest::Harness" "-e" "undef *Test::Harness::Switches; test_harness(0, 'blib/lib', 'blib/arch')" t/*.t
t/00-compile.t ........... ok
t/99-various.t ........... ok
t/author-pod-coverage.t .. skipped: these tests are for testing by the author
t/author-pod-syntax.t .... skipped: these tests are for testing by the author
t/js-misc.t .............. ok
Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 834.
t/js-type-date.t ......... 
Dubious, test returned 255 (wstat 65280, 0xff00)
No subtests run 
Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.
t/js-type-duration.t ..... 
Dubious, test returned 255 (wstat 65280, 0xff00)
No subtests run 
    # Loading 10-type-all.json ...
    # Loading 10-type-any.json ...
    # Loading 10-type-array.json ...

    #   Failed test 'compile ok ((tags=clause:default, type, type:array) array0020: default: must accept valid default []}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 643.

    #   Failed test 'compile ok ((tags=clause:default, type, type:array) array0021: default: must reject invalid default a}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 643.
    # Skipping test (tags=clause:check_each_index, type, type:array) array0117: check_each_index: clause check_each_index not yet implemented
    # Skipping test (tags=clause:check_each_elem, type, type:array) array0118: check_each_elem: clause check_each_elem not yet implemented
    # Skipping test (tags=clause:uniq, type, type:array) array0119: uniq=1: clause uniq not yet implemented
    # Skipping test (tags=clause:uniq, type, type:array) array0120: uniq=0: clause uniq not yet implemented
    # Skipping test (tags=clause:uniq, op, op:not, opshortcut, type, type:array) array0121: !uniq=1: clause uniq not yet implemented
    # Skipping test (tags=clause:exists, type, type:array) array0122: exists: clause exists not yet implemented
    # Skipping test (tags=prop:len, type, type:array) array0129: prop:len: properties are not yet implemented
    # Skipping test (tags=prop:indices, type, type:array) array0130: prop:indices: properties are not yet implemented
    # Skipping test (tags=prop:elems, type, type:array) array0131: prop:elems: properties are not yet implemented

    #   Failed test 'compile ok ((tags=clause:elems, type, type:array) array0133: elems (nok, first elem required)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 643.

    #   Failed test 'compile ok ((tags=clause:elems, type, type:array) array0139: elems (ok, create_default=0)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 643.

    #   Failed test 'js file executed successfully'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 245.
    # output=<<            ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 1 - (tags=type, type:array) array0001: type check: must accept []
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 2 - (tags=type, type:array) array0002: type check: must accept [1,"a"]
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 3 - (tags=type, type:array) array0003: type check: must accept [[]]
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 4 - (tags=type, type:array) array0004: type check: must reject 1
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 5 - (tags=type, type:array) array0005: type check: must reject a
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 6 - (tags=type, type:array) array0006: type check: must reject {}
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 7 - (tags=type, type:array) array0007: must accept undefined value
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 8 - (tags=clause:defhash_v, type, type:array) array0008: defhash_v
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 9 - (tags=clause:v, type, type:array) array0009: v
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 10 - (tags=clause:c, type, type:array) array0010: c
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 11 - (tags=clause:default_lang, type, type:array) array0011: default_lang
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 12 - (tags=clause:name, type, type:array) array0012: name
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 13 - (tags=clause:summary, type, type:array) array0013: summary
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 14 - (tags=clause:description, type, type:array) array0014: description
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 15 - (tags=clause:tags, type, type:array) array0015: tags
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 16 - (tags=clause:req, type, type:array) array0016: req=0 must accept undefined value
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 17 - (tags=clause:req, type, type:array) array0017: req=1 must reject undefined value
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 18 - (tags=clause:forbidden, type, type:array) array0018: forbidden=0 must accept defined value
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 19 - (tags=clause:forbidden, type, type:array) array0019: forbidden=1 must reject defined value
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 20 - (tags=clause:clause, type, type:array) array0023: clause (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 21 - (tags=clause:clause, type, type:array) array0024: clause (ok) + clause nok = nok
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 22 - (tags=clause:clause, type, type:array) array0025: clause (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 23 - (tags=type, type:array) array0028: clset (empty = ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 24 - (tags=clause:clset, type, type:array) array0029: clset (ignored clause/attr = ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 25 - (tags=clause:clset, type, type:array) array0030: clset (ok + ok = ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 26 - (tags=clause:clset, type, type:array) array0031: clset (ok) + clause nok = nok
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 27 - (tags=clause:clset, type, type:array) array0032: clset (ok + nok = nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 28 - (tags=clause:clset, type, type:array) array0033: clset (nok + ok = nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 29 - (tags=clause:clset, type, type:array) array0034: clset (nok + nok = nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 30 - (tags=clause:ok, type, type:array) array0035: ok
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 31 - (tags=clause:ok, op, op:not, type, type:array) array0036: ok + op not (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 32 - (tags=attr, attr:err_level, type, type:array) array0037: .err_level=error (clause=is, ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 33 - (tags=attr, attr:err_level, type, type:array) array0038: .err_level=error (clause=is, nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 34 - (tags=attr, attr:err_level, type, type:array) array0039: .err_level=warn (clause=is, ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 35 - (tags=attr, attr:err_level, type, type:array) array0040: .err_level=warn (clause=is, nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 36 - (tags=clause:is, type, type:array) array0041: is: must accept same value
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 37 - (tags=clause:is, type, type:array) array0042: is: must reject different value
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 38 - (tags=clause:is, op, op:not, opshortcut, type, type:array) array0043: !is (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 39 - (tags=clause:is, op, op:not, opshortcut, type, type:array) array0044: !is (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 40 - (tags=clause:is, op, op:not, type, type:array) array0045: is.op=not (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 41 - (tags=clause:is, op, op:not, type, type:array) array0046: is.op=not (ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 42 - (tags=clause:is, op, op:and, opshortcut, type, type:array) array0047: is& (no items)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 43 - (tags=clause:is, op, op:and, opshortcut, type, type:array) array0048: is& (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 44 - (tags=clause:is, op, op:and, opshortcut, type, type:array) array0049: is& (nok + ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 45 - (tags=clause:is, op, op:and, opshortcut, type, type:array) array0050: is& (ok + nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 46 - (tags=clause:is, op, op:and, opshortcut, type, type:array) array0051: is& (nok + nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 47 - (tags=type, type:array) array0052: is.op=and (no items)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 48 - (tags=clause:is, op, op:and, type, type:array) array0053: is.op=and (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 49 - (tags=clause:is, op, op:and, type, type:array) array0054: is.op=and (nok + ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 50 - (tags=clause:is, op, op:and, type, type:array) array0055: is.op=and (ok + nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 51 - (tags=clause:is, op, op:and, type, type:array) array0056: is.op=and (nok + nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 52 - (tags=clause:is, op, op:or, opshortcut, type, type:array) array0057: is| (no items)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 53 - (tags=clause:is, op, op:or, opshortcut, type, type:array) array0058: is| (ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 54 - (tags=clause:is, op, op:or, opshortcut, type, type:array) array0059: is| (nok + ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 55 - (tags=clause:is, op, op:or, opshortcut, type, type:array) array0060: is| (ok + nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 56 - (tags=clause:is, op, op:or, opshortcut, type, type:array) array0061: is| (nok + nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 57 - (tags=clause:is, op, op:or, type, type:array) array0062: is.op=or (no items)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 58 - (tags=clause:is, op, op:or, type, type:array) array0063: is.op=or (ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 59 - (tags=clause:is, op, op:or, type, type:array) array0064: is.op=or (nok + ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 60 - (tags=clause:is, op, op:or, type, type:array) array0065: is.op=or (ok + nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 61 - (tags=clause:is, op, op:or, type, type:array) array0066: is.op=or (nok + nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 62 - (tags=clause:is, op, op:none, type, type:array) array0067: is.op=none (empty items)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 63 - (tags=clause:is, op, op:none, type, type:array) array0068: is.op=none (nok + nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 64 - (tags=clause:is, op, op:none, type, type:array) array0069: is.op=none (nok + ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 65 - (tags=clause:is, op, op:none, type, type:array) array0070: is.op=none (ok + nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 66 - (tags=clause:is, op, op:none, type, type:array) array0071: is.op=none (ok + ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 67 - (tags=clause:in, type, type:array) array0072: in: must accept valid choices
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 68 - (tags=clause:in, type, type:array) array0073: in: must reject empty choices
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 69 - (tags=clause:in, op, op:not, opshortcut, type, type:array) array0074: !in (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 70 - (tags=clause:in, op, op:not, opshortcut, type, type:array) array0075: !in (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 71 - (tags=clause:in, op, op:not, type, type:array) array0076: in.op=not (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 72 - (tags=clause:in, op, op:not, type, type:array) array0077: in.op=not (ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 73 - (tags=clause:in, op, op:and, opshortcut, type, type:array) array0078: in& (no items)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 74 - (tags=clause:in, op, op:and, opshortcut, type, type:array) array0079: in& (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 75 - (tags=clause:in, op, op:and, opshortcut, type, type:array) array0080: in& (nok + ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 76 - (tags=clause:in, op, op:and, opshortcut, type, type:array) array0081: in& (ok + nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 77 - (tags=clause:in, op, op:and, opshortcut, type, type:array) array0082: in& (nok + nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 78 - (tags=type, type:array) array0083: in.op=and (no items)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 79 - (tags=clause:in, op, op:and, type, type:array) array0084: in.op=and (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 80 - (tags=clause:in, op, op:and, type, type:array) array0085: in.op=and (nok + ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 81 - (tags=clause:in, op, op:and, type, type:array) array0086: in.op=and (ok + nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 82 - (tags=clause:in, op, op:and, type, type:array) array0087: in.op=and (nok + nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 83 - (tags=clause:in, op, op:or, opshortcut, type, type:array) array0088: in| (no items)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 84 - (tags=clause:in, op, op:or, opshortcut, type, type:array) array0089: in| (ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 85 - (tags=clause:in, op, op:or, opshortcut, type, type:array) array0090: in| (nok + ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 86 - (tags=clause:in, op, op:or, opshortcut, type, type:array) array0091: in| (ok + nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 87 - (tags=clause:in, op, op:or, opshortcut, type, type:array) array0092: in| (nok + nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 88 - (tags=clause:in, op, op:or, type, type:array) array0093: in.op=or (no items)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 89 - (tags=clause:in, op, op:or, type, type:array) array0094: in.op=or (ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 90 - (tags=clause:in, op, op:or, type, type:array) array0095: in.op=or (nok + ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 91 - (tags=clause:in, op, op:or, type, type:array) array0096: in.op=or (ok + nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 92 - (tags=clause:in, op, op:or, type, type:array) array0097: in.op=or (nok + nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 93 - (tags=clause:in, op, op:none, type, type:array) array0098: in.op=none (empty items)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 94 - (tags=clause:in, op, op:none, type, type:array) array0099: in.op=none (nok + nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 95 - (tags=clause:in, op, op:none, type, type:array) array0100: in.op=none (nok + ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 96 - (tags=clause:in, op, op:none, type, type:array) array0101: in.op=none (ok + nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 97 - (tags=clause:in, op, op:none, type, type:array) array0102: in.op=none (ok + ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 98 - (tags=clause:len, type, type:array) array0103: len (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 99 - (tags=clause:len, type, type:array) array0104: len (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 100 - (tags=clause:min_len, type, type:array) array0105: min_len (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 101 - (tags=clause:min_len, type, type:array) array0106: min_len (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 102 - (tags=clause:max_len, type, type:array) array0107: max_len (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 103 - (tags=clause:max_len, type, type:array) array0108: max_len (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 104 - (tags=clause:len_between, type, type:array) array0109: len_between (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 105 - (tags=clause:len_between, type, type:array) array0110: len_between (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 106 - (tags=clause:each_index, type, type:array) array0111: each_index (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 107 - (tags=clause:each_index, type, type:array) array0112: each_index (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 108 - (tags=clause:each_elem, type, type:array) array0113: each_elem (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 109 - (tags=clause:each_elem, type, type:array) array0114: each_elem (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 110 - (tags=clause:of, type, type:array) array0115: of (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 111 - (tags=clause:of, type, type:array) array0116: of (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 112 - (tags=clause:elems, type, type:array) array0123: elems (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 113 - (tags=clause:elems, type, type:array) array0124: elems (nok)
    #             not ok 1 - valid input [0]
    #             not ok 2 - valid input [1]
    #             ok 3 - invalid input [0]
    #             ok 4 - invalid input [1]
    #             # 2 failed test(s)
    #             1..4
    #         not ok 114 - (tags=clause:has, type, type:array) array0125: has
    #             ok 1 - valid input [0]
    #             ok 2 - valid input [1]
    #             not ok 3 - invalid input [0]
    #             not ok 4 - invalid input [1]
    #             # 2 failed test(s)
    #             1..4
    #         not ok 115 - (tags=clause:has, op, op:not, opshortcut, type, type:array) array0126: has + op.not
    #             not ok 1 - valid input [0]
    #             not ok 2 - valid input [1]
    #             ok 3 - invalid input [0]
    #             ok 4 - invalid input [1]
    #             # 2 failed test(s)
    #             1..4
    #         not ok 116 - (tags=clause:has, op, op:or, opshortcut, type, type:array) array0127: has + op.or
    #             not ok 1 - valid input [0]
    #             ok 2 - invalid input [0]
    #             ok 3 - invalid input [1]
    #             ok 4 - invalid input [2]
    #             # 1 failed test(s)
    #             1..4
    #         not ok 117 - (tags=clause:has, op, op:and, opshortcut, type, type:array) array0128: has + op.and
    #             ok 1 - valid input [0]
    #             ok 2 - valid input [1]
    #             ok 3 - invalid input [0]
    #             1..3
    #         ok 118 - (tags=clause:of, type, type:array) array0132: array[array[int]] (test nested loop variable in implementation)
    # /tmp/I1IO3CXrL2/js9RO4Yja6:9103
    #     ok(sahv_array116_bool([1]), 'valid (rt=bool)');
    #     ^
    # 
    # ReferenceError: sahv_array116_bool is not defined
    #     at /tmp/I1IO3CXrL2/js9RO4Yja6:9103:5
    #     at subtest (/tmp/I1IO3CXrL2/js9RO4Yja6:44:6)
    #     at Object.<anonymous> (/tmp/I1IO3CXrL2/js9RO4Yja6:9102:1)
    #     at Module._compile (internal/modules/cjs/loader.js:778:30)
    #     at Object.Module._extensions..js (internal/modules/cjs/loader.js:789:10)
    #     at Module.load (internal/modules/cjs/loader.js:653:32)
    #     at tryModuleLoad (internal/modules/cjs/loader.js:593:12)
    #     at Function.Module._load (internal/modules/cjs/loader.js:585:3)
    #     at Function.Module.runMain (internal/modules/cjs/loader.js:831:12)
    #     at startup (internal/bootstrap/node.js:283:19)
    # >>, exit status ($?)=256, errno ($!)=Illegal seek, result=256Illegal seek
    # Looks like you failed 5 tests of 338.

#   Failed test '10-type-array.json'
#   at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Test/Data/Sah.pm line 272.
    # Loading 10-type-bool.json ...

    #   Failed test 'compile ok ((tags=type, type:bool) bool0001: type check: must accept 0}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:defhash_v, type, type:bool) bool0006: defhash_v}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:v, type, type:bool) bool0007: v}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:c, type, type:bool) bool0008: c}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:default_lang, type, type:bool) bool0009: default_lang}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:name, type, type:bool) bool0010: name}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:summary, type, type:bool) bool0011: summary}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:description, type, type:bool) bool0012: description}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:tags, type, type:bool) bool0013: tags}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:req, type, type:bool) bool0014: req=0 must accept undefined value}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:req, type, type:bool) bool0015: req=1 must reject undefined value}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:forbidden, type, type:bool) bool0016: forbidden=0 must accept defined value}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:forbidden, type, type:bool) bool0017: forbidden=1 must reject defined value}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:default, type, type:bool) bool0018: default: must accept valid default 1}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 643.

    #   Failed test 'compile ok ((tags=clause:default, type, type:bool) bool0019: default: must reject invalid default []}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 643.

    #   Failed test 'compile ok ((tags=type, type:bool) bool0023: clset (empty = ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:clset, type, type:bool) bool0024: clset (ignored clause/attr = ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:ok, type, type:bool) bool0025: ok}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:ok, op, op:not, type, type:bool) bool0026: ok + op not (nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=attr, attr:err_level, type, type:bool) bool0027: .err_level=error (clause=is, ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=attr, attr:err_level, type, type:bool) bool0029: .err_level=warn (clause=is, ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=attr, attr:err_level, type, type:bool) bool0030: .err_level=warn (clause=is, nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, type, type:bool) bool0031: is: must accept same value}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:not, opshortcut, type, type:bool) bool0033: !is (nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:not, opshortcut, type, type:bool) bool0034: !is (ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:not, type, type:bool) bool0035: is.op=not (nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:not, type, type:bool) bool0036: is.op=not (ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:and, opshortcut, type, type:bool) bool0037: is& (no items)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:and, opshortcut, type, type:bool) bool0038: is& (ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:and, opshortcut, type, type:bool) bool0039: is& (nok + ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:and, opshortcut, type, type:bool) bool0040: is& (ok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:and, opshortcut, type, type:bool) bool0041: is& (nok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=type, type:bool) bool0042: is.op=and (no items)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:and, type, type:bool) bool0043: is.op=and (ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:and, type, type:bool) bool0044: is.op=and (nok + ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:and, type, type:bool) bool0045: is.op=and (ok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:and, type, type:bool) bool0046: is.op=and (nok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:or, opshortcut, type, type:bool) bool0047: is| (no items)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:or, opshortcut, type, type:bool) bool0048: is| (ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:or, opshortcut, type, type:bool) bool0049: is| (nok + ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:or, opshortcut, type, type:bool) bool0050: is| (ok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:or, opshortcut, type, type:bool) bool0051: is| (nok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:or, type, type:bool) bool0052: is.op=or (no items)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:or, type, type:bool) bool0053: is.op=or (ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:or, type, type:bool) bool0054: is.op=or (nok + ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:or, type, type:bool) bool0055: is.op=or (ok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:or, type, type:bool) bool0056: is.op=or (nok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:none, type, type:bool) bool0057: is.op=none (empty items)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:none, type, type:bool) bool0058: is.op=none (nok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:none, type, type:bool) bool0059: is.op=none (nok + ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:none, type, type:bool) bool0060: is.op=none (ok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is, op, op:none, type, type:bool) bool0061: is.op=none (ok + ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, type, type:bool) bool0062: in: must accept valid choices}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, type, type:bool) bool0063: in: must reject empty choices}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:not, opshortcut, type, type:bool) bool0064: !in (nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:not, opshortcut, type, type:bool) bool0065: !in (ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:not, type, type:bool) bool0066: in.op=not (nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:not, type, type:bool) bool0067: in.op=not (ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:and, opshortcut, type, type:bool) bool0068: in& (no items)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:and, opshortcut, type, type:bool) bool0069: in& (ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:and, opshortcut, type, type:bool) bool0070: in& (nok + ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:and, opshortcut, type, type:bool) bool0071: in& (ok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:and, opshortcut, type, type:bool) bool0072: in& (nok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=type, type:bool) bool0073: in.op=and (no items)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:and, type, type:bool) bool0074: in.op=and (ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:and, type, type:bool) bool0075: in.op=and (nok + ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:and, type, type:bool) bool0076: in.op=and (ok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:and, type, type:bool) bool0077: in.op=and (nok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:or, opshortcut, type, type:bool) bool0078: in| (no items)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:or, opshortcut, type, type:bool) bool0079: in| (ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:or, opshortcut, type, type:bool) bool0080: in| (nok + ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:or, opshortcut, type, type:bool) bool0081: in| (ok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:or, opshortcut, type, type:bool) bool0082: in| (nok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:or, type, type:bool) bool0083: in.op=or (no items)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:or, type, type:bool) bool0084: in.op=or (ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:or, type, type:bool) bool0085: in.op=or (nok + ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:or, type, type:bool) bool0086: in.op=or (ok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:or, type, type:bool) bool0087: in.op=or (nok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:none, type, type:bool) bool0088: in.op=none (empty items)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:none, type, type:bool) bool0089: in.op=none (nok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:none, type, type:bool) bool0090: in.op=none (nok + ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:none, type, type:bool) bool0091: in.op=none (ok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:in, op, op:none, type, type:bool) bool0092: in.op=none (ok + ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:min, type, type:bool) bool0093: min: 1 0}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:min, type, type:bool) bool0094: min: 1 1}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:xmin, type, type:bool) bool0096: xmin: 1 0}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:xmin, type, type:bool) bool0097: xmin: 1 1 -> fail}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:max, type, type:bool) bool0099: max: 1 0 -> fail}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:max, type, type:bool) bool0100: max: 1 1}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:xmax, type, type:bool) bool0102: xmax: 1 0 -> fail}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:xmax, type, type:bool) bool0103: xmax: 1 1 -> fail}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, type, type:bool) bool0105: between: 1 0 & 1}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, type, type:bool) bool0107: between: 1 1 & 1}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:xbetween, type, type:bool) bool0109: xbetween: 1 0 & 1}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:xbetween, type, type:bool) bool0110: xbetween: 1 0 & 1 -> fail}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:xbetween, type, type:bool) bool0111: xbetween: 1 1 & 1 -> fail}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:not, opshortcut, type, type:bool) bool0113: !between (nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:not, opshortcut, type, type:bool) bool0114: !between (ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:not, type, type:bool) bool0115: between.op=not (nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:not, type, type:bool) bool0116: between.op=not (ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:and, opshortcut, type, type:bool) bool0117: between& (no items)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:and, opshortcut, type, type:bool) bool0118: between& (ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:and, opshortcut, type, type:bool) bool0119: between& (nok + ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:and, opshortcut, type, type:bool) bool0120: between& (ok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:and, opshortcut, type, type:bool) bool0121: between& (nok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=type, type:bool) bool0122: between.op=and (no items)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:and, type, type:bool) bool0123: between.op=and (ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:and, type, type:bool) bool0124: between.op=and (nok + ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:and, type, type:bool) bool0125: between.op=and (ok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:and, type, type:bool) bool0126: between.op=and (nok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:or, opshortcut, type, type:bool) bool0127: between| (no items)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:or, opshortcut, type, type:bool) bool0128: between| (ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:or, opshortcut, type, type:bool) bool0129: between| (nok + ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:or, opshortcut, type, type:bool) bool0130: between| (ok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:or, opshortcut, type, type:bool) bool0131: between| (nok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:or, type, type:bool) bool0132: between.op=or (no items)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:or, type, type:bool) bool0133: between.op=or (ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:or, type, type:bool) bool0134: between.op=or (nok + ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:or, type, type:bool) bool0135: between.op=or (ok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:or, type, type:bool) bool0136: between.op=or (nok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:none, type, type:bool) bool0137: between.op=none (empty items)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:none, type, type:bool) bool0138: between.op=none (nok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:none, type, type:bool) bool0139: between.op=none (nok + ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:none, type, type:bool) bool0140: between.op=none (ok + nok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:between, op, op:none, type, type:bool) bool0141: between.op=none (ok + ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is_true, type, type:bool) bool0142: is_true: 1 (ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is_true, type, type:bool) bool0144: is_true: 0 (ok)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'compile ok ((tags=clause:is_true, type, type:bool) bool0146: is_true: undef (ok 1)}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 853.

    #   Failed test 'js file executed successfully'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 245.
    # output=<</tmp/I1IO3CXrL2/jsT7hku0g4:67
    #     ok(sahv_bool1_bool(1), 'valid (rt=bool)');
    #     ^
    # 
    # ReferenceError: sahv_bool1_bool is not defined
    #     at /tmp/I1IO3CXrL2/jsT7hku0g4:67:5
    #     at subtest (/tmp/I1IO3CXrL2/jsT7hku0g4:44:6)
    #     at Object.<anonymous> (/tmp/I1IO3CXrL2/jsT7hku0g4:66:1)
    #     at Module._compile (internal/modules/cjs/loader.js:778:30)
    #     at Object.Module._extensions..js (internal/modules/cjs/loader.js:789:10)
    #     at Module.load (internal/modules/cjs/loader.js:653:32)
    #     at tryModuleLoad (internal/modules/cjs/loader.js:593:12)
    #     at Function.Module._load (internal/modules/cjs/loader.js:585:3)
    #     at Function.Module.runMain (internal/modules/cjs/loader.js:831:12)
    #     at startup (internal/bootstrap/node.js:283:19)
    # >>, exit status ($?)=256, errno ($!)=Illegal seek, result=256Illegal seek
    # Looks like you failed 129 tests of 132.

#   Failed test '10-type-bool.json'
#   at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Test/Data/Sah.pm line 272.
    # Loading 10-type-buf.json ...

    #   Failed test 'compile ok ((tags=clause:default, type, type:buf) buf0020: default: must accept valid default a}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 643.

    #   Failed test 'compile ok ((tags=clause:default, type, type:buf) buf0021: default: must reject invalid default []}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 643.
    # Skipping test (tags=clause:check_each_index, type, type:buf) buf0164: check_each_index: clause check_each_index not yet implemented
    # Skipping test (tags=clause:check_each_elem, type, type:buf) buf0165: check_each_elem: clause check_each_elem not yet implemented
    # Skipping test (tags=clause:uniq, type, type:buf) buf0166: uniq=1: clause uniq not yet implemented
    # Skipping test (tags=clause:uniq, type, type:buf) buf0167: uniq=0: clause uniq not yet implemented
    # Skipping test (tags=clause:uniq, op, op:not, opshortcut, type, type:buf) buf0168: !uniq=1: clause uniq not yet implemented
    # Skipping test (tags=clause:exists, type, type:buf) buf0169: exists: clause exists not yet implemented
    # Skipping test (tags=prop:len, type, type:buf) buf0174: prop:len: properties are not yet implemented
    # Skipping test (tags=prop:indices, type, type:buf) buf0175: prop:indices: properties are not yet implemented
    # Skipping test (tags=prop:elems, type, type:buf) buf0176: prop:elems: properties are not yet implemented
    # Looks like you failed 2 tests of 467.

#   Failed test '10-type-buf.json'
#   at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Test/Data/Sah.pm line 272.
    # Loading 10-type-cistr.json ...

    #   Failed test 'compile ok ((tags=clause:default, type, type:cistr) cistr0020: default: must accept valid default a}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 643.

    #   Failed test 'compile ok ((tags=clause:default, type, type:cistr) cistr0021: default: must reject invalid default []}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 643.
    # Skipping test (tags=clause:check_each_index, type, type:cistr) cistr0164: check_each_index: clause check_each_index not yet implemented
    # Skipping test (tags=clause:check_each_elem, type, type:cistr) cistr0165: check_each_elem: clause check_each_elem not yet implemented
    # Skipping test (tags=clause:uniq, type, type:cistr) cistr0166: uniq=1: clause uniq not yet implemented
    # Skipping test (tags=clause:uniq, type, type:cistr) cistr0167: uniq=0: clause uniq not yet implemented
    # Skipping test (tags=clause:uniq, op, op:not, opshortcut, type, type:cistr) cistr0168: !uniq=1: clause uniq not yet implemented
    # Skipping test (tags=clause:exists, type, type:cistr) cistr0169: exists: clause exists not yet implemented
    # Skipping test (tags=prop:len, type, type:cistr) cistr0174: prop:len: properties are not yet implemented
    # Skipping test (tags=prop:indices, type, type:cistr) cistr0175: prop:indices: properties are not yet implemented
    # Skipping test (tags=prop:elems, type, type:cistr) cistr0176: prop:elems: properties are not yet implemented
    # Looks like you failed 2 tests of 467.

#   Failed test '10-type-cistr.json'
#   at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Test/Data/Sah.pm line 272.
    # Loading 10-type-float.json ...

    #   Failed test 'compile ok ((tags=clause:default, type, type:float) float0022: default: must accept valid default 1.1}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 643.

    #   Failed test 'compile ok ((tags=clause:default, type, type:float) float0023: default: must reject invalid default []}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 643.
    # Looks like you failed 2 tests of 411.

#   Failed test '10-type-float.json'
#   at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Test/Data/Sah.pm line 272.
    # Loading 10-type-hash.json ...

    #   Failed test 'compile ok ((tags=clause:default, type, type:hash) hash0020: default: must accept valid default {}}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 643.

    #   Failed test 'compile ok ((tags=clause:default, type, type:hash) hash0021: default: must reject invalid default a}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 643.
    # Skipping test (tags=clause:check_each_index, type, type:hash) hash0121: check_each_index: clause check_each_index not yet implemented
    # Skipping test (tags=clause:check_each_key, type, type:hash) hash0122: check_each_key: clause check_each_key not yet implemented
    # Skipping test (tags=clause:check_each_elem, type, type:hash) hash0123: check_each_elem: clause check_each_elem not yet implemented
    # Skipping test (tags=clause:check_each_value, type, type:hash) hash0124: check_each_value: clause check_each_value not yet implemented
    # Skipping test (tags=clause:uniq, type, type:hash) hash0125: uniq=1: clause uniq not yet implemented
    # Skipping test (tags=clause:uniq, type, type:hash) hash0126: uniq=0: clause uniq not yet implemented
    # Skipping test (tags=clause:uniq, op, op:not, opshortcut, type, type:hash) hash0127: !uniq=1: clause uniq not yet implemented
    # Skipping test (tags=clause:exists, type, type:hash) hash0128: exists: clause exists not yet implemented
    # Skipping test (tags=prop:len, type, type:hash) hash0133: prop:len: properties are not yet implemented
    # Skipping test (tags=prop:indices, type, type:hash) hash0134: prop:indices: properties are not yet implemented
    # Skipping test (tags=prop:keys, type, type:hash) hash0135: prop:keys: properties are not yet implemented
    # Skipping test (tags=prop:elems, type, type:hash) hash0136: prop:elems: properties are not yet implemented
    # Skipping test (tags=prop:values, type, type:hash) hash0137: prop:values: properties are not yet implemented

    #   Failed test 'compile ok ((tags=clause:keys, type, type:hash) hash0149: keys (create_default=1) 1}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 643.

    #   Failed test 'compile ok ((tags=clause:keys, type, type:hash) hash0151: keys (create_default=0) 1}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 643.
    # Skipping test (tags=prop:keys, type, type:hash) hash0263: prop:keys: properties are not yet implemented
    # Skipping test (tags=prop:values, type, type:hash) hash0264: prop:values: properties are not yet implemented

    #   Failed test 'js file executed successfully'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 245.
    # output=<<            ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 1 - (tags=type, type:hash) hash0001: type check: must accept {}
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 2 - (tags=type, type:hash) hash0002: type check: must accept {a=>1}
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 3 - (tags=type, type:hash) hash0003: type check: must accept {""=>[]}
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 4 - (tags=type, type:hash) hash0004: type check: must reject 1
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 5 - (tags=type, type:hash) hash0005: type check: must reject a
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 6 - (tags=type, type:hash) hash0006: type check: must reject []
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 7 - (tags=type, type:hash) hash0007: must accept undefined value
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 8 - (tags=clause:defhash_v, type, type:hash) hash0008: defhash_v
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 9 - (tags=clause:v, type, type:hash) hash0009: v
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 10 - (tags=clause:c, type, type:hash) hash0010: c
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 11 - (tags=clause:default_lang, type, type:hash) hash0011: default_lang
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 12 - (tags=clause:name, type, type:hash) hash0012: name
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 13 - (tags=clause:summary, type, type:hash) hash0013: summary
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 14 - (tags=clause:description, type, type:hash) hash0014: description
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 15 - (tags=clause:tags, type, type:hash) hash0015: tags
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 16 - (tags=clause:req, type, type:hash) hash0016: req=0 must accept undefined value
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 17 - (tags=clause:req, type, type:hash) hash0017: req=1 must reject undefined value
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 18 - (tags=clause:forbidden, type, type:hash) hash0018: forbidden=0 must accept defined value
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 19 - (tags=clause:forbidden, type, type:hash) hash0019: forbidden=1 must reject defined value
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 20 - (tags=clause:clause, type, type:hash) hash0023: clause (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 21 - (tags=clause:clause, type, type:hash) hash0024: clause (ok) + clause nok = nok
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 22 - (tags=clause:clause, type, type:hash) hash0025: clause (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 23 - (tags=type, type:hash) hash0028: clset (empty = ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 24 - (tags=clause:clset, type, type:hash) hash0029: clset (ignored clause/attr = ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 25 - (tags=clause:clset, type, type:hash) hash0030: clset (ok + ok = ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 26 - (tags=clause:clset, type, type:hash) hash0031: clset (ok) + clause nok = nok
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 27 - (tags=clause:clset, type, type:hash) hash0032: clset (ok + nok = nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 28 - (tags=clause:clset, type, type:hash) hash0033: clset (nok + ok = nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 29 - (tags=clause:clset, type, type:hash) hash0034: clset (nok + nok = nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 30 - (tags=clause:ok, type, type:hash) hash0035: ok
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 31 - (tags=clause:ok, op, op:not, type, type:hash) hash0036: ok + op not (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 32 - (tags=attr, attr:err_level, type, type:hash) hash0037: .err_level=error (clause=is, ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 33 - (tags=attr, attr:err_level, type, type:hash) hash0038: .err_level=error (clause=is, nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 34 - (tags=attr, attr:err_level, type, type:hash) hash0039: .err_level=warn (clause=is, ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 35 - (tags=attr, attr:err_level, type, type:hash) hash0040: .err_level=warn (clause=is, nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 36 - (tags=clause:is, type, type:hash) hash0041: is: must accept same value
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 37 - (tags=clause:is, type, type:hash) hash0042: is: must reject different value
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 38 - (tags=clause:is, op, op:not, opshortcut, type, type:hash) hash0043: !is (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 39 - (tags=clause:is, op, op:not, opshortcut, type, type:hash) hash0044: !is (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 40 - (tags=clause:is, op, op:not, type, type:hash) hash0045: is.op=not (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 41 - (tags=clause:is, op, op:not, type, type:hash) hash0046: is.op=not (ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 42 - (tags=clause:is, op, op:and, opshortcut, type, type:hash) hash0047: is& (no items)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 43 - (tags=clause:is, op, op:and, opshortcut, type, type:hash) hash0048: is& (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 44 - (tags=clause:is, op, op:and, opshortcut, type, type:hash) hash0049: is& (nok + ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 45 - (tags=clause:is, op, op:and, opshortcut, type, type:hash) hash0050: is& (ok + nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 46 - (tags=clause:is, op, op:and, opshortcut, type, type:hash) hash0051: is& (nok + nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 47 - (tags=type, type:hash) hash0052: is.op=and (no items)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 48 - (tags=clause:is, op, op:and, type, type:hash) hash0053: is.op=and (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 49 - (tags=clause:is, op, op:and, type, type:hash) hash0054: is.op=and (nok + ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 50 - (tags=clause:is, op, op:and, type, type:hash) hash0055: is.op=and (ok + nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 51 - (tags=clause:is, op, op:and, type, type:hash) hash0056: is.op=and (nok + nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 52 - (tags=clause:is, op, op:or, opshortcut, type, type:hash) hash0057: is| (no items)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 53 - (tags=clause:is, op, op:or, opshortcut, type, type:hash) hash0058: is| (ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 54 - (tags=clause:is, op, op:or, opshortcut, type, type:hash) hash0059: is| (nok + ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 55 - (tags=clause:is, op, op:or, opshortcut, type, type:hash) hash0060: is| (ok + nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 56 - (tags=clause:is, op, op:or, opshortcut, type, type:hash) hash0061: is| (nok + nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 57 - (tags=clause:is, op, op:or, type, type:hash) hash0062: is.op=or (no items)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 58 - (tags=clause:is, op, op:or, type, type:hash) hash0063: is.op=or (ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 59 - (tags=clause:is, op, op:or, type, type:hash) hash0064: is.op=or (nok + ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 60 - (tags=clause:is, op, op:or, type, type:hash) hash0065: is.op=or (ok + nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 61 - (tags=clause:is, op, op:or, type, type:hash) hash0066: is.op=or (nok + nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 62 - (tags=clause:is, op, op:none, type, type:hash) hash0067: is.op=none (empty items)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 63 - (tags=clause:is, op, op:none, type, type:hash) hash0068: is.op=none (nok + nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 64 - (tags=clause:is, op, op:none, type, type:hash) hash0069: is.op=none (nok + ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 65 - (tags=clause:is, op, op:none, type, type:hash) hash0070: is.op=none (ok + nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 66 - (tags=clause:is, op, op:none, type, type:hash) hash0071: is.op=none (ok + ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 67 - (tags=clause:in, type, type:hash) hash0072: in: must accept valid choices
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 68 - (tags=clause:in, type, type:hash) hash0073: in: must reject empty choices
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 69 - (tags=clause:in, op, op:not, opshortcut, type, type:hash) hash0074: !in (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 70 - (tags=clause:in, op, op:not, opshortcut, type, type:hash) hash0075: !in (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 71 - (tags=clause:in, op, op:not, type, type:hash) hash0076: in.op=not (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 72 - (tags=clause:in, op, op:not, type, type:hash) hash0077: in.op=not (ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 73 - (tags=clause:in, op, op:and, opshortcut, type, type:hash) hash0078: in& (no items)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 74 - (tags=clause:in, op, op:and, opshortcut, type, type:hash) hash0079: in& (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 75 - (tags=clause:in, op, op:and, opshortcut, type, type:hash) hash0080: in& (nok + ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 76 - (tags=clause:in, op, op:and, opshortcut, type, type:hash) hash0081: in& (ok + nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 77 - (tags=clause:in, op, op:and, opshortcut, type, type:hash) hash0082: in& (nok + nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 78 - (tags=type, type:hash) hash0083: in.op=and (no items)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 79 - (tags=clause:in, op, op:and, type, type:hash) hash0084: in.op=and (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 80 - (tags=clause:in, op, op:and, type, type:hash) hash0085: in.op=and (nok + ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 81 - (tags=clause:in, op, op:and, type, type:hash) hash0086: in.op=and (ok + nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 82 - (tags=clause:in, op, op:and, type, type:hash) hash0087: in.op=and (nok + nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 83 - (tags=clause:in, op, op:or, opshortcut, type, type:hash) hash0088: in| (no items)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 84 - (tags=clause:in, op, op:or, opshortcut, type, type:hash) hash0089: in| (ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 85 - (tags=clause:in, op, op:or, opshortcut, type, type:hash) hash0090: in| (nok + ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 86 - (tags=clause:in, op, op:or, opshortcut, type, type:hash) hash0091: in| (ok + nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 87 - (tags=clause:in, op, op:or, opshortcut, type, type:hash) hash0092: in| (nok + nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 88 - (tags=clause:in, op, op:or, type, type:hash) hash0093: in.op=or (no items)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 89 - (tags=clause:in, op, op:or, type, type:hash) hash0094: in.op=or (ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 90 - (tags=clause:in, op, op:or, type, type:hash) hash0095: in.op=or (nok + ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 91 - (tags=clause:in, op, op:or, type, type:hash) hash0096: in.op=or (ok + nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 92 - (tags=clause:in, op, op:or, type, type:hash) hash0097: in.op=or (nok + nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 93 - (tags=clause:in, op, op:none, type, type:hash) hash0098: in.op=none (empty items)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 94 - (tags=clause:in, op, op:none, type, type:hash) hash0099: in.op=none (nok + nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 95 - (tags=clause:in, op, op:none, type, type:hash) hash0100: in.op=none (nok + ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 96 - (tags=clause:in, op, op:none, type, type:hash) hash0101: in.op=none (ok + nok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 97 - (tags=clause:in, op, op:none, type, type:hash) hash0102: in.op=none (ok + ok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 98 - (tags=clause:len, type, type:hash) hash0103: len (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 99 - (tags=clause:len, type, type:hash) hash0104: len (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 100 - (tags=clause:min_len, type, type:hash) hash0105: min_len (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 101 - (tags=clause:min_len, type, type:hash) hash0106: min_len (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 102 - (tags=clause:max_len, type, type:hash) hash0107: max_len (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 103 - (tags=clause:max_len, type, type:hash) hash0108: max_len (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 104 - (tags=clause:len_between, type, type:hash) hash0109: len_between (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 105 - (tags=clause:len_between, type, type:hash) hash0110: len_between (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 106 - (tags=clause:each_index, type, type:hash) hash0111: each_index (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 107 - (tags=clause:each_index, type, type:hash) hash0112: each_index (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 108 - (tags=clause:each_key, type, type:hash) hash0113: each_key (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 109 - (tags=clause:each_key, type, type:hash) hash0114: each_key (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 110 - (tags=clause:each_elem, type, type:hash) hash0115: each_elem (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 111 - (tags=clause:each_elem, type, type:hash) hash0116: each_elem (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 112 - (tags=clause:of, type, type:hash) hash0117: of (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 113 - (tags=clause:of, type, type:hash) hash0118: of (nok)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 114 - (tags=clause:each_value, type, type:hash) hash0119: each_value (ok)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 115 - (tags=clause:each_value, type, type:hash) hash0120: each_value (nok)
    #             ok 1 - valid input [0]
    #             ok 2 - valid input [1]
    #             ok 3 - invalid input [0]
    #             ok 4 - invalid input [1]
    #             1..4
    #         ok 116 - (tags=clause:has, type, type:hash) hash0129: has
    #             ok 1 - valid input [0]
    #             ok 2 - valid input [1]
    #             ok 3 - invalid input [0]
    #             ok 4 - invalid input [1]
    #             1..4
    #         ok 117 - (tags=clause:has, op, op:not, opshortcut, type, type:hash) hash0130: has + op.not
    #             ok 1 - valid input [0]
    #             ok 2 - valid input [1]
    #             ok 3 - invalid input [0]
    #             ok 4 - invalid input [1]
    #             1..4
    #         ok 118 - (tags=clause:has, op, op:or, opshortcut, type, type:hash) hash0131: has + op.or
    #             ok 1 - valid input [0]
    #             ok 2 - invalid input [0]
    #             ok 3 - invalid input [1]
    #             ok 4 - invalid input [2]
    #             1..4
    #         ok 119 - (tags=clause:has, op, op:and, opshortcut, type, type:hash) hash0132: has + op.and
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 120 - (tags=clause:keys, type, type:hash) hash0138: keys: (ok, empty)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 121 - (tags=clause:keys, type, type:hash) hash0139: keys: (ok, only a, a valid 1)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 122 - (tags=clause:keys, type, type:hash) hash0140: keys: (ok, only a, a valid 2)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 123 - (tags=clause:keys, type, type:hash) hash0141: keys: (nok, only a, a invalid)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 124 - (tags=clause:keys, type, type:hash) hash0142: keys: (ok, only a, valid 2)
    #             ok 1 - valid (rt=bool)
    #             ok 2 - valid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 125 - (tags=clause:keys, type, type:hash) hash0143: keys: (ok, a & b, valid)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 126 - (tags=clause:keys, type, type:hash) hash0144: keys: (nok, a & b, b invalid)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 127 - (tags=clause:keys, type, type:hash) hash0145: keys: (nok, a & b, a invalid)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 128 - (tags=clause:keys, type, type:hash) hash0146: keys: (nok, a & b, a & b invalid)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 129 - (tags=clause:keys, type, type:hash) hash0147: keys: (nok, extra)
    #             ok 1 - invalid (rt=bool)
    #             ok 2 - invalid (rt=str)
    #             ok 3 - validator (rt=full) returns object
    #             ok 4 - errors (rt=full)
    #             ok 5 - warnings (rt=full)
    #             1..5
    #         ok 130 - (tags=clause:keys, type, type:hash) hash0148: keys: (ok, extra, restrict=0)
    # /tmp/I1IO3CXrL2/jsnubVC0ty:9374
    #     ok(sahv_hash118_bool({"b":null}), 'valid (rt=bool)');
    #     ^
    # 
    # ReferenceError: sahv_hash118_bool is not defined
    #     at /tmp/I1IO3CXrL2/jsnubVC0ty:9374:5
    #     at subtest (/tmp/I1IO3CXrL2/jsnubVC0ty:44:6)
    #     at Object.<anonymous> (/tmp/I1IO3CXrL2/jsnubVC0ty:9373:1)
    #     at Module._compile (internal/modules/cjs/loader.js:778:30)
    #     at Object.Module._extensions..js (internal/modules/cjs/loader.js:789:10)
    #     at Module.load (internal/modules/cjs/loader.js:653:32)
    #     at tryModuleLoad (internal/modules/cjs/loader.js:593:12)
    #     at Function.Module._load (internal/modules/cjs/loader.js:585:3)
    #     at Function.Module.runMain (internal/modules/cjs/loader.js:831:12)
    #     at startup (internal/bootstrap/node.js:283:19)
    # >>, exit status ($?)=256, errno ($!)=Illegal seek, result=256Illegal seek
    # Looks like you failed 5 tests of 419.

#   Failed test '10-type-hash.json'
#   at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Test/Data/Sah.pm line 272.
    # Loading 10-type-int.json ...

    #   Failed test 'compile ok ((tags=clause:default, type, type:int) int0021: default: must accept valid default 1}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 643.

    #   Failed test 'compile ok ((tags=clause:default, type, type:int) int0022: default: must reject invalid default []}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 643.
    # Looks like you failed 2 tests of 414.

#   Failed test '10-type-int.json'
#   at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Test/Data/Sah.pm line 272.
    # Loading 10-type-num.json ...

    #   Failed test 'compile ok ((tags=clause:default, type, type:num) num0022: default: must accept valid default 1.1}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 643.

    #   Failed test 'compile ok ((tags=clause:default, type, type:num) num0023: default: must reject invalid default []}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 643.
    # Looks like you failed 2 tests of 411.

#   Failed test '10-type-num.json'
#   at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Test/Data/Sah.pm line 272.
    # Loading 10-type-obj.json ...
    # Skipping test (tags=clause:isa, type, type:obj) obj0002: isa (nok): obj clause isa not yet implemented
    # Skipping test (tags=prop:meths, type, type:obj) obj0003: prop:meths (nok): properties are not yet implemented
    # Skipping test (tags=prop:attrs, type, type:obj) obj0004: prop:attrs (nok): properties are not yet implemented
    # Loading 10-type-str.json ...

    #   Failed test 'compile ok ((tags=clause:default, type, type:str) str0020: default: must accept valid default a}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 643.

    #   Failed test 'compile ok ((tags=clause:default, type, type:str) str0021: default: must reject invalid default []}, bool)'
    #   at /tmp/loop_over_bdir-867410-MBhhnI/Data-Sah-JS-0.87-0/blib/lib/Test/Data/Sah/JS.pm line 157.
    # Can't locate object method "expr_list" via package "Data::Sah::Compiler::js" at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Data/Sah/Compiler/Prog.pm line 643.
    # Skipping test (tags=clause:check_each_index, type, type:str) str0164: check_each_index: clause check_each_index not yet implemented
    # Skipping test (tags=clause:check_each_elem, type, type:str) str0165: check_each_elem: clause check_each_elem not yet implemented
    # Skipping test (tags=clause:uniq, type, type:str) str0166: uniq=1: clause uniq not yet implemented
    # Skipping test (tags=clause:uniq, type, type:str) str0167: uniq=0: clause uniq not yet implemented
    # Skipping test (tags=clause:uniq, op, op:not, opshortcut, type, type:str) str0168: !uniq=1: clause uniq not yet implemented
    # Skipping test (tags=clause:exists, type, type:str) str0169: exists: clause exists not yet implemented
    # Skipping test (tags=prop:len, type, type:str) str0174: prop:len: properties are not yet implemented
    # Skipping test (tags=prop:indices, type, type:str) str0175: prop:indices: properties are not yet implemented
    # Skipping test (tags=prop:elems, type, type:str) str0176: prop:elems: properties are not yet implemented
    # Looks like you failed 2 tests of 467.

#   Failed test '10-type-str.json'
#   at /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/Test/Data/Sah.pm line 272.
    # Loading 10-type-undef.json ...
# Looks like you failed 9 tests of 13.
t/spectest-js.t .......... 
Dubious, test returned 9 (wstat 2304, 0x900)
Failed 9/13 subtests 

Test Summary Report
-------------------
t/js-type-date.t       (Wstat: 65280 Tests: 0 Failed: 0)
  Non-zero exit status: 255
  Parse errors: No plan found in TAP output
t/js-type-duration.t   (Wstat: 65280 Tests: 0 Failed: 0)
  Non-zero exit status: 255
  Parse errors: No plan found in TAP output
t/spectest-js.t        (Wstat: 2304 Tests: 13 Failed: 9)
  Failed tests:  3-10, 12
  Non-zero exit status: 9
Files=8, Tests=36, 30 wallclock secs ( 0.57 usr  0.08 sys + 25.10 cusr  4.21 csys = 29.96 CPU)
Result: FAIL
Failed 3/8 test programs. 9/36 subtests failed.
make: *** [Makefile:1014: test_dynamic] Error 9

------------------------------
PREREQUISITES
------------------------------

Prerequisite modules loaded:

requires:

    Module                        Need     Have    
    ----------------------------- -------- --------
    Capture::Tiny                 0        0.48    
    Data::Clean::JSON             0.11     0.392   
    Data::Sah                     0.84     0.903   
    Data::Sah::Coerce             0.014    0.044   
    Data::Sah::Compiler::Prog     0        0.903   
    Data::Sah::Compiler::Prog::TH 0        0.903   
    Data::Sah::Type::array        0        0.903   
    Data::Sah::Type::bool         0        0.903   
    Data::Sah::Type::buf          0        0.903   
    Data::Sah::Type::cistr        0        0.903   
    Data::Sah::Type::code         0        0.903   
    Data::Sah::Type::date         0        0.903   
    Data::Sah::Type::duration     0        0.903   
    Data::Sah::Type::float        0        0.903   
    Data::Sah::Type::hash         0        0.903   
    Data::Sah::Type::int          0        0.903   
    Data::Sah::Type::num          0        0.903   
    Data::Sah::Type::obj          0        0.903   
    Data::Sah::Type::re           0        0.903   
    Data::Sah::Type::str          0        0.903   
    Data::Sah::Type::undef        0        0.903   
    Exporter                      0        5.73    
    File::Temp                    0        0.2309  
    IPC::System::Options          0.27     0.332   
    JSON::MaybeXS                 0        1.004000
    Mo                            0        0.40    
    Nodejs::Util                  0.006    0.012   
    parent                        0        0.237   
    perl                          5.010001 5.014004
    Role::Tiny::With              0        2.001004
    Scalar::Util                  0        1.53    
    Scalar::Util::Numeric::PP     0        0.04    
    strict                        0        1.04    
    String::Indent                0        0.03    
    Test::Data::Sah               0.87     0.903   
    Test::More                    0.98     1.302171
    warnings                      0        1.12    

build_requires:

    Module                        Need     Have    
    ----------------------------- -------- --------
    ExtUtils::MakeMaker           0        7.41_01 
    File::Spec                    0        3.75    
    IO::Handle                    0        1.39    
    IPC::Open3                    0        1.0901  
    Sah::SpecTest                 v0.9.42  0.9.46  
    Test::Exception               0        0.43    
    Test::More                    0.98     1.302171

configure_requires:

    Module                        Need     Have    
    ----------------------------- -------- --------
    ExtUtils::MakeMaker           0        7.41_01 


------------------------------
ENVIRONMENT AND OTHER CONTEXT
------------------------------

Environment variables:

    AUTOMATED_TESTING = 1
    LANG = en_US.UTF-8
    PATH = /home/sand/bin:/usr/local/bin:/usr/bin:/bin:/usr/games:/usr/local/perl/bin:/usr/X11/bin:/sbin:/usr/sbin
    PERL5LIB = 
    PERL5OPT = 
    PERL5_CPANPLUS_IS_RUNNING = 4125665
    PERL5_CPAN_IS_RUNNING = 4125665
    PERL_CANARY_STABILITY_NOPROMPT = 1
    PERL_MM_USE_DEFAULT = 1
    PERL_USE_UNSAFE_INC = 1
    SHELL = /usr/bin/zsh
    TERM = screen

Perl special variables (and OS-specific diagnostics, for MSWin32):

    $^X = /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/bin/perl
    $UID/$EUID = 1005 / 1005
    $GID = 1005 1005
    $EGID = 1005 1005

Perl module toolchain versions installed:

    Module              Have    
    ------------------- --------
    CPAN                2.27    
    CPAN::Meta          2.150010
    Cwd                 3.75    
    ExtUtils::CBuilder  0.280234
    ExtUtils::Command   7.41_01 
    ExtUtils::Install   2.06    
    ExtUtils::MakeMaker 7.41_01 
    ExtUtils::Manifest  1.70    
    ExtUtils::ParseXS   3.35    
    File::Spec          3.75    
    JSON                4.02    
    JSON::PP            4.04    
    Module::Build       0.4229  
    Module::Signature   0.83    
    Parse::CPAN::Meta   2.150010
    Test::Harness       3.42    
    Test::More          1.302171
    YAML                1.29    
    YAML::Syck          1.31    
    version             0.9924  


--

Summary of my perl5 (revision 5 version 14 subversion 4) configuration:
  Derived from: 26c5c13a4ece9084f310610bb17fb2f24c72a73e
  Platform:
    osname=linux, osvers=5.3.0-2-amd64, archname=x86_64-linux-ld
    uname='linux k93msid 5.3.0-2-amd64 #1 smp debian 5.3.9-3 (2019-11-19) x86_64 gnulinux '
    config_args='-Dprefix=/home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43 -Dmyhostname=k93msid -Dinstallusrbinperl=n -Uversiononly -Dusedevel -des -Ui_db -Dlibswanted=cl pthread socket inet nsl gdbm dbm malloc dl ld sun m crypt sec util c cposix posix ucb BSD gdbm_compat -Uuseithreads -Duselongdouble -DEBUGGING=both'
    hint=recommended, useposix=true, d_sigaction=define
    useithreads=undef, usemultiplicity=undef
    useperlio=define, d_sfio=undef, uselargefiles=define, usesocks=undef
    use64bitint=define, use64bitall=define, uselongdouble=define
    usemymalloc=n, bincompat5005=undef
  Compiler:
    cc='cc', ccflags ='-fwrapv -DDEBUGGING -fno-strict-aliasing -pipe -fstack-protector -I/usr/local/include -D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64',
    optimize='-O2 -g',
    cppflags='-fwrapv -DDEBUGGING -fno-strict-aliasing -pipe -fstack-protector -I/usr/local/include'
    ccversion='', gccversion='9.2.1 20191109', gccosandvers=''
    intsize=4, longsize=8, ptrsize=8, doublesize=8, byteorder=12345678
    d_longlong=define, longlongsize=8, d_longdbl=define, longdblsize=16
    ivtype='long', ivsize=8, nvtype='long double', nvsize=16, Off_t='off_t', lseeksize=8
    alignbytes=16, prototype=define
  Linker and Libraries:
    ld='cc', ldflags =' -fstack-protector -L/usr/local/lib'
    libpth=/usr/local/lib /lib/x86_64-linux-gnu /lib/../lib /usr/lib/x86_64-linux-gnu /usr/lib/../lib /lib /usr/lib
    libs=-lpthread -lnsl -ldl -lm -lcrypt -lutil -lc
    perllibs=-lpthread -lnsl -ldl -lm -lcrypt -lutil -lc
    libc=libc-2.29.so, so=so, useshrplib=false, libperl=libperl.a
    gnulibc_version='2.29'
  Dynamic Linking:
    dlsrc=dl_dlopen.xs, dlext=so, d_dlsymun=undef, ccdlflags='-Wl,-E'
    cccdlflags='-fPIC', lddlflags='-shared -O2 -g -L/usr/local/lib -fstack-protector'


Characteristics of this binary (from libperl): 
  Compile-time options: DEBUGGING PERL_DONT_CREATE_GVSV PERL_MALLOC_WRAP
                        PERL_PRESERVE_IVUV PERL_USE_DEVEL USE_64_BIT_ALL
                        USE_64_BIT_INT USE_LARGE_FILES USE_LONG_DOUBLE
                        USE_PERLIO USE_PERL_ATOF
  Locally applied patches:
	uncommitted-changes
  Built under linux
  Compiled at Nov 26 2019 08:08:33
  %ENV:
    PERL5LIB=""
    PERL5OPT=""
    PERL5_CPANPLUS_IS_RUNNING="4125665"
    PERL5_CPAN_IS_RUNNING="4125665"
    PERL_CANARY_STABILITY_NOPROMPT="1"
    PERL_MM_USE_DEFAULT="1"
    PERL_USE_UNSAFE_INC="1"
  @INC:
    /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4/x86_64-linux-ld
    /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/site_perl/5.14.4
    /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/5.14.4/x86_64-linux-ld
    /home/sand/src/perl/repoperls/installed-perls/host/k93msid/v5.14.4/fc43/lib/5.14.4
    .