blob: 9fea117bd086a497c6366d379760c216d3aba218 [file] [log] [blame]
Darren Tuckerffaa6a52004-06-17 16:32:45 +10001# $OpenBSD: multiplex.sh,v 1.4 2004/06/17 06:00:05 dtucker Exp $
Darren Tuckere7d05832004-06-16 20:22:22 +10002# Placed in the Public Domain.
3
4CTL=$OBJ/ctl-sock
5
6tid="connection multiplexing"
7
Darren Tuckerffaa6a52004-06-17 16:32:45 +10008DATA=/bin/ls
9COPY=$OBJ/ls.copy
10
Darren Tuckere7d05832004-06-16 20:22:22 +100011start_sshd
12
13trace "start master, fork to background"
14${SSH} -2 -MS$CTL -F $OBJ/ssh_config -f somehost sleep 60
15
Darren Tuckerffaa6a52004-06-17 16:32:45 +100016rm -f ${COPY}
Darren Tuckere7d05832004-06-16 20:22:22 +100017trace "ssh transfer over multiplexed connection and check result"
Darren Tuckerffaa6a52004-06-17 16:32:45 +100018${SSH} -S$CTL otherhost cat ${DATA} > ${COPY}
19test -f ${COPY} || fail "failed copy ${DATA}"
20cmp ${DATA} ${COPY} || fail "corrupted copy of ${DATA}"
Darren Tuckere7d05832004-06-16 20:22:22 +100021
Darren Tuckerffaa6a52004-06-17 16:32:45 +100022rm -f ${COPY}
Darren Tuckere7d05832004-06-16 20:22:22 +100023trace "ssh transfer over multiplexed connection and check result"
Darren Tuckerffaa6a52004-06-17 16:32:45 +100024${SSH} -S $CTL otherhost cat ${DATA} > ${COPY}
25test -f ${COPY} || fail "failed copy ${DATA}"
26cmp ${DATA} ${COPY} || fail "corrupted copy of ${DATA}"
Darren Tuckere7d05832004-06-16 20:22:22 +100027
Darren Tuckerffaa6a52004-06-17 16:32:45 +100028rm -f ${COPY}
Darren Tuckere7d05832004-06-16 20:22:22 +100029trace "sftp transfer over multiplexed connection and check result"
Darren Tuckerffaa6a52004-06-17 16:32:45 +100030echo "get ${DATA} ${COPY}" | \
Darren Tucker5711dca2004-06-16 23:23:50 +100031 ${SFTP} -oControlPath=$CTL otherhost >/dev/null 2>&1
Darren Tuckerffaa6a52004-06-17 16:32:45 +100032test -f ${COPY} || fail "failed copy ${DATA}"
33cmp ${DATA} ${COPY} || fail "corrupted copy of ${DATA}"
Darren Tuckere7d05832004-06-16 20:22:22 +100034
Darren Tuckerffaa6a52004-06-17 16:32:45 +100035rm -f ${COPY}
Darren Tuckere7d05832004-06-16 20:22:22 +100036trace "scp transfer over multiplexed connection and check result"
Darren Tuckerffaa6a52004-06-17 16:32:45 +100037${SCP} -oControlPath=$CTL otherhost:${DATA} ${COPY} >/dev/null 2>&1
38test -f ${COPY} || fail "failed copy ${DATA}"
39cmp ${DATA} ${COPY} || fail "corrupted copy of ${DATA}"
Darren Tuckere7d05832004-06-16 20:22:22 +100040
Darren Tuckerffaa6a52004-06-17 16:32:45 +100041rm -f ${COPY}
Darren Tuckerddea13d2004-06-17 16:27:43 +100042
Darren Tuckere7d05832004-06-16 20:22:22 +100043for s in 0 1 4 5 44; do
44 trace "exit status $s over multiplexed connection"
45 verbose "test $tid: status $s"
46 ${SSH} -S $CTL otherhost exit $s
47 r=$?
48 if [ $r -ne $s ]; then
49 fail "exit code mismatch for protocol $p: $r != $s"
50 fi
51
52 # same with early close of stdout/err
53 trace "exit status $s with early close over multiplexed connection"
54 ${SSH} -S $CTL -n otherhost \
55 exec sh -c \'"sleep 2; exec > /dev/null 2>&1; sleep 3; exit $s"\'
56 r=$?
57 if [ $r -ne $s ]; then
58 fail "exit code (with sleep) mismatch for protocol $p: $r != $s"
59 fi
60done
61
Darren Tuckerddea13d2004-06-17 16:27:43 +100062# kill master, remove control socket. ssh -MS will exit when sleep exits
63$SUDO kill `cat $PIDFILE`
64rm -f $CTL