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