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 | }
|