From cc75acdcab094a44bebf163bb6c197dfa939e309 Mon Sep 17 00:00:00 2001 From: David Dillow Date: Sat, 6 Jun 2009 00:25:07 -0400 Subject: [PATCH] NFS test: rearrange code to test multiple client configurations This also gets rid of BASENET, which was an unneeded idea in hindsight. --- test/TEST-20-NFS/server-init | 3 +- test/TEST-20-NFS/test.sh | 78 ++++++++++++++++++++++-------------- 2 files changed, 48 insertions(+), 33 deletions(-) diff --git a/test/TEST-20-NFS/server-init b/test/TEST-20-NFS/server-init index d3527f02..f9c822f8 100755 --- a/test/TEST-20-NFS/server-init +++ b/test/TEST-20-NFS/server-init @@ -3,11 +3,10 @@ export TERM=linux export PS1='nfstest-server:\w\$ ' stty sane echo "made it to the rootfs!" -. /etc/basenet echo server > /proc/sys/kernel/hostname ip addr add 127.0.0.1/8 dev lo ip link set lo up -ip addr add $BASENET.1/24 dev eth0 +ip addr add 192.168.50.1/24 dev eth0 ip link set eth0 up rpcbind modprobe nfsd diff --git a/test/TEST-20-NFS/test.sh b/test/TEST-20-NFS/test.sh index df6ec8f5..e641edfb 100755 --- a/test/TEST-20-NFS/test.sh +++ b/test/TEST-20-NFS/test.sh @@ -2,37 +2,60 @@ TEST_DESCRIPTION="root filesystem on NFS" KVERSION=${KVERSION-$(uname -r)} -BASENET=${BASENET-192.168.100} -test_run() { +run_server() { # Start server first + echo "NFS TEST SETUP: Starting DHCP/NFS server" + $testdir/run-qemu -hda server.ext2 -m 512M -nographic \ -net nic,macaddr=52:54:00:12:34:56,model=e1000 \ -net socket,mcast=230.0.0.1:1234 \ -serial udp:127.0.0.1:9999 \ -kernel /boot/vmlinuz-$KVERSION \ -append "root=/dev/sda rw quiet console=ttyS0,115200n81" \ - -initrd initramfs.server -pidfile server.pid -daemonize - sudo chmod 644 server.pid - - # Starting the server messes up the terminal, fix that - stty sane + -initrd initramfs.server -pidfile server.pid -daemonize || return 1 + sudo chmod 644 server.pid || return 1 echo Sleeping 10 seconds to give the server a head start sleep 10 +} + +client_test() { + local test_name="$1" + local mac=$2 + local cmdline="$3" + + echo "CLIENT TEST START: $test_name" + + # Need this so kvm-qemu will boot (needs non-/dev/zero local disk) + if ! dd if=/dev/zero of=client.img bs=1M count=1; then + echo "Unable to make client sda image" 1>&2 + return 1 + fi $testdir/run-qemu -hda client.img -m 512M -nographic \ - -net nic,macaddr=52:54:00:12:35:56,model=e1000 \ + -net nic,macaddr=$mac,model=e1000 \ -net socket,mcast=230.0.0.1:1234 \ -kernel /boot/vmlinuz-$KVERSION \ - -append "root=dhcp rw quiet console=ttyS0,115200n81" \ + -append "$cmdline rw quiet console=ttyS0,115200n81" \ -initrd initramfs.testing - if [[ -s server.pid ]]; then - sudo kill -TERM $(cat server.pid) - rm -f server.pid + if [[ $? -eq 0 ]] && grep -m 1 -q nfs-OK client.img; then + echo "CLIENT TEST END: $test_name [OK]" + return 0 + else + echo "CLIENT TEST END: $test_name [FAILED]" + return 1 + fi +} + +test_run() { + if ! run_server; then + echo "Failed to start server" 1>&2 + return 1 fi - grep -m 1 -q nfs-OK client.img || return 1 + + client_test "NFSv3 root=dhcp" 52:54:00:12:34:00 "root=dhcp" || return 1 } test_setup() { @@ -60,25 +83,21 @@ test_setup() { cat > etc/hosts < etc/dnsmasq.conf < etc/basenet < etc/exports <