selftests: drv-net: support generating iperf3 load
JIRA: https://issues.redhat.com/browse/RHEL-89014 commit 0f0cdf312ecc06e63fbba95caf2844e2c405b076 Author: Jakub Kicinski <kuba@kernel.org> Date: Mon Apr 29 07:44:25 2024 -0700 selftests: drv-net: support generating iperf3 load While we are not very interested in testing performance it's useful to be able to generate a lot of traffic. iperf is the simplest way of getting relatively high PPS. Reviewed-by: Willem de Bruijn <willemb@google.com> Link: https://lore.kernel.org/r/20240429144426.743476-6-kuba@kernel.org Signed-off-by: Jakub Kicinski <kuba@kernel.org> Signed-off-by: Mohammad Heib <mheib@redhat.com>
This commit is contained in:
parent
8be6ded901
commit
2b5d145c1e
|
@ -15,4 +15,5 @@ except ModuleNotFoundError as e:
|
|||
sys.exit(4)
|
||||
|
||||
from .env import *
|
||||
from .load import *
|
||||
from .remote import Remote
|
||||
|
|
|
@ -0,0 +1,41 @@
|
|||
# SPDX-License-Identifier: GPL-2.0
|
||||
|
||||
import time
|
||||
|
||||
from lib.py import ksft_pr, cmd, ip, rand_port, wait_port_listen
|
||||
|
||||
class GenerateTraffic:
|
||||
def __init__(self, env):
|
||||
env.require_cmd("iperf3", remote=True)
|
||||
|
||||
self.env = env
|
||||
|
||||
port = rand_port()
|
||||
self._iperf_server = cmd(f"iperf3 -s -p {port}", background=True)
|
||||
wait_port_listen(port)
|
||||
time.sleep(0.1)
|
||||
self._iperf_client = cmd(f"iperf3 -c {env.addr} -P 16 -p {port} -t 86400",
|
||||
background=True, host=env.remote)
|
||||
|
||||
# Wait for traffic to ramp up
|
||||
pkt = ip("-s link show dev " + env.ifname, json=True)[0]["stats64"]["rx"]["packets"]
|
||||
for _ in range(50):
|
||||
time.sleep(0.1)
|
||||
now = ip("-s link show dev " + env.ifname, json=True)[0]["stats64"]["rx"]["packets"]
|
||||
if now - pkt > 1000:
|
||||
return
|
||||
pkt = now
|
||||
self.stop(verbose=True)
|
||||
raise Exception("iperf3 traffic did not ramp up")
|
||||
|
||||
def stop(self, verbose=None):
|
||||
self._iperf_client.process(terminate=True)
|
||||
if verbose:
|
||||
ksft_pr(">> Client:")
|
||||
ksft_pr(self._iperf_client.stdout)
|
||||
ksft_pr(self._iperf_client.stderr)
|
||||
self._iperf_server.process(terminate=True)
|
||||
if verbose:
|
||||
ksft_pr(">> Server:")
|
||||
ksft_pr(self._iperf_server.stdout)
|
||||
ksft_pr(self._iperf_server.stderr)
|
Loading…
Reference in New Issue