Home | History | Annotate | Line # | Download | only in librumphijack
t_tcpip.sh revision 1.5
      1  1.5  pooka #       $NetBSD: t_tcpip.sh,v 1.5 2011/02/16 19:31:31 pooka Exp $
      2  1.1  pooka #
      3  1.1  pooka # Copyright (c) 2011 The NetBSD Foundation, Inc.
      4  1.1  pooka # All rights reserved.
      5  1.1  pooka #
      6  1.1  pooka # Redistribution and use in source and binary forms, with or without
      7  1.1  pooka # modification, are permitted provided that the following conditions
      8  1.1  pooka # are met:
      9  1.1  pooka # 1. Redistributions of source code must retain the above copyright
     10  1.1  pooka #    notice, this list of conditions and the following disclaimer.
     11  1.1  pooka # 2. Redistributions in binary form must reproduce the above copyright
     12  1.1  pooka #    notice, this list of conditions and the following disclaimer in the
     13  1.1  pooka #    documentation and/or other materials provided with the distribution.
     14  1.1  pooka #
     15  1.1  pooka # THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     16  1.1  pooka # ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     17  1.1  pooka # TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     18  1.1  pooka # PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
     19  1.1  pooka # BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     20  1.1  pooka # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     21  1.1  pooka # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     22  1.1  pooka # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     23  1.1  pooka # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     24  1.1  pooka # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     25  1.1  pooka # POSSIBILITY OF SUCH DAMAGE.
     26  1.1  pooka #
     27  1.1  pooka 
     28  1.1  pooka rumpnetsrv='rump_server -lrumpnet -lrumpnet_net -lrumpnet_netinet'
     29  1.1  pooka export RUMP_SERVER=unix://csock
     30  1.1  pooka 
     31  1.1  pooka atf_test_case http cleanup
     32  1.1  pooka http_head()
     33  1.1  pooka {
     34  1.1  pooka         atf_set "descr" "Start hijacked httpd and get webpage from it"
     35  1.1  pooka }
     36  1.1  pooka 
     37  1.1  pooka http_body()
     38  1.1  pooka {
     39  1.1  pooka 
     40  1.1  pooka 	atf_check -s exit:0 ${rumpnetsrv} ${RUMP_SERVER}
     41  1.1  pooka 	# make sure clients die after we nuke the server
     42  1.5  pooka 	export RUMPHIJACK_RETRYCONNECT='die'
     43  1.1  pooka 
     44  1.1  pooka 	# start bozo in daemon mode
     45  1.2  pooka 	atf_check -s exit:0 env LD_PRELOAD=/usr/lib/librumphijack.so \
     46  1.1  pooka 	    /usr/libexec/httpd -b -s $(atf_get_srcdir)
     47  1.1  pooka 
     48  1.1  pooka 	atf_check -s exit:0 -o file:"$(atf_get_srcdir)/netstat.expout" \
     49  1.1  pooka 	    rump.netstat -a
     50  1.1  pooka 
     51  1.1  pooka 	# get the webpage
     52  1.1  pooka 	atf_check -s exit:0 env LD_PRELOAD=/usr/lib/librumphijack.so 	\
     53  1.1  pooka 	    $(atf_get_srcdir)/h_netget 127.0.0.1 80 webfile
     54  1.1  pooka 
     55  1.1  pooka 	# check that we got what we wanted
     56  1.1  pooka 	atf_check -o match:'HTTP/1.0 200 OK' cat webfile
     57  1.1  pooka 	atf_check -o match:'Content-Length: 95' cat webfile
     58  1.1  pooka 	atf_check -o file:"$(atf_get_srcdir)/index.html" \
     59  1.1  pooka 	    sed -n '1,/^
$/!p' webfile
     61  1.1  pooka }
     62  1.1  pooka 
     63  1.1  pooka http_cleanup()
     64  1.1  pooka {
     65  1.1  pooka 	rump.halt
     66  1.1  pooka }
     67  1.2  pooka 
     68  1.2  pooka #
     69  1.2  pooka # Starts a SSH server and sets up the client to access it.
     70  1.2  pooka # Authentication is allowed and done using an RSA key exclusively, which
     71  1.2  pooka # is generated on the fly as part of the test case.
     72  1.2  pooka # XXX: Ideally, all the tests in this test program should be able to share
     73  1.2  pooka # the generated key, because creating it can be a very slow process on some
     74  1.2  pooka # machines.
     75  1.2  pooka #
     76  1.2  pooka # XXX2: copypasted from jmmv's sshd thingamob in the psshfs test.
     77  1.2  pooka # ideally code (and keys, like jmmv notes above) could be shared
     78  1.2  pooka #
     79  1.2  pooka start_sshd() {
     80  1.2  pooka 	echo "Setting up SSH server configuration"
     81  1.2  pooka 	sed -e "s,@SRCDIR@,$(atf_get_srcdir),g" -e "s,@WORKDIR@,$(pwd),g" \
     82  1.2  pooka 	    $(atf_get_srcdir)/sshd_config.in >sshd_config || \
     83  1.2  pooka 	    atf_fail "Failed to create sshd_config"
     84  1.2  pooka 	atf_check -s ignore -o empty -e ignore \
     85  1.2  pooka 	    cp $(atf_get_srcdir)/ssh_host_key .
     86  1.2  pooka 	atf_check -s ignore -o empty -e ignore \
     87  1.2  pooka 	    cp $(atf_get_srcdir)/ssh_host_key.pub .
     88  1.2  pooka 	atf_check -s eq:0 -o empty -e empty chmod 400 ssh_host_key
     89  1.2  pooka 	atf_check -s eq:0 -o empty -e empty chmod 444 ssh_host_key.pub
     90  1.2  pooka 
     91  1.2  pooka         env LD_PRELOAD=/usr/lib/librumphijack.so \
     92  1.2  pooka 	    /usr/sbin/sshd -e -f ./sshd_config
     93  1.2  pooka 	while [ ! -f sshd.pid ]; do
     94  1.2  pooka 		sleep 0.01
     95  1.2  pooka 	done
     96  1.2  pooka 	echo "SSH server started (pid $(cat sshd.pid))"
     97  1.2  pooka 
     98  1.2  pooka 	echo "Setting up SSH client configuration"
     99  1.2  pooka 	atf_check -s eq:0 -o empty -e empty \
    100  1.2  pooka 	    ssh-keygen -f ssh_user_key -t rsa -b 1024 -N "" -q
    101  1.2  pooka 	atf_check -s eq:0 -o empty -e empty \
    102  1.2  pooka 	    cp ssh_user_key.pub authorized_keys
    103  1.2  pooka 	echo "127.0.0.1,localhost,::1 " \
    104  1.2  pooka 	    "$(cat $(atf_get_srcdir)/ssh_host_key.pub)" >known_hosts || \
    105  1.2  pooka 	    atf_fail "Failed to create known_hosts"
    106  1.2  pooka 	atf_check -s eq:0 -o empty -e empty chmod 600 authorized_keys
    107  1.2  pooka 	sed -e "s,@SRCDIR@,$(atf_get_srcdir),g" -e "s,@WORKDIR@,$(pwd),g" \
    108  1.2  pooka 	    $(atf_get_srcdir)/ssh_config.in >ssh_config || \
    109  1.2  pooka 	    atf_fail "Failed to create ssh_config"
    110  1.2  pooka 	
    111  1.2  pooka 	echo "sshd running"
    112  1.2  pooka }
    113  1.2  pooka 
    114  1.2  pooka atf_test_case ssh cleanup
    115  1.2  pooka ssh_head()
    116  1.2  pooka {
    117  1.2  pooka         atf_set "descr" "Test that hijacked ssh/sshd works"
    118  1.2  pooka }
    119  1.2  pooka 
    120  1.2  pooka ssh_body()
    121  1.2  pooka {
    122  1.2  pooka 
    123  1.2  pooka 	atf_check -s exit:0 ${rumpnetsrv} ${RUMP_SERVER}
    124  1.5  pooka 	# make sure clients die after we nuke the server
    125  1.2  pooka 	export RUMPHIJACK_RETRYCONNECT='die'
    126  1.2  pooka 
    127  1.2  pooka 	start_sshd
    128  1.2  pooka 
    129  1.2  pooka 	# create some sort of directory for us to "ls"
    130  1.2  pooka 	mkdir testdir
    131  1.2  pooka 	cd testdir
    132  1.2  pooka 	jot 11 | xargs touch
    133  1.2  pooka 	jot 11 12 | xargs mkdir
    134  1.2  pooka 	cd ..
    135  1.2  pooka 
    136  1.2  pooka 	atf_check -s exit:0 -o save:ssh.out				\
    137  1.4  pooka 	    env LD_PRELOAD=/usr/lib/librumphijack.so			\
    138  1.4  pooka 	    ssh -T -F ssh_config 127.0.0.1 env BLOCKSIZE=512		\
    139  1.4  pooka 	    ls -li $(pwd)/testdir
    140  1.4  pooka 	atf_check -s exit:0 -o file:ssh.out env BLOCKSIZE=512 		\
    141  1.2  pooka 	    ls -li $(pwd)/testdir
    142  1.2  pooka }
    143  1.2  pooka 
    144  1.2  pooka ssh_cleanup()
    145  1.2  pooka {
    146  1.5  pooka 	rump.halt
    147  1.2  pooka 	# sshd dies due to RUMPHIJACK_RETRYCONNECT=1d6
    148  1.2  pooka }
    149  1.1  pooka 
    150  1.1  pooka atf_init_test_cases()
    151  1.1  pooka {
    152  1.2  pooka 	atf_add_test_case http
    153  1.1  pooka 	atf_add_test_case ssh
    154             }
    155