Harald Hoyer 9d5d75
From ca8f1c1ba3e5f1ebfb2e5e70ea4d4b7a791b0bc2 Mon Sep 17 00:00:00 2001
Harald Hoyer 9d5d75
From: Harald Hoyer <harald@redhat.com>
Harald Hoyer 9d5d75
Date: Tue, 14 Aug 2018 13:58:21 +0200
Harald Hoyer 9d5d75
Subject: [PATCH] test: fixed KVERSION and qemu backwards compatiblity
Harald Hoyer 9d5d75
Harald Hoyer 9d5d75
---
Harald Hoyer 9d5d75
 test/TEST-50-MULTINIC/test.sh           | 137 ++++++++++++++++++--------------
Harald Hoyer 9d5d75
 test/TEST-70-BONDBRIDGETEAMVLAN/test.sh |  52 ++++++++----
Harald Hoyer 9d5d75
 2 files changed, 115 insertions(+), 74 deletions(-)
Harald Hoyer 9d5d75
Harald Hoyer 9d5d75
diff --git a/test/TEST-50-MULTINIC/test.sh b/test/TEST-50-MULTINIC/test.sh
Harald Hoyer 9d5d75
index 2640c318..02443c40 100755
Harald Hoyer 9d5d75
--- a/test/TEST-50-MULTINIC/test.sh
Harald Hoyer 9d5d75
+++ b/test/TEST-50-MULTINIC/test.sh
Harald Hoyer 9d5d75
@@ -12,19 +12,36 @@ run_server() {
Harald Hoyer 9d5d75
     echo "MULTINIC TEST SETUP: Starting DHCP/NFS server"
Harald Hoyer 9d5d75
 
Harald Hoyer 9d5d75
     fsck -a "$TESTDIR"/server.ext3 || return 1
Harald Hoyer 9d5d75
-    $testdir/run-qemu \
Harald Hoyer 9d5d75
-        -drive format=raw,index=0,media=disk,file="$TESTDIR"/server.ext3 \
Harald Hoyer 9d5d75
-        -m 512M  -smp 2 \
Harald Hoyer 9d5d75
-        -display none \
Harald Hoyer 9d5d75
-        -net socket,listen=127.0.0.1:12350 \
Harald Hoyer 9d5d75
-        -net nic,macaddr=52:54:01:12:34:56,model=e1000 \
Harald Hoyer 9d5d75
-        ${SERIAL:+-serial "$SERIAL"} \
Harald Hoyer 9d5d75
-        ${SERIAL:--serial file:"$TESTDIR"/server.log} \
Harald Hoyer 9d5d75
-        -watchdog i6300esb -watchdog-action poweroff \
Harald Hoyer 9d5d75
-        -no-reboot \
Harald Hoyer 9d5d75
-        -append "panic=1 loglevel=7 root=/dev/sda rootfstype=ext3 rw console=ttyS0,115200n81 selinux=0" \
Harald Hoyer 9d5d75
-        -initrd "$TESTDIR"/initramfs.server \
Harald Hoyer 9d5d75
-        -pidfile "$TESTDIR"/server.pid -daemonize || return 1
Harald Hoyer 9d5d75
+
Harald Hoyer 9d5d75
+    if $testdir/run-qemu --help | grep -qF -m1 'netdev hubport,id=str,hubid=n[,netdev=nd]' && echo OK; then
Harald Hoyer 9d5d75
+        $testdir/run-qemu \
Harald Hoyer 9d5d75
+            -drive format=raw,index=0,media=disk,file="$TESTDIR"/server.ext3 \
Harald Hoyer 9d5d75
+            -m 512M  -smp 2 \
Harald Hoyer 9d5d75
+            -display none \
Harald Hoyer 9d5d75
+            -net socket,listen=127.0.0.1:12350 \
Harald Hoyer 9d5d75
+            -net nic,macaddr=52:54:01:12:34:56,model=e1000 \
Harald Hoyer 9d5d75
+            ${SERIAL:+-serial "$SERIAL"} \
Harald Hoyer 9d5d75
+            ${SERIAL:--serial file:"$TESTDIR"/server.log} \
Harald Hoyer 9d5d75
+            -watchdog i6300esb -watchdog-action poweroff \
Harald Hoyer 9d5d75
+            -no-reboot \
Harald Hoyer 9d5d75
+            -append "panic=1 loglevel=7 root=/dev/sda rootfstype=ext3 rw console=ttyS0,115200n81 selinux=0" \
Harald Hoyer 9d5d75
+            -initrd "$TESTDIR"/initramfs.server \
Harald Hoyer 9d5d75
+            -pidfile "$TESTDIR"/server.pid -daemonize || return 1
Harald Hoyer 9d5d75
+    else
Harald Hoyer 9d5d75
+        $testdir/run-qemu \
Harald Hoyer 9d5d75
+            -drive format=raw,index=0,media=disk,file="$TESTDIR"/client.img -m 512M  -smp 2 -nographic \
Harald Hoyer 9d5d75
+            -net socket,vlan=0,connect=127.0.0.1:12350 \
Harald Hoyer 9d5d75
+            -net nic,vlan=0,macaddr=52:54:00:12:34:$mac1,model=e1000 \
Harald Hoyer 9d5d75
+            -net nic,vlan=0,macaddr=52:54:00:12:34:$mac2,model=e1000 \
Harald Hoyer 9d5d75
+            -net nic,vlan=0,macaddr=52:54:00:12:34:$mac3,model=e1000 \
Harald Hoyer 9d5d75
+            -net nic,vlan=1,macaddr=52:54:00:12:34:98,model=e1000 \
Harald Hoyer 9d5d75
+            -net nic,vlan=2,macaddr=52:54:00:12:34:99,model=e1000 \
Harald Hoyer 9d5d75
+            -watchdog i6300esb -watchdog-action poweroff \
Harald Hoyer 9d5d75
+            -no-reboot \
Harald Hoyer 9d5d75
+            -append "panic=1 rd.shell=0 $cmdline $DEBUGFAIL rd.retry=5 ro console=ttyS0,115200n81 selinux=0 init=/sbin/init rd.debug systemd.log_target=console loglevel=7" \
Harald Hoyer 9d5d75
+            -initrd "$TESTDIR"/initramfs.testing
Harald Hoyer 9d5d75
+    fi
Harald Hoyer 9d5d75
+
Harald Hoyer 9d5d75
     sudo chmod 644 -- "$TESTDIR"/server.pid || return 1
Harald Hoyer 9d5d75
 
Harald Hoyer 9d5d75
     # Cleanup the terminal if we have one
Harald Hoyer 9d5d75
@@ -51,18 +68,18 @@ client_test() {
Harald Hoyer 9d5d75
     fi
Harald Hoyer 9d5d75
 
Harald Hoyer 9d5d75
     $testdir/run-qemu -drive format=raw,index=0,media=disk,file="$TESTDIR"/client.img -m 512M  -smp 2 -nographic \
Harald Hoyer 9d5d75
-      -net socket,connect=127.0.0.1:12350 \
Harald Hoyer 9d5d75
-      -net nic,macaddr=52:54:00:12:34:$mac1,model=e1000 \
Harald Hoyer 9d5d75
-      -net nic,macaddr=52:54:00:12:34:$mac2,model=e1000 \
Harald Hoyer 9d5d75
-      -net nic,macaddr=52:54:00:12:34:$mac3,model=e1000 \
Harald Hoyer 9d5d75
-      -netdev hubport,id=n1,hubid=1 \
Harald Hoyer 9d5d75
-      -netdev hubport,id=n2,hubid=2 \
Harald Hoyer 9d5d75
-      -device e1000,netdev=n1,mac=52:54:00:12:34:98 \
Harald Hoyer 9d5d75
-      -device e1000,netdev=n2,mac=52:54:00:12:34:99 \
Harald Hoyer 9d5d75
-      -watchdog i6300esb -watchdog-action poweroff \
Harald Hoyer 9d5d75
-      -no-reboot \
Harald Hoyer 9d5d75
-      -append "panic=1 rd.shell=0 $cmdline $DEBUGFAIL rd.retry=5 ro console=ttyS0,115200n81 selinux=0 init=/sbin/init rd.debug systemd.log_target=console loglevel=7" \
Harald Hoyer 9d5d75
-        -initrd "$TESTDIR"/initramfs.testing
Harald Hoyer 9d5d75
+                      -net socket,connect=127.0.0.1:12350 \
Harald Hoyer 9d5d75
+                      -net nic,macaddr=52:54:00:12:34:$mac1,model=e1000 \
Harald Hoyer 9d5d75
+                      -net nic,macaddr=52:54:00:12:34:$mac2,model=e1000 \
Harald Hoyer 9d5d75
+                      -net nic,macaddr=52:54:00:12:34:$mac3,model=e1000 \
Harald Hoyer 9d5d75
+                      -netdev hubport,id=n1,hubid=1 \
Harald Hoyer 9d5d75
+                      -netdev hubport,id=n2,hubid=2 \
Harald Hoyer 9d5d75
+                      -device e1000,netdev=n1,mac=52:54:00:12:34:98 \
Harald Hoyer 9d5d75
+                      -device e1000,netdev=n2,mac=52:54:00:12:34:99 \
Harald Hoyer 9d5d75
+                      -watchdog i6300esb -watchdog-action poweroff \
Harald Hoyer 9d5d75
+                      -no-reboot \
Harald Hoyer 9d5d75
+                      -append "panic=1 rd.shell=0 $cmdline $DEBUGFAIL rd.retry=5 ro console=ttyS0,115200n81 selinux=0 init=/sbin/init rd.debug systemd.log_target=console loglevel=7" \
Harald Hoyer 9d5d75
+                      -initrd "$TESTDIR"/initramfs.testing
Harald Hoyer 9d5d75
 
Harald Hoyer 9d5d75
     { read OK; read IFACES; } < "$TESTDIR"/client.img
Harald Hoyer 9d5d75
 
Harald Hoyer 9d5d75
@@ -110,58 +127,58 @@ test_client() {
Harald Hoyer 9d5d75
 
Harald Hoyer 9d5d75
     # PXE Style BOOTIF=
Harald Hoyer 9d5d75
     client_test "MULTINIC root=nfs BOOTIF=" \
Harald Hoyer 9d5d75
-        00 01 02 \
Harald Hoyer 9d5d75
-        "root=nfs:192.168.50.1:/nfs/client BOOTIF=52-54-00-12-34-00" \
Harald Hoyer 9d5d75
-        "ens3" || return 1
Harald Hoyer 9d5d75
+                00 01 02 \
Harald Hoyer 9d5d75
+                "root=nfs:192.168.50.1:/nfs/client BOOTIF=52-54-00-12-34-00" \
Harald Hoyer 9d5d75
+                "ens3" || return 1
Harald Hoyer 9d5d75
 
Harald Hoyer 9d5d75
     client_test "MULTINIC root=nfs BOOTIF= ip=ens4:dhcp" \
Harald Hoyer 9d5d75
-        00 01 02 \
Harald Hoyer 9d5d75
-        "root=nfs:192.168.50.1:/nfs/client BOOTIF=52-54-00-12-34-00 ip=ens4:dhcp" \
Harald Hoyer 9d5d75
-        "ens3 ens4" || return 1
Harald Hoyer 9d5d75
+                00 01 02 \
Harald Hoyer 9d5d75
+                "root=nfs:192.168.50.1:/nfs/client BOOTIF=52-54-00-12-34-00 ip=ens4:dhcp" \
Harald Hoyer 9d5d75
+                "ens3 ens4" || return 1
Harald Hoyer 9d5d75
 
Harald Hoyer 9d5d75
     # PXE Style BOOTIF= with dhcp root-path
Harald Hoyer 9d5d75
     client_test "MULTINIC root=dhcp BOOTIF=" \
Harald Hoyer 9d5d75
-        00 01 02 \
Harald Hoyer 9d5d75
-        "root=dhcp BOOTIF=52-54-00-12-34-02" \
Harald Hoyer 9d5d75
-        "ens5" || return 1
Harald Hoyer 9d5d75
+                00 01 02 \
Harald Hoyer 9d5d75
+                "root=dhcp BOOTIF=52-54-00-12-34-02" \
Harald Hoyer 9d5d75
+                "ens5" || return 1
Harald Hoyer 9d5d75
 
Harald Hoyer 9d5d75
     # Multinic case, where only one nic works
Harald Hoyer 9d5d75
     client_test "MULTINIC root=nfs ip=dhcp" \
Harald Hoyer 9d5d75
-        FF 00 FE \
Harald Hoyer 9d5d75
-        "root=nfs:192.168.50.1:/nfs/client ip=dhcp" \
Harald Hoyer 9d5d75
-        "ens4" || return 1
Harald Hoyer 9d5d75
+                FF 00 FE \
Harald Hoyer 9d5d75
+                "root=nfs:192.168.50.1:/nfs/client ip=dhcp" \
Harald Hoyer 9d5d75
+                "ens4" || return 1
Harald Hoyer 9d5d75
 
Harald Hoyer 9d5d75
     # Require two interfaces
Harald Hoyer 9d5d75
     client_test "MULTINIC root=nfs ip=ens4:dhcp ip=ens5:dhcp bootdev=ens4" \
Harald Hoyer 9d5d75
-        00 01 02 \
Harald Hoyer 9d5d75
-        "root=nfs:192.168.50.1:/nfs/client ip=ens4:dhcp ip=ens5:dhcp bootdev=ens4" \
Harald Hoyer 9d5d75
-        "ens4 ens5" || return 1
Harald Hoyer 9d5d75
+                00 01 02 \
Harald Hoyer 9d5d75
+                "root=nfs:192.168.50.1:/nfs/client ip=ens4:dhcp ip=ens5:dhcp bootdev=ens4" \
Harald Hoyer 9d5d75
+                "ens4 ens5" || return 1
Harald Hoyer 9d5d75
 
Harald Hoyer 9d5d75
     # Require three interfaces with dhcp root-path
Harald Hoyer 9d5d75
     client_test "MULTINIC root=dhcp ip=ens3:dhcp ip=ens4:dhcp ip=ens5:dhcp bootdev=ens5" \
Harald Hoyer 9d5d75
-        00 01 02 \
Harald Hoyer 9d5d75
-        "root=dhcp ip=ens3:dhcp ip=ens4:dhcp ip=ens5:dhcp bootdev=ens5" \
Harald Hoyer 9d5d75
-        "ens3 ens4 ens5" || return 1
Harald Hoyer 9d5d75
+                00 01 02 \
Harald Hoyer 9d5d75
+                "root=dhcp ip=ens3:dhcp ip=ens4:dhcp ip=ens5:dhcp bootdev=ens5" \
Harald Hoyer 9d5d75
+                "ens3 ens4 ens5" || return 1
Harald Hoyer 9d5d75
 
Harald Hoyer 9d5d75
     client_test "MULTINIC bonding" \
Harald Hoyer 9d5d75
-        00 01 02 \
Harald Hoyer 9d5d75
-        "root=nfs:192.168.50.1:/nfs/client ip=bond0:dhcp  bond=bond0:ens3,ens4,ens5:mode=balance-rr" \
Harald Hoyer 9d5d75
-        "bond0" || return 1
Harald Hoyer 9d5d75
+                00 01 02 \
Harald Hoyer 9d5d75
+                "root=nfs:192.168.50.1:/nfs/client ip=bond0:dhcp  bond=bond0:ens3,ens4,ens5:mode=balance-rr" \
Harald Hoyer 9d5d75
+                "bond0" || return 1
Harald Hoyer 9d5d75
 
Harald Hoyer 9d5d75
     client_test "MULTINIC bridging" \
Harald Hoyer 9d5d75
-        00 01 02 \
Harald Hoyer 9d5d75
-        "root=nfs:192.168.50.1:/nfs/client ip=bridge0:dhcp  bridge=bridge0:ens3,ens6,ens7" \
Harald Hoyer 9d5d75
-        "bridge0" || return 1
Harald Hoyer 9d5d75
+                00 01 02 \
Harald Hoyer 9d5d75
+                "root=nfs:192.168.50.1:/nfs/client ip=bridge0:dhcp  bridge=bridge0:ens3,ens6,ens7" \
Harald Hoyer 9d5d75
+                "bridge0" || return 1
Harald Hoyer 9d5d75
     return 0
Harald Hoyer 9d5d75
 }
Harald Hoyer 9d5d75
 
Harald Hoyer 9d5d75
 test_setup() {
Harald Hoyer 9d5d75
-     # Make server root
Harald Hoyer 9d5d75
+    # Make server root
Harald Hoyer 9d5d75
     dd if=/dev/null of="$TESTDIR"/server.ext3 bs=1M seek=120
Harald Hoyer 9d5d75
     mke2fs -j -F -- "$TESTDIR"/server.ext3
Harald Hoyer 9d5d75
     mkdir -- "$TESTDIR"/mnt
Harald Hoyer 9d5d75
     sudo mount -o loop -- "$TESTDIR"/server.ext3 "$TESTDIR"/mnt
Harald Hoyer 9d5d75
-
Harald Hoyer 9d5d75
+    kernel=$KVERSION
Harald Hoyer 9d5d75
     (
Harald Hoyer 9d5d75
         export initdir="$TESTDIR"/mnt
Harald Hoyer 9d5d75
         . "$basedir"/dracut-init.sh
Harald Hoyer 9d5d75
@@ -185,9 +202,9 @@ test_setup() {
Harald Hoyer 9d5d75
         done
Harald Hoyer 9d5d75
 
Harald Hoyer 9d5d75
         inst_multiple sh ls shutdown poweroff stty cat ps ln ip \
Harald Hoyer 9d5d75
-            dmesg mkdir cp ping exportfs \
Harald Hoyer 9d5d75
-            modprobe rpc.nfsd rpc.mountd showmount tcpdump \
Harald Hoyer 9d5d75
-            /etc/services sleep mount chmod
Harald Hoyer 9d5d75
+                      dmesg mkdir cp ping exportfs \
Harald Hoyer 9d5d75
+                      modprobe rpc.nfsd rpc.mountd showmount tcpdump \
Harald Hoyer 9d5d75
+                      /etc/services sleep mount chmod
Harald Hoyer 9d5d75
         for _terminfodir in /lib/terminfo /etc/terminfo /usr/share/terminfo; do
Harald Hoyer 9d5d75
             [ -f "${_terminfodir}"/l/linux ] && break
Harald Hoyer 9d5d75
         done
Harald Hoyer 9d5d75
@@ -212,7 +229,7 @@ test_setup() {
Harald Hoyer 9d5d75
         inst_libdir_file 'libnfsidmap*.so*'
Harald Hoyer 9d5d75
 
Harald Hoyer 9d5d75
         _nsslibs=$(sed -e '/^#/d' -e 's/^.*://' -e 's/\[NOTFOUND=return\]//' /etc/nsswitch.conf \
Harald Hoyer 9d5d75
-            |  tr -s '[:space:]' '\n' | sort -u | tr -s '[:space:]' '|')
Harald Hoyer 9d5d75
+                       |  tr -s '[:space:]' '\n' | sort -u | tr -s '[:space:]' '|')
Harald Hoyer 9d5d75
         _nsslibs=${_nsslibs#|}
Harald Hoyer 9d5d75
         _nsslibs=${_nsslibs%|}
Harald Hoyer 9d5d75
 
Harald Hoyer 9d5d75
@@ -241,7 +258,7 @@ test_setup() {
Harald Hoyer 9d5d75
             done
Harald Hoyer 9d5d75
         )
Harald Hoyer 9d5d75
         inst_multiple sh shutdown poweroff stty cat ps ln ip \
Harald Hoyer 9d5d75
-            mount dmesg mkdir cp ping grep ls
Harald Hoyer 9d5d75
+                      mount dmesg mkdir cp ping grep ls
Harald Hoyer 9d5d75
         for _terminfodir in /lib/terminfo /etc/terminfo /usr/share/terminfo; do
Harald Hoyer 9d5d75
             [[ -f ${_terminfodir}/l/linux ]] && break
Harald Hoyer 9d5d75
         done
Harald Hoyer 9d5d75
@@ -258,7 +275,7 @@ test_setup() {
Harald Hoyer 9d5d75
         inst_libdir_file 'libnfsidmap*.so*'
Harald Hoyer 9d5d75
 
Harald Hoyer 9d5d75
         _nsslibs=$(sed -e '/^#/d' -e 's/^.*://' -e 's/\[NOTFOUND=return\]//' -- /etc/nsswitch.conf \
Harald Hoyer 9d5d75
-            |  tr -s '[:space:]' '\n' | sort -u | tr -s '[:space:]' '|')
Harald Hoyer 9d5d75
+                       |  tr -s '[:space:]' '\n' | sort -u | tr -s '[:space:]' '|')
Harald Hoyer 9d5d75
         _nsslibs=${_nsslibs#|}
Harald Hoyer 9d5d75
         _nsslibs=${_nsslibs%|}
Harald Hoyer 9d5d75
 
Harald Hoyer 9d5d75
@@ -282,14 +299,16 @@ test_setup() {
Harald Hoyer 9d5d75
     )
Harald Hoyer 9d5d75
 
Harald Hoyer 9d5d75
     # Make server's dracut image
Harald Hoyer 9d5d75
-    $basedir/dracut.sh -l -i "$TESTDIR"/overlay / \
Harald Hoyer 9d5d75
+    $basedir/dracut.sh \
Harald Hoyer 9d5d75
+        -l -i "$TESTDIR"/overlay / \
Harald Hoyer 9d5d75
         -m "dash udev-rules base rootfs-block fs-lib debug kernel-modules watchdog" \
Harald Hoyer 9d5d75
         -d "af_packet piix ide-gd_mod ata_piix ext3 sd_mod nfsv2 nfsv3 nfsv4 nfs_acl nfs_layout_nfsv41_files nfsd e1000 i6300esb ib700wdt" \
Harald Hoyer 9d5d75
         --no-hostonly-cmdline -N \
Harald Hoyer 9d5d75
         -f "$TESTDIR"/initramfs.server "$KVERSION" || return 1
Harald Hoyer 9d5d75
 
Harald Hoyer 9d5d75
     # Make client's dracut image
Harald Hoyer 9d5d75
-    $basedir/dracut.sh -l -i "$TESTDIR"/overlay / \
Harald Hoyer 9d5d75
+    $basedir/dracut.sh \
Harald Hoyer 9d5d75
+        -l -i "$TESTDIR"/overlay / \
Harald Hoyer 9d5d75
         -o "plymouth" \
Harald Hoyer 9d5d75
         -a "debug" \
Harald Hoyer 9d5d75
         -d "af_packet piix sd_mod sr_mod ata_piix ide-gd_mod e1000 nfsv2 nfsv3 nfsv4 nfs_acl nfs_layout_nfsv41_files sunrpc i6300esb ib700wdt" \
Harald Hoyer 9d5d75
diff --git a/test/TEST-70-BONDBRIDGETEAMVLAN/test.sh b/test/TEST-70-BONDBRIDGETEAMVLAN/test.sh
Harald Hoyer 9d5d75
index eadf09f1..8c11a7d3 100755
Harald Hoyer 9d5d75
--- a/test/TEST-70-BONDBRIDGETEAMVLAN/test.sh
Harald Hoyer 9d5d75
+++ b/test/TEST-70-BONDBRIDGETEAMVLAN/test.sh
Harald Hoyer 9d5d75
@@ -14,6 +14,7 @@ run_server() {
Harald Hoyer 9d5d75
     echo "MULTINIC TEST SETUP: Starting DHCP/NFS server"
Harald Hoyer 9d5d75
 
Harald Hoyer 9d5d75
     fsck -a "$TESTDIR"/server.ext3 || return 1
Harald Hoyer 9d5d75
+
Harald Hoyer 9d5d75
     $testdir/run-qemu \
Harald Hoyer 9d5d75
         -hda "$TESTDIR"/server.ext3 \
Harald Hoyer 9d5d75
         -m 512M -smp 2 \
Harald Hoyer 9d5d75
@@ -66,17 +67,38 @@ client_test() {
Harald Hoyer 9d5d75
         nic3=" -netdev hubport,id=n3,hubid=3"
Harald Hoyer 9d5d75
     fi
Harald Hoyer 9d5d75
 
Harald Hoyer 9d5d75
-    $testdir/run-qemu -hda "$TESTDIR"/client.img -m 512M -smp 2 -nographic \
Harald Hoyer 9d5d75
-        -netdev socket,connect=127.0.0.1:12370,id=s1 -netdev hubport,hubid=1,id=h1,netdev=s1 \
Harald Hoyer 9d5d75
-        -netdev hubport,hubid=1,id=h2 -device e1000,mac=52:54:00:12:34:01,netdev=h2 \
Harald Hoyer 9d5d75
-        -netdev hubport,hubid=1,id=h3 -device e1000,mac=52:54:00:12:34:02,netdev=h3 \
Harald Hoyer 9d5d75
-        $nic1 -device e1000,mac=52:54:00:12:34:03,netdev=n1  \
Harald Hoyer 9d5d75
-        -netdev socket,connect=127.0.0.1:12372,id=n2 -device e1000,mac=52:54:00:12:34:04,netdev=n2 \
Harald Hoyer 9d5d75
-        $nic3 -device e1000,mac=52:54:00:12:34:05,netdev=n3 \
Harald Hoyer 9d5d75
-        -watchdog i6300esb -watchdog-action poweroff \
Harald Hoyer 9d5d75
-        -no-reboot \
Harald Hoyer 9d5d75
-        -append "panic=1 $cmdline rd.debug $DEBUGFAIL rd.retry=5 rw console=ttyS0,115200n81 selinux=0 init=/sbin/init" \
Harald Hoyer 9d5d75
-        -initrd "$TESTDIR"/initramfs.testing
Harald Hoyer 9d5d75
+    if $testdir/run-qemu --help | grep -qF -m1 'netdev hubport,id=str,hubid=n[,netdev=nd]' && echo OK; then
Harald Hoyer 9d5d75
+        $testdir/run-qemu \
Harald Hoyer 9d5d75
+            -hda "$TESTDIR"/client.img -m 512M -smp 2 -nographic \
Harald Hoyer 9d5d75
+            -netdev socket,connect=127.0.0.1:12370,id=s1 \
Harald Hoyer 9d5d75
+            -netdev hubport,hubid=1,id=h1,netdev=s1 \
Harald Hoyer 9d5d75
+            -netdev hubport,hubid=1,id=h2 -device e1000,mac=52:54:00:12:34:01,netdev=h2 \
Harald Hoyer 9d5d75
+            -netdev hubport,hubid=1,id=h3 -device e1000,mac=52:54:00:12:34:02,netdev=h3 \
Harald Hoyer 9d5d75
+            $nic1 -device e1000,mac=52:54:00:12:34:03,netdev=n1  \
Harald Hoyer 9d5d75
+            -netdev socket,connect=127.0.0.1:12372,id=n2 -device e1000,mac=52:54:00:12:34:04,netdev=n2 \
Harald Hoyer 9d5d75
+            $nic3 -device e1000,mac=52:54:00:12:34:05,netdev=n3 \
Harald Hoyer 9d5d75
+            -watchdog i6300esb -watchdog-action poweroff \
Harald Hoyer 9d5d75
+            -no-reboot \
Harald Hoyer 9d5d75
+            -append "panic=1 $cmdline rd.debug $DEBUGFAIL rd.retry=5 rw console=ttyS0,115200n81 selinux=0 init=/sbin/init" \
Harald Hoyer 9d5d75
+            -initrd "$TESTDIR"/initramfs.testing
Harald Hoyer 9d5d75
+    else
Harald Hoyer 9d5d75
+        $testdir/run-qemu \
Harald Hoyer 9d5d75
+            -hda "$TESTDIR"/client.img -m 512M -smp 2 -nographic \
Harald Hoyer 9d5d75
+            -net socket,vlan=0,connect=127.0.0.1:12370 \
Harald Hoyer 9d5d75
+            ${do_vlan13:+-net socket,vlan=1,connect=127.0.0.1:12371} \
Harald Hoyer 9d5d75
+            -net socket,vlan=2,connect=127.0.0.1:12372 \
Harald Hoyer 9d5d75
+            ${do_vlan13:+-net socket,vlan=3,connect=127.0.0.1:12373} \
Harald Hoyer 9d5d75
+            -net nic,vlan=0,macaddr=52:54:00:12:34:01,model=e1000 \
Harald Hoyer 9d5d75
+            -net nic,vlan=0,macaddr=52:54:00:12:34:02,model=e1000 \
Harald Hoyer 9d5d75
+            -net nic,vlan=1,macaddr=52:54:00:12:34:03,model=e1000 \
Harald Hoyer 9d5d75
+            -net nic,vlan=2,macaddr=52:54:00:12:34:04,model=e1000 \
Harald Hoyer 9d5d75
+            -net nic,vlan=3,macaddr=52:54:00:12:34:05,model=e1000 \
Harald Hoyer 9d5d75
+            -watchdog i6300esb -watchdog-action poweroff \
Harald Hoyer 9d5d75
+            -no-reboot \
Harald Hoyer 9d5d75
+            -append "panic=1 $cmdline rd.debug $DEBUGFAIL rd.retry=5 rw console=ttyS0,115200n81 selinux=0 init=/sbin/init" \
Harald Hoyer 9d5d75
+            -initrd "$TESTDIR"/initramfs.testing
Harald Hoyer 9d5d75
+    fi
Harald Hoyer 9d5d75
+
Harald Hoyer 9d5d75
     { 
Harald Hoyer 9d5d75
         read OK
Harald Hoyer 9d5d75
         if [[ "$OK" != "OK" ]]; then
Harald Hoyer 9d5d75
@@ -167,7 +189,7 @@ test_setup() {
Harald Hoyer 9d5d75
     mke2fs -j -F -- "$TESTDIR"/server.ext3
Harald Hoyer 9d5d75
     mkdir -- "$TESTDIR"/mnt
Harald Hoyer 9d5d75
     mount -o loop -- "$TESTDIR"/server.ext3 "$TESTDIR"/mnt
Harald Hoyer 9d5d75
-
Harald Hoyer 9d5d75
+    kernel=$KVERSION
Harald Hoyer 9d5d75
     (
Harald Hoyer 9d5d75
         export initdir="$TESTDIR"/mnt
Harald Hoyer 9d5d75
         . "$basedir"/dracut-init.sh
Harald Hoyer 9d5d75
@@ -203,7 +225,7 @@ test_setup() {
Harald Hoyer 9d5d75
         [ -f /etc/netconfig ] && inst_multiple /etc/netconfig
Harald Hoyer 9d5d75
         type -P dhcpd >/dev/null && inst_multiple dhcpd
Harald Hoyer 9d5d75
         [ -x /usr/sbin/dhcpd3 ] && inst /usr/sbin/dhcpd3 /usr/sbin/dhcpd
Harald Hoyer 9d5d75
-        instmods nfsd sunrpc ipv6 lockd af_packet 8021q
Harald Hoyer 9d5d75
+        instmods nfsd sunrpc ipv6 lockd af_packet 8021q ipvlan macvlan
Harald Hoyer 9d5d75
         inst_simple /etc/os-release
Harald Hoyer 9d5d75
         inst ./server-init.sh /sbin/init
Harald Hoyer 9d5d75
         inst ./hosts /etc/hosts
Harald Hoyer 9d5d75
@@ -286,7 +308,7 @@ test_setup() {
Harald Hoyer 9d5d75
     $basedir/dracut.sh -l -i "$TESTDIR"/overlay / \
Harald Hoyer 9d5d75
         --no-early-microcode \
Harald Hoyer 9d5d75
         -m "udev-rules base rootfs-block fs-lib debug kernel-modules watchdog" \
Harald Hoyer 9d5d75
-        -d "af_packet piix ide-gd_mod ata_piix ext3 sd_mod nfsv2 nfsv3 nfsv4 nfs_acl nfs_layout_nfsv41_files nfsd e1000 i6300esb ib700wdt" \
Harald Hoyer 9d5d75
+        -d "ipvlan macvlan af_packet piix ide-gd_mod ata_piix ext3 sd_mod nfsv2 nfsv3 nfsv4 nfs_acl nfs_layout_nfsv41_files nfsd e1000 i6300esb ib700wdt" \
Harald Hoyer 9d5d75
         --no-hostonly-cmdline -N \
Harald Hoyer 9d5d75
         -f "$TESTDIR"/initramfs.server "$KVERSION" || return 1
Harald Hoyer 9d5d75
 
Harald Hoyer 9d5d75
@@ -295,7 +317,7 @@ test_setup() {
Harald Hoyer 9d5d75
         --no-early-microcode \
Harald Hoyer 9d5d75
         -o "plymouth" \
Harald Hoyer 9d5d75
         -a "debug" \
Harald Hoyer 9d5d75
-        -d "af_packet piix sd_mod sr_mod ata_piix ide-gd_mod e1000 nfsv2 nfsv3 nfsv4 nfs_acl nfs_layout_nfsv41_files sunrpc i6300esb ib700wdt" \
Harald Hoyer 9d5d75
+        -d "ipvlan macvlan af_packet piix sd_mod sr_mod ata_piix ide-gd_mod e1000 nfsv2 nfsv3 nfsv4 nfs_acl nfs_layout_nfsv41_files sunrpc i6300esb ib700wdt" \
Harald Hoyer 9d5d75
         --no-hostonly-cmdline -N \
Harald Hoyer 9d5d75
         -f "$TESTDIR"/initramfs.testing "$KVERSION" || return 1
Harald Hoyer 9d5d75
 }
Harald Hoyer 9d5d75