|
|
#!/bin/sh |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
. "${srcdir=.}/tests/init.sh"; path_prepend_ ./src |
|
|
print_ver_ tee |
|
|
|
|
|
echo line >sample || framework_failure_ |
|
|
|
|
|
|
|
|
for n in 0 1 2 12 13; do |
|
|
files=$(seq $n) |
|
|
rm -f $files |
|
|
tee $files <sample >out || fail=1 |
|
|
for f in out $files; do |
|
|
compare sample $f || fail=1 |
|
|
done |
|
|
done |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
tee - <sample >out 2>err || fail=1 |
|
|
compare sample ./- || fail=1 |
|
|
compare sample out || fail=1 |
|
|
compare /dev/null err || fail=1 |
|
|
|
|
|
|
|
|
if test -w /dev/full && test -c /dev/full; then |
|
|
yes | returns_ 1 timeout 10 tee /dev/full 2>err >/dev/full || fail=1 |
|
|
|
|
|
|
|
|
test $(wc -l < err) = 2 || { cat err; fail=1; } |
|
|
|
|
|
|
|
|
|
|
|
seq 10000 > multi_read || framework_failure_ |
|
|
|
|
|
returns_ 1 tee /dev/full out2 2>err >out1 <multi_read || fail=1 |
|
|
cmp multi_read out1 || fail=1 |
|
|
cmp multi_read out2 || fail=1 |
|
|
|
|
|
test $(wc -l < err) = 1 || { cat err; fail=1; } |
|
|
|
|
|
returns_ 1 tee out1 out2 2>err >/dev/full <multi_read || fail=1 |
|
|
cmp multi_read out1 || fail=1 |
|
|
cmp multi_read out2 || fail=1 |
|
|
|
|
|
test $(wc -l < err) = 1 || { cat err; fail=1; } |
|
|
fi |
|
|
|
|
|
case $host_triplet in |
|
|
*aix*) echo 'avoiding due to no way to detect closed outputs on AIX' ;; |
|
|
*) |
|
|
|
|
|
tee_exited() { sleep $1; test -f tee.exited; } |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
retry_delay_ tee_exited .1 7 | |
|
|
{ timeout 10 tee -p 2>err && touch tee.exited; } | : |
|
|
test $(wc -l < err) = 0 || { cat err; fail=1; } |
|
|
test -f tee.exited || fail=1 ;; |
|
|
esac |
|
|
|
|
|
|
|
|
if ! uid_is_privileged_; then |
|
|
touch file.ro || framework_failure_ |
|
|
chmod a-w file.ro || framework_failure_ |
|
|
returns_ 1 tee -p </dev/null file.ro || fail=1 |
|
|
fi |
|
|
|
|
|
mkfifo_or_skip_ fifo |
|
|
|
|
|
|
|
|
|
|
|
cleanup_() { kill $pid 2>/dev/null && wait $pid; } |
|
|
read_fifo_delayed() { |
|
|
{ sleep .1; timeout 10 dd of=/dev/null status=none; } <fifo |
|
|
} |
|
|
read_fifo_delayed & pid=$! |
|
|
dd count=20 bs=100K if=/dev/zero status=none | |
|
|
{ |
|
|
dd count=0 oflag=nonblock status=none |
|
|
tee || { cleanup_; touch tee.fail; } |
|
|
} >fifo |
|
|
test -f tee.fail && fail=1 || cleanup_ |
|
|
|
|
|
|
|
|
read_fifo() { timeout 10 dd count=1 if=fifo of=/dev/null status=none & } |
|
|
|
|
|
|
|
|
read_fifo |
|
|
yes >fifo |
|
|
pipe_status=$? |
|
|
|
|
|
|
|
|
read_fifo |
|
|
yes | returns_ $pipe_status timeout 10 tee ./e/noent 2>err >fifo || fail=1 |
|
|
test $(wc -l < err) = 1 || { cat err; fail=1; } |
|
|
|
|
|
|
|
|
read_fifo |
|
|
yes | timeout 10 tee -p 2>err >fifo || fail=1 |
|
|
test $(wc -l < err) = 0 || { cat err; fail=1; } |
|
|
|
|
|
|
|
|
read_fifo |
|
|
yes | returns_ 1 timeout 10 tee --output-error=warn 2>err >fifo || fail=1 |
|
|
test $(wc -l < err) = 1 || { cat err; fail=1; } |
|
|
|
|
|
|
|
|
read_fifo |
|
|
yes | returns_ 1 timeout 10 tee --output-error=exit /dev/null 2>err >fifo \ |
|
|
|| fail=1 |
|
|
test $(wc -l < err) = 1 || { cat err; fail=1; } |
|
|
|
|
|
|
|
|
read_fifo |
|
|
yes | returns_ 1 timeout 10 tee --output-error=exit ./e/noent 2>err >fifo \ |
|
|
|| fail=1 |
|
|
test $(wc -l < err) = 1 || { cat err; fail=1; } |
|
|
|
|
|
|
|
|
read_fifo |
|
|
yes | timeout 10 tee --output-error=exit-nopipe 2>err >fifo || fail=1 |
|
|
test $(wc -l < err) = 0 || { cat err; fail=1; } |
|
|
|
|
|
wait |
|
|
Exit $fail |
|
|
|