blob: 654aae5e6ea69b812c1835eea6c0a9ac92a75b8a [file] [log] [blame]
Darren Tucker3e86fc42004-06-17 16:34:02 +10001# $OpenBSD: multiplex.sh,v 1.5 2004/06/17 06:19:06 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 Tucker10e7f192004-06-17 16:36:27 +10008DATA=/bin/ls${EXEEXT}
Darren Tuckerffaa6a52004-06-17 16:32:45 +10009COPY=$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}
Darren Tucker3e86fc42004-06-17 16:34:02 +100019test -f ${COPY} || fail "ssh -Sctl: failed copy ${DATA}"
20cmp ${DATA} ${COPY} || fail "ssh -Sctl: 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}
Darren Tucker3e86fc42004-06-17 16:34:02 +100025test -f ${COPY} || fail "ssh -S ctl: failed copy ${DATA}"
26cmp ${DATA} ${COPY} || fail "ssh -S ctl: 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 Tucker3e86fc42004-06-17 16:34:02 +100032test -f ${COPY} || fail "sftp: failed copy ${DATA}"
33cmp ${DATA} ${COPY} || fail "sftp: 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
Darren Tucker3e86fc42004-06-17 16:34:02 +100038test -f ${COPY} || fail "scp: failed copy ${DATA}"
39cmp ${DATA} ${COPY} || fail "scp: 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