1#	$OpenBSD: connect-privsep.sh,v 1.3 2012/06/26 12:06:59 dtucker Exp $
2#	Placed in the Public Domain.
3
4tid="proxy connect with privsep"
5
6cp $OBJ/sshd_proxy $OBJ/sshd_proxy.orig
7echo 'UsePrivilegeSeparation yes' >> $OBJ/sshd_proxy
8
9for p in 1 2; do
10	${SSH} -$p -F $OBJ/ssh_proxy 999.999.999.999 true
11	if [ $? -ne 0 ]; then
12		fail "ssh privsep+proxyconnect protocol $p failed"
13	fi
14done
15
16cp $OBJ/sshd_proxy.orig $OBJ/sshd_proxy
17echo 'UsePrivilegeSeparation sandbox' >> $OBJ/sshd_proxy
18
19for p in 1 2; do
20	${SSH} -$p -F $OBJ/ssh_proxy 999.999.999.999 true
21	if [ $? -ne 0 ]; then
22		fail "ssh privsep/sandbox+proxyconnect protocol $p failed"
23	fi
24done
25
26# Because sandbox is sensitive to changes in libc, especially malloc, retest
27# with every malloc.conf option (and none).
28for m in '' A F G H J P R S X Z '<' '>'; do
29    for p in 1 2; do
30	env MALLOC_OPTIONS="$m" ${SSH} -$p -F $OBJ/ssh_proxy 999.999.999.999 true
31	if [ $? -ne 0 ]; then
32		fail "ssh privsep/sandbox+proxyconnect protocol $p mopt '$m' failed"
33	fi
34    done
35done
36
37exit
38