From 296e592de93bbcfe5926bec0570c3888185febff Mon Sep 17 00:00:00 2001 From: Jean-Christophe Hugly Date: Thu, 30 Nov 2023 11:19:56 +0100 Subject: [PATCH] router: Small cleanup of the test harness. Move the TTL setting out of create_interface and improve comments. --- acceptance/router_newbenchmark/test.py | 19 ++++++++++--------- 1 file changed, 10 insertions(+), 9 deletions(-) diff --git a/acceptance/router_newbenchmark/test.py b/acceptance/router_newbenchmark/test.py index 974bb7b94b..ab1abbadaf 100644 --- a/acceptance/router_newbenchmark/test.py +++ b/acceptance/router_newbenchmark/test.py @@ -93,16 +93,14 @@ def create_interface(self, req: IntfReq, ns: str): other in the host stack. The outcome is the pair of interfaces and a record in intfMap, which associates the given - label with two mac addresses. One for each end of the pair. The mac addresses are not - chosen by the invoker, but by this function. - - In the isolated network, set default TTL for outgoing packets to the common - value 64, so that packets sent from router will match the expected value. + label with the network interface's host-side name and two mac addresses; one for each end + of the pair. The mac addresses, if they can be chosen, are not chosen by the invoker, but + by this function. We could add: - sudo("ip", "addr", "add", f"{req.peerIp}/{req.prefixLen}", "dev", hostIntf) - sudo("ip", "link", "set", hostIntf, "address", peerMac) - But it not necessary, the ARP seeding on the other end is enough. But not setting these + sudo("ip", "addr", "add", f"{req.peerIp}/{req.prefixLen}", "dev", hostIntf) + sudo("ip", "link", "set", hostIntf, "address", peerMac) + But it not necessary. The ARP seeding on the other end is enough. By not setting these addresses on the host side we make it look a little weird for anyone who would look at it but we avoid the risk of colliding with actual addresses of the host. @@ -130,7 +128,6 @@ def create_interface(self, req: IntfReq, ns: str): # The network namespace sudo("ip", "link", "set", brIntf, "netns", ns) - sudo("ip", "netns", "exec", ns, "sysctl", "-w", "net.ipv4.ip_default_ttl=64") # The addresses (presumably must be done once the br interface is in the namespace). sudo("ip", "netns", "exec", ns, @@ -181,6 +178,10 @@ def setup_prepare(self): "-f", "{{.NetworkSettings.SandboxKey}}").strip() sudo("ln", "-sfT", ns, "/var/run/netns/benchmark") + # Set the default TTL for outgoing packets to the common + # value 64, so that packets sent from router will match the expected value. + sudo("ip", "netns", "exec", "benchmark", "sysctl", "-w", "net.ipv4.ip_default_ttl=64") + # Run test brload test with --show-interfaces and set up the veth that it needs. # The router uses one end and the test uses the other end to feed it with (and possibly # capture) traffic.