test: Embed script for dhclient(8) in mbuto(1) profile
David reports that dhclient-script(8) on Fedora needs a number of binaries that are not included in PROGS of the current mbuto profile, and we would also need to include hostnamectl(1) there, which will fail without a systemd init. Embed a minimal script for dhclient(8) in the profile itself, written to /sbin/dhclient-script at boot, to just check what we need to check out of DHCP and DHCPv6 functionality. While at it, drop busybox and logger from PROGS, as we don't need them, and add hostname(1). While DHCP option 12 isn't supported yet by the DHCP implementation in passt, we should probably add it soon. Note: owing to the simplicity of this script, we now need to bring up the interface before starting dhclient: add this in test scripts where it's not the case yet. Reported-by: David Gibson <david@gibson.dropbear.id.au> Suggested-by: David Gibson <david@gibson.dropbear.id.au> Signed-off-by: Stefano Brivio <sbrivio@redhat.com> note that we need to bring up the interface before starting dhclient
This commit is contained in:
parent
27aec5911a
commit
4d777144fd
4 changed files with 26 additions and 10 deletions
|
@ -11,7 +11,7 @@
|
||||||
# Author: Stefano Brivio <sbrivio@redhat.com>
|
# Author: Stefano Brivio <sbrivio@redhat.com>
|
||||||
|
|
||||||
PROGS="${PROGS:-ash,dash,bash ip mount ls insmod mkdir ln cat chmod lsmod
|
PROGS="${PROGS:-ash,dash,bash ip mount ls insmod mkdir ln cat chmod lsmod
|
||||||
modprobe find grep mknod mv rm umount jq iperf3 dhclient busybox logger
|
modprobe find grep mknod mv rm umount jq iperf3 dhclient hostname
|
||||||
sed tr chown sipcalc cut md5sum nc dd strace ping tail killall sleep
|
sed tr chown sipcalc cut md5sum nc dd strace ping tail killall sleep
|
||||||
sysctl nproc tcp_rr tcp_crr udp_rr which tee seq bc}"
|
sysctl nproc tcp_rr tcp_crr udp_rr which tee seq bc}"
|
||||||
|
|
||||||
|
@ -22,15 +22,29 @@ LINKS="${LINKS:-
|
||||||
ash,dash,bash /bin/sh
|
ash,dash,bash /bin/sh
|
||||||
ash,dash,bash /usr/bin/bash}"
|
ash,dash,bash /usr/bin/bash}"
|
||||||
|
|
||||||
COPIES="${COPIES}
|
DIRS="${DIRS} /tmp /sbin"
|
||||||
/sbin/dhclient-script"
|
|
||||||
|
|
||||||
DIRS="${DIRS} /tmp"
|
FIXUP="${FIXUP}"'
|
||||||
|
cat > /sbin/dhclient-script << EOF
|
||||||
|
#!/bin/sh
|
||||||
|
[ -n "\${new_interface_mtu}" ] && ip link set dev \${interface} mtu \${new_interface_mtu}
|
||||||
|
|
||||||
FIXUP="${FIXUP}
|
[ -n "\${new_ip_address}" ] && ip addr add \${new_ip_address}/\${new_subnet_mask} dev \${interface}
|
||||||
|
[ -n "\${new_routers}" ] && for r in \${new_routers}; do ip route add default via \${r} dev \${interface}; done
|
||||||
|
[ -n "\${new_domain_name_servers}" ] && for d in \${new_domain_name_servers}; do echo "nameserver \${d}" >> /etc/resolv.conf; done
|
||||||
|
[ -n "\${new_domain_name}" ] && (printf "search"; for d in \${new_domain_name}; do printf " %s" "\${d}"; done; printf "\n") >> /etc/resolv.conf
|
||||||
|
|
||||||
|
[ -n "\${new_ip6_address}" ] && ip addr add \${new_ip6_address}/\${new_ip6_prefixlen} dev \${interface}
|
||||||
|
[ -n "\${new_dhcp6_name_servers}" ] && for d in \${new_dhcp6_name_servers}; do echo "nameserver \${d}%\${interface}" >> /etc/resolv.conf; done
|
||||||
|
[ -n "\${new_dhcp6_domain_search}" ] && (printf "search"; for d in \${new_dhcp6_domain_search}; do printf " %s" "\${d}"; done; printf "\n") >> /etc/resolv.conf
|
||||||
|
|
||||||
|
[ -n "\${new_host_name}" ] && hostname "\${new_host_name}"
|
||||||
|
exit 0
|
||||||
|
EOF
|
||||||
|
chmod 755 /sbin/dhclient-script
|
||||||
:> /etc/fstab
|
:> /etc/fstab
|
||||||
sh +m
|
sh +m
|
||||||
"
|
'
|
||||||
|
|
||||||
OUTPUT="KERNEL=__KERNEL__
|
OUTPUT="KERNEL=__KERNEL__
|
||||||
INITRD=__INITRD__
|
INITRD=__INITRD__
|
||||||
|
|
|
@ -18,7 +18,7 @@ htools bc head sed seq
|
||||||
|
|
||||||
# In this setup, virtio_net TX queue sometimes hangs, still under investigation
|
# In this setup, virtio_net TX queue sometimes hangs, still under investigation
|
||||||
def virtio_net_workaround
|
def virtio_net_workaround
|
||||||
guest modprobe -r virtio_net; modprobe virtio_net napi_tx=1; dhclient -4; dhclient -6; sleep 3
|
guest modprobe -r virtio_net; modprobe virtio_net napi_tx=1; ip link set dev eth0 up; dhclient -4; dhclient -6; sleep 3
|
||||||
endef
|
endef
|
||||||
|
|
||||||
test passt: throughput and latency
|
test passt: throughput and latency
|
||||||
|
|
|
@ -18,7 +18,7 @@ htools bc head sed
|
||||||
|
|
||||||
# In this setup, virtio_net TX queue sometimes hangs, still under investigation
|
# In this setup, virtio_net TX queue sometimes hangs, still under investigation
|
||||||
def virtio_net_workaround
|
def virtio_net_workaround
|
||||||
guest modprobe -r virtio_net; modprobe virtio_net napi_tx=1; dhclient -4; dhclient -6; sleep 3
|
guest modprobe -r virtio_net; modprobe virtio_net napi_tx=1; ip link set dev eth0 up; dhclient -4; dhclient -6; sleep 3
|
||||||
endef
|
endef
|
||||||
|
|
||||||
test passt: throughput and latency
|
test passt: throughput and latency
|
||||||
|
|
|
@ -23,8 +23,10 @@ check [ -n "__IFNAME1__" ]
|
||||||
check [ -n "__IFNAME2__" ]
|
check [ -n "__IFNAME2__" ]
|
||||||
|
|
||||||
test DHCP: addresses
|
test DHCP: addresses
|
||||||
|
guest1 ip link set dev __IFNAME1__ up
|
||||||
guest1 /sbin/dhclient -4 __IFNAME1__
|
guest1 /sbin/dhclient -4 __IFNAME1__
|
||||||
guest2 /sbin/dhclient -4 __IFNAME1__
|
guest2 ip link set dev __IFNAME2__ up
|
||||||
|
guest2 /sbin/dhclient -4 __IFNAME2__
|
||||||
g1out ADDR1 ip -j -4 addr show|jq -rM '.[] | select(.ifname == "__IFNAME1__").addr_info[0].local'
|
g1out ADDR1 ip -j -4 addr show|jq -rM '.[] | select(.ifname == "__IFNAME1__").addr_info[0].local'
|
||||||
g2out ADDR2 ip -j -4 addr show|jq -rM '.[] | select(.ifname == "__IFNAME2__").addr_info[0].local'
|
g2out ADDR2 ip -j -4 addr show|jq -rM '.[] | select(.ifname == "__IFNAME2__").addr_info[0].local'
|
||||||
hout HOST_ADDR ip -j -4 addr show|jq -rM '.[] | select(.ifname == "__HOST_IFNAME__").addr_info[0].local'
|
hout HOST_ADDR ip -j -4 addr show|jq -rM '.[] | select(.ifname == "__HOST_IFNAME__").addr_info[0].local'
|
||||||
|
@ -35,7 +37,7 @@ test DHCPv6: addresses
|
||||||
# Link is up now, wait for DAD to complete
|
# Link is up now, wait for DAD to complete
|
||||||
sleep 2
|
sleep 2
|
||||||
guest1 /sbin/dhclient -6 __IFNAME1__
|
guest1 /sbin/dhclient -6 __IFNAME1__
|
||||||
guest2 /sbin/dhclient -6 __IFNAME1__
|
guest2 /sbin/dhclient -6 __IFNAME2__
|
||||||
g1out ADDR1_6 ip -j -6 addr show|jq -rM '.[] | select(.ifname == "__IFNAME1__").addr_info[] | select(.prefixlen == 128).local'
|
g1out ADDR1_6 ip -j -6 addr show|jq -rM '.[] | select(.ifname == "__IFNAME1__").addr_info[] | select(.prefixlen == 128).local'
|
||||||
g2out ADDR2_6 ip -j -6 addr show|jq -rM '.[] | select(.ifname == "__IFNAME2__").addr_info[] | select(.prefixlen == 128).local'
|
g2out ADDR2_6 ip -j -6 addr show|jq -rM '.[] | select(.ifname == "__IFNAME2__").addr_info[] | select(.prefixlen == 128).local'
|
||||||
hout HOST_ADDR6 ip -j -6 addr show|jq -rM '.[] | select(.ifname == "__HOST_IFNAME__").addr_info[] | select(.scope == "global").local'
|
hout HOST_ADDR6 ip -j -6 addr show|jq -rM '.[] | select(.ifname == "__HOST_IFNAME__").addr_info[] | select(.scope == "global").local'
|
||||||
|
|
Loading…
Reference in a new issue