| 1 | #!/usr/bin/env bash
|
| 2 | #
|
| 3 | # Testing library for bash and OSH.
|
| 4 | #
|
| 5 | # Capture status/stdout/stderr, and nq-assert those values.
|
| 6 |
|
| 7 | #module yblocks || return 0
|
| 8 |
|
| 9 | : ${LIB_OSH=stdlib/osh}
|
| 10 | source $LIB_OSH/two.sh
|
| 11 |
|
| 12 | # There is no yb-run, because you can just use try { } and inspect _error.code
|
| 13 | # There is no yb-redir, because you can just use try >$tmp { } and inspect _error.code
|
| 14 |
|
| 15 | proc yb-capture(; out; ; block) {
|
| 16 | ### capture status and stderr
|
| 17 |
|
| 18 | var stdout = ''
|
| 19 | try {
|
| 20 | eval (block) | read --all (&stdout)
|
| 21 | }
|
| 22 | # TODO: if 'block' contains a pipeline, we lose this magic var
|
| 23 | var result = {status: _pipeline_status[0], stdout}
|
| 24 |
|
| 25 | #echo 'result-1'
|
| 26 | #pp test_ (result)
|
| 27 |
|
| 28 | call out->setValue(result)
|
| 29 | }
|
| 30 |
|
| 31 | proc yb-capture-2(; out; ; block) {
|
| 32 | ### capture status and stderr
|
| 33 |
|
| 34 | var stderr = ''
|
| 35 | try {
|
| 36 | eval (block) 2>&1 | read --all (&stderr)
|
| 37 | }
|
| 38 | #pp test_ (_pipeline_status)
|
| 39 |
|
| 40 | var result = {status: _pipeline_status[0], stderr}
|
| 41 | #echo 'result-2'
|
| 42 | #pp test_ (result)
|
| 43 |
|
| 44 | call out->setValue(result)
|
| 45 | }
|