run-file () { local spec_name=$1; shift; local spec_file=spec/$spec_name.test.sh; local suite; suite=$(test/sh_spec.py --print-spec-suite $spec_file); local spec_subdir; case $suite in osh) spec_subdir='osh-cpp' ;; ysh) spec_subdir='ysh-cpp' ;; *) die "Invalid suite $suite" ;; esac; local base_dir=_tmp/spec/$spec_subdir; mkdir -v -p $base_dir; sh-spec $spec_file --timeout 10 --oils-bin-dir $PWD/bin --oils-cpp-bin-dir $REPO_ROOT/_bin/cxx-asan --tsv-output $base_dir/${spec_name}.tsv "$@" } introspect: spec test case results

Results for introspect.test.sh

statusoshosh-cpp
pass 1313
total1313
caseoshosh-cppdescription
0pass pass ${FUNCNAME[@]} array
1pass pass FUNCNAME with source (scalar or array)
2pass pass BASH_SOURCE and BASH_LINENO scalar or array (e.g. for virtualenv)
3pass pass ${FUNCNAME} with prefix/suffix operators
4pass pass operators on FUNCNAME
5pass pass ${FUNCNAME} and "set -u" (OSH regression)
6pass pass $((BASH_LINENO)) (scalar form in arith)
7pass pass ${BASH_SOURCE[@]} with source and function name
8pass pass ${BASH_SOURCE[@]} with line numbers
9pass pass ${BASH_LINENO[@]} is a stack of line numbers for function calls
10pass pass Locations with temp frame
11pass pass Locations when sourcing
12pass pass Sourcing inside function grows the debug stack
26 passed, 0 OK, 0 not implemented, 0 BUG, 0 failed, 0 timeouts, 0 cases skipped