1 |
## oils_failures_allowed: 1
|
2 |
## compare_shells: bash dash mksh zsh
|
3 |
|
4 |
#
|
5 |
# Tests for pipelines.
|
6 |
# NOTE: Grammatically, ! is part of the pipeline:
|
7 |
#
|
8 |
# pipeline : pipe_sequence
|
9 |
# | Bang pipe_sequence
|
10 |
|
11 |
|
12 |
{ echo one; echo two; } | tac
|
13 |
## stdout-json: "two\none\n"
|
14 |
|
15 |
|
16 |
for w in one two; do
|
17 |
echo $w
|
18 |
done | tac
|
19 |
## stdout-json: "two\none\n"
|
20 |
|
21 |
|
22 |
seq 3 | while read i
|
23 |
do
|
24 |
echo ".$i"
|
25 |
done
|
26 |
## stdout-json: ".1\n.2\n.3\n"
|
27 |
|
28 |
|
29 |
echo hi 1>&2 | wc -l
|
30 |
## stdout: 0
|
31 |
## BUG zsh stdout: 1
|
32 |
|
33 |
|
34 |
echo abcd | # input
|
35 |
# blank line
|
36 |
tr a-z A-Z # transform
|
37 |
## stdout: ABCD
|
38 |
|
39 |
|
40 |
echo a | egrep '[0-9]+'
|
41 |
## status: 1
|
42 |
|
43 |
|
44 |
return3() {
|
45 |
return 3
|
46 |
}
|
47 |
{ sleep 0.03; exit 1; } | { sleep 0.02; exit 2; } | { sleep 0.01; return3; }
|
48 |
echo ${PIPESTATUS[@]}
|
49 |
## stdout: 1 2 3
|
50 |
## N-I dash status: 2
|
51 |
## N-I dash stdout-json: ""
|
52 |
## N-I zsh status: 0
|
53 |
## N-I zsh stdout-json: "\n"
|
54 |
|
55 |
|
56 |
case $SH in dash|zsh) exit ;; esac
|
57 |
|
58 |
false
|
59 |
echo pipestatus ${PIPESTATUS[@]}
|
60 |
|
61 |
## STDOUT:
|
62 |
pipestatus 1
|
63 |
## END
|
64 |
## OK osh STDOUT:
|
65 |
pipestatus
|
66 |
## END
|
67 |
## N-I dash/zsh STDOUT:
|
68 |
## END
|
69 |
|
70 |
|
71 |
shopt -s lastpipe
|
72 |
return3() {
|
73 |
return 3
|
74 |
}
|
75 |
{ sleep 0.03; exit 1; } | { sleep 0.02; exit 2; } | { sleep 0.01; return3; }
|
76 |
echo ${PIPESTATUS[@]}
|
77 |
## stdout: 1 2 3
|
78 |
## N-I dash status: 2
|
79 |
## N-I dash stdout-json: ""
|
80 |
## N-I zsh status: 0
|
81 |
## N-I zsh stdout-json: "\n"
|
82 |
|
83 |
|
84 |
stdout_stderr.py |& cat
|
85 |
## STDOUT:
|
86 |
STDERR
|
87 |
STDOUT
|
88 |
## END
|
89 |
## status: 0
|
90 |
## N-I dash/mksh stdout-json: ""
|
91 |
## N-I dash status: 2
|
92 |
## N-I osh stdout-json: ""
|
93 |
## N-I osh status: 1
|
94 |
|
95 |
|
96 |
! $SH -c 'exit 42'; echo $?
|
97 |
## stdout: 0
|
98 |
## status: 0
|
99 |
|
100 |
|
101 |
! $SH -c 'exit 0'; echo $?
|
102 |
## stdout: 1
|
103 |
## status: 0
|
104 |
|
105 |
|
106 |
if ! echo hi; then
|
107 |
echo TRUE
|
108 |
else
|
109 |
echo FALSE
|
110 |
fi
|
111 |
## stdout-json: "hi\nFALSE\n"
|
112 |
## status: 0
|
113 |
|
114 |
|
115 |
! echo hi || echo FAILED
|
116 |
## stdout-json: "hi\nFAILED\n"
|
117 |
## status: 0
|
118 |
|
119 |
|
120 |
! { echo 1; echo 2; } || echo FAILED
|
121 |
## stdout-json: "1\n2\nFAILED\n"
|
122 |
## status: 0
|
123 |
|
124 |
|
125 |
! ( echo 1; echo 2 ) || echo FAILED
|
126 |
## stdout-json: "1\n2\nFAILED\n"
|
127 |
## status: 0
|
128 |
|
129 |
|
130 |
v='!'
|
131 |
$v echo hi
|
132 |
## status: 127
|
133 |
|
134 |
|
135 |
${cmd=echo} hi | wc -l
|
136 |
echo "cmd=$cmd"
|
137 |
## STDOUT:
|
138 |
1
|
139 |
cmd=
|
140 |
## END
|
141 |
## BUG zsh STDOUT:
|
142 |
1
|
143 |
cmd=echo
|
144 |
## END
|
145 |
|
146 |
|
147 |
echo hi | read line
|
148 |
echo "line=$line"
|
149 |
## stdout: line=hi
|
150 |
## OK bash/dash/mksh stdout: line=
|
151 |
|
152 |
|
153 |
shopt -s lastpipe
|
154 |
echo hi | read line
|
155 |
echo "line=$line"
|
156 |
## stdout: line=hi
|
157 |
## N-I dash/mksh stdout: line=
|
158 |
|
159 |
|
160 |
shopt -s lastpipe
|
161 |
i=0
|
162 |
seq 3 | while read line; do
|
163 |
(( i++ ))
|
164 |
done
|
165 |
echo i=$i
|
166 |
## stdout: i=3
|
167 |
## N-I dash/mksh stdout: i=0
|
168 |
|
169 |
|
170 |
|
171 |
cat /dev/urandom | sleep 0.1
|
172 |
echo ${PIPESTATUS[@]}
|
173 |
|
174 |
# hm bash gives '1 0' which seems wrong
|
175 |
|
176 |
## STDOUT:
|
177 |
141 0
|
178 |
## END
|
179 |
## BUG bash STDOUT:
|
180 |
1 0
|
181 |
## END
|
182 |
## N-I zsh stdout:
|
183 |
## N-I dash status: 2
|
184 |
## N-I dash stdout-json: ""
|
185 |
|
186 |
|
187 |
{ sleep 0.1 | seq 3; } | cat
|
188 |
{ sleep 0.1 | seq 10; } | { cat | cat; } | wc -l
|
189 |
## STDOUT:
|
190 |
1
|
191 |
2
|
192 |
3
|
193 |
10
|
194 |
## END
|
195 |
|
196 |
|
197 |
ls /dev/null | eval 'cat | cat' | wc -l
|
198 |
## STDOUT:
|
199 |
1
|
200 |
## END
|
201 |
|
202 |
|
203 |
|
204 |
|
205 |
case $SH in dash) exit ;; esac
|
206 |
|
207 |
$SH -c '
|
208 |
shopt -s lastpipe
|
209 |
set -o errexit
|
210 |
set -o pipefail
|
211 |
|
212 |
ls | false | wc -l'
|
213 |
echo status=$?
|
214 |
|
215 |
# Why does this give status 0? It should fail
|
216 |
|
217 |
$SH -c '
|
218 |
shopt -s lastpipe
|
219 |
shopt -s no_fork_last # OSH only
|
220 |
set -o errexit
|
221 |
set -o pipefail
|
222 |
|
223 |
ls | false | wc -l'
|
224 |
echo status=$?
|
225 |
|
226 |
## STDOUT:
|
227 |
0
|
228 |
status=1
|
229 |
0
|
230 |
status=1
|
231 |
## END
|
232 |
|
233 |
## N-I dash STDOUT:
|
234 |
## END
|
235 |
|
236 |
|
237 |
|
238 |
|