+ try:
+ self.validateResults(worker_client, worker_server, self.timeout)
+ except Exception as error:
+ self.fail("Failed with %s" % error)
+
+ def validateResults(self, worker_client, worker_server, timeout):
+ if os.path.isdir('/proc/{}'.format(worker_server.process.pid)):
+ self.logger.info("Killing server worker process (pid %d)" %
+ worker_server.process.pid)
+ os.killpg(os.getpgid(worker_server.process.pid), signal.SIGTERM)
+ worker_server.join()
+ self.logger.info("Client worker result is `%s'" % worker_client.result)
+ error = False
+ if worker_client.result is None:
+ try:
+ error = True
+ self.logger.error(
+ "Timeout: %ss! Killing client worker process (pid %d)" %
+ (timeout, worker_client.process.pid))
+ os.killpg(os.getpgid(worker_client.process.pid),
+ signal.SIGTERM)
+ worker_client.join()
+ except:
+ self.logger.debug(
+ "Couldn't kill client worker process")
+ raise
+ if error:
+ raise Exception(
+ "Timeout! Client worker did not finish in %ss" % timeout)
+ self.assert_equal(worker_client.result, 0, "Binary test return code")
+
+
+class VCLCutThruTestCase(VCLTestCase):
+ """ VCL Cut Thru Tests """
+
+ def setUp(self):
+ super(VCLCutThruTestCase, self).setUp()
+
+ self.cut_thru_setup()
+ self.client_echo_test_args = ["-E", self.echo_phrase, "-X",
+ self.server_addr, self.server_port]
+ self.client_iperf3_timeout = 20
+ self.client_iperf3_args = ["-V4d", "-t 5", "-c", self.server_addr]
+ self.server_iperf3_args = ["-V4d", "-s"]
+ self.client_uni_dir_nsock_timeout = 20
+ self.client_uni_dir_nsock_test_args = ["-N", "1000", "-U", "-X",
+ "-I", "2",
+ self.server_addr,
+ self.server_port]
+ self.client_bi_dir_nsock_timeout = 20
+ self.client_bi_dir_nsock_test_args = ["-N", "1000", "-B", "-X",
+ "-I", "2",
+ self.server_addr,
+ self.server_port]
+
+ def tearDown(self):
+ self.cut_thru_tear_down()
+
+ super(VCLCutThruTestCase, self).tearDown()
+
+ def test_ldp_cut_thru_echo(self):
+ """ run LDP cut thru echo test """
+
+ self.cut_thru_test("sock_test_server", self.server_args,
+ "sock_test_client", self.client_echo_test_args)
+
+ def test_ldp_cut_thru_iperf3(self):
+ """ run LDP cut thru iperf3 test """
+
+ try:
+ subprocess.check_output(['iperf3', '-v'])
+ except subprocess.CalledProcessError:
+ self.logger.error("WARNING: 'iperf3' is not installed,")
+ self.logger.error(" 'test_ldp_cut_thru_iperf3' not run!")
+ return
+
+ self.timeout = self.client_iperf3_timeout
+ self.cut_thru_test("iperf3", self.server_iperf3_args,
+ "iperf3", self.client_iperf3_args)
+
+ def test_ldp_cut_thru_uni_dir_nsock(self):
+ """ run LDP cut thru uni-directional (multiple sockets) test """
+
+ self.timeout = self.client_uni_dir_nsock_timeout
+ self.cut_thru_test("sock_test_server", self.server_args,
+ "sock_test_client",
+ self.client_uni_dir_nsock_test_args)
+
+ def test_ldp_cut_thru_bi_dir_nsock(self):
+ """ run LDP cut thru bi-directional (multiple sockets) test """
+
+ self.timeout = self.client_bi_dir_nsock_timeout
+ self.cut_thru_test("sock_test_server", self.server_args,
+ "sock_test_client",
+ self.client_bi_dir_nsock_test_args)
+
+ def test_vcl_cut_thru_echo(self):
+ """ run VCL cut thru echo test """
+
+ self.cut_thru_test("vcl_test_server", self.server_args,
+ "vcl_test_client", self.client_echo_test_args)
+
+ def test_vcl_cut_thru_uni_dir_nsock(self):
+ """ run VCL cut thru uni-directional (multiple sockets) test """
+
+ self.timeout = self.client_uni_dir_nsock_timeout
+ self.cut_thru_test("vcl_test_server", self.server_args,
+ "vcl_test_client",
+ self.client_uni_dir_nsock_test_args)
+
+ def test_vcl_cut_thru_bi_dir_nsock(self):
+ """ run VCL cut thru bi-directional (multiple sockets) test """
+
+ self.timeout = self.client_bi_dir_nsock_timeout
+ self.cut_thru_test("vcl_test_server", self.server_args,
+ "vcl_test_client",
+ self.client_bi_dir_nsock_test_args)
+
+
+class VCLThruHostStackTestCase(VCLTestCase):
+ """ VCL Thru Host Stack Tests """
+
+ def setUp(self):
+ super(VCLThruHostStackTestCase, self).setUp()
+
+ self.thru_host_stack_setup()
+ self.client_echo_test_args = ["-E", self.echo_phrase, "-X",
+ self.loop0.local_ip4,
+ self.server_port]
+
+ def tearDown(self):
+ self.thru_host_stack_tear_down()
+
+ super(VCLThruHostStackTestCase, self).tearDown()
+
+ def test_ldp_thru_host_stack_echo(self):
+ """ run LDP thru host stack echo test """
+
+ self.thru_host_stack_test("sock_test_server", self.server_args,
+ "sock_test_client",
+ self.client_echo_test_args)
+ # TBD: Remove these when VPP thru host teardown config bug is fixed.
+ self.thru_host_stack_test("vcl_test_server", self.server_args,
+ "vcl_test_client",
+ self.client_echo_test_args)
+
+ def test_vcl_thru_host_stack_echo(self):
+ """ run VCL thru host stack echo test """
+
+ # TBD: Enable this when VPP thru host teardown config bug is fixed.
+ # self.thru_host_stack_test("vcl_test_server", self.server_args,
+ # "vcl_test_client",
+ # self.client_echo_test_args)
+
+ # TBD: Remove VCLThruHostStackGroup*TestCase classes and move
+ # tests here when VPP thru host teardown/setup config bug
+ # is fixed.
+
+
+class VCLThruHostStackNSessionBidirTestCase(VCLTestCase):
+ """ VCL Thru Host Stack NSession Bidir Tests """
+
+ def setUp(self):
+ super(VCLThruHostStackNSessionBidirTestCase, self).setUp()
+
+ self.thru_host_stack_setup()
+ if self.vppDebug:
+ self.client_bi_dir_nsock_timeout = 20
+ self.client_bi_dir_nsock_test_args = ["-N", "1000", "-B", "-X",
+ "-I", "2",
+ self.loop0.local_ip4,
+ self.server_port]
+ else:
+ self.client_bi_dir_nsock_timeout = 20
+ self.client_bi_dir_nsock_test_args = ["-N", "1000", "-B", "-X",
+ "-I", "2",
+ self.loop0.local_ip4,
+ self.server_port]
+
+ def tearDown(self):
+ self.thru_host_stack_tear_down()
+
+ super(VCLThruHostStackNSessionBidirTestCase, self).tearDown()
+
+ def test_vcl_thru_host_stack_bi_dir_nsock(self):
+ """ run VCL thru host stack bi-directional (multiple sockets) test """
+
+ self.timeout = self.client_bi_dir_nsock_timeout
+ self.thru_host_stack_test("vcl_test_server", self.server_args,
+ "vcl_test_client",
+ self.client_bi_dir_nsock_test_args)
+
+
+class VCLThruHostStackGroupBTestCase(VCLTestCase):
+ """ VCL Thru Host Stack Group B Tests """
+
+ def setUp(self):
+ super(VCLThruHostStackGroupBTestCase, self).setUp()
+
+ self.thru_host_stack_setup()
+ if self.vppDebug:
+ self.client_bi_dir_nsock_timeout = 20
+ self.client_bi_dir_nsock_test_args = ["-N", "1000", "-B", "-X",
+ # OUCH! Host Stack Bug?
+ # "-I", "2",
+ self.loop0.local_ip4,
+ self.server_port]
+ else:
+ self.client_bi_dir_nsock_timeout = 20
+ self.client_bi_dir_nsock_test_args = ["-N", "1000", "-B", "-X",
+ # OUCH! Host Stack Bug?
+ # "-I", "2",
+ self.loop0.local_ip4,
+ self.server_port]
+
+ def tearDown(self):
+ self.thru_host_stack_tear_down()
+
+ super(VCLThruHostStackGroupBTestCase, self).tearDown()
+
+ def test_ldp_thru_host_stack_bi_dir_nsock(self):
+ """ run LDP thru host stack bi-directional (multiple sockets) test """
+
+ self.timeout = self.client_bi_dir_nsock_timeout
+ self.thru_host_stack_test("sock_test_server", self.server_args,
+ "sock_test_client",
+ self.client_bi_dir_nsock_test_args)
+
+
+class VCLThruHostStackGroupCTestCase(VCLTestCase):
+ """ VCL Thru Host Stack Group C Tests """
+
+ def setUp(self):
+ super(VCLThruHostStackGroupCTestCase, self).setUp()
+
+ self.thru_host_stack_setup()
+ if self.vppDebug:
+ self.client_uni_dir_nsock_timeout = 20
+ self.numSockets = "2"
+ else:
+ self.client_uni_dir_nsock_timeout = 20
+ self.numSockets = "5"
+
+ self.client_uni_dir_nsock_test_args = ["-N", "1000", "-U", "-X",
+ "-I", self.numSockets,
+ self.loop0.local_ip4,
+ self.server_port]
+
+ def tearDown(self):
+ self.thru_host_stack_tear_down()
+
+ super(VCLThruHostStackGroupCTestCase, self).tearDown()
+
+ def test_ldp_thru_host_stack_uni_dir_nsock(self):
+ """ run LDP thru host stack uni-directional (multiple sockets) test """
+
+ self.timeout = self.client_uni_dir_nsock_timeout
+ self.thru_host_stack_test("sock_test_server", self.server_args,
+ "sock_test_client",
+ self.client_uni_dir_nsock_test_args)
+
+
+class VCLThruHostStackGroupDTestCase(VCLTestCase):
+ """ VCL Thru Host Stack Group D Tests """
+
+ def setUp(self):
+ super(VCLThruHostStackGroupDTestCase, self).setUp()
+
+ self.thru_host_stack_setup()
+ if self.vppDebug:
+ self.client_uni_dir_nsock_timeout = 20
+ self.numSockets = "2"
+ else:
+ self.client_uni_dir_nsock_timeout = 20
+ self.numSockets = "5"
+
+ self.client_uni_dir_nsock_test_args = ["-N", "1000", "-U", "-X",
+ "-I", self.numSockets,
+ self.loop0.local_ip4,
+ self.server_port]
+
+ def tearDown(self):
+ self.thru_host_stack_tear_down()
+
+ super(VCLThruHostStackGroupDTestCase, self).tearDown()
+
+ def test_vcl_thru_host_stack_uni_dir_nsock(self):
+ """ run VCL thru host stack uni-directional (multiple sockets) test """
+
+ self.timeout = self.client_uni_dir_nsock_timeout
+ self.thru_host_stack_test("vcl_test_server", self.server_args,
+ "vcl_test_client",
+ self.client_uni_dir_nsock_test_args)
+
+
+class VCLThruHostStackIperfTestCase(VCLTestCase):
+ """ VCL Thru Host Stack Iperf Tests """
+
+ def setUp(self):
+ super(VCLThruHostStackIperfTestCase, self).setUp()
+
+ self.thru_host_stack_setup()
+ self.client_iperf3_timeout = 20
+ self.client_iperf3_args = ["-V4d", "-t 5", "-c", self.loop0.local_ip4]
+ self.server_iperf3_args = ["-V4d", "-s"]
+
+ def tearDown(self):
+ self.thru_host_stack_tear_down()
+
+ super(VCLThruHostStackIperfTestCase, self).tearDown()
+
+ def test_ldp_thru_host_stack_iperf3(self):
+ """ run LDP thru host stack iperf3 test """
+
+ try:
+ subprocess.check_output(['iperf3', '-v'])
+ except subprocess.CalledProcessError:
+ self.logger.error("WARNING: 'iperf3' is not installed,")
+ self.logger.error(
+ " 'test_ldp_thru_host_stack_iperf3' not run!")
+ return
+
+ self.timeout = self.client_iperf3_timeout
+ self.thru_host_stack_test("iperf3", self.server_iperf3_args,
+ "iperf3", self.client_iperf3_args)
+
+
+class VCLIpv6CutThruTestCase(VCLTestCase):
+ """ VCL IPv6 Cut Thru Tests """
+
+ def setUp(self):
+ super(VCLIpv6CutThruTestCase, self).setUp()
+
+ self.cut_thru_setup()
+ self.client_iperf3_timeout = 20
+ self.client_uni_dir_nsock_timeout = 20
+ self.client_bi_dir_nsock_timeout = 20
+ self.client_ipv6_echo_test_args = ["-6", "-E", self.echo_phrase, "-X",
+ self.server_ipv6_addr,
+ self.server_port]
+ self.client_ipv6_iperf3_args = ["-V6d", "-t 5", "-c",
+ self.server_ipv6_addr]
+ self.server_ipv6_iperf3_args = ["-V6d", "-s"]
+ self.client_ipv6_uni_dir_nsock_test_args = ["-N", "1000", "-U", "-X",
+ "-6",
+ "-I", "2",
+ self.server_ipv6_addr,
+ self.server_port]
+ self.client_ipv6_bi_dir_nsock_test_args = ["-N", "1000", "-B", "-X",
+ "-6",
+ "-I", "2",
+ self.server_ipv6_addr,
+ self.server_port]
+
+ def tearDown(self):
+ self.cut_thru_tear_down()
+
+ super(VCLIpv6CutThruTestCase, self).tearDown()
+
+ def test_ldp_ipv6_cut_thru_echo(self):
+ """ run LDP IPv6 cut thru echo test """
+
+ self.cut_thru_test("sock_test_server",
+ self.server_ipv6_args,
+ "sock_test_client",
+ self.client_ipv6_echo_test_args)
+
+ def test_ldp_ipv6_cut_thru_iperf3(self):
+ """ run LDP IPv6 cut thru iperf3 test """
+
+ try:
+ subprocess.check_output(['iperf3', '-v'])
+ except:
+ self.logger.error("WARNING: 'iperf3' is not installed,")
+ self.logger.error(
+ " 'test_ldp_ipv6_cut_thru_iperf3' not run!")
+ return
+
+ self.timeout = self.client_iperf3_timeout
+ self.cut_thru_test("iperf3", self.server_ipv6_iperf3_args,
+ "iperf3", self.client_ipv6_iperf3_args)
+
+ def test_ldp_ipv6_cut_thru_uni_dir_nsock(self):
+ """ run LDP IPv6 cut thru uni-directional (multiple sockets) test """
+
+ self.timeout = self.client_uni_dir_nsock_timeout
+ self.cut_thru_test("sock_test_server", self.server_ipv6_args,
+ "sock_test_client",
+ self.client_ipv6_uni_dir_nsock_test_args)
+
+ def test_ldp_ipv6_cut_thru_bi_dir_nsock(self):
+ """ run LDP IPv6 cut thru bi-directional (multiple sockets) test """
+
+ self.timeout = self.client_bi_dir_nsock_timeout
+ self.cut_thru_test("sock_test_server", self.server_ipv6_args,
+ "sock_test_client",
+ self.client_ipv6_bi_dir_nsock_test_args)
+
+ def test_vcl_ipv6_cut_thru_echo(self):
+ """ run VCL IPv6 cut thru echo test """
+
+ self.cut_thru_test("vcl_test_server",
+ self.server_ipv6_args,
+ "vcl_test_client",
+ self.client_ipv6_echo_test_args)
+
+ def test_vcl_ipv6_cut_thru_uni_dir_nsock(self):
+ """ run VCL IPv6 cut thru uni-directional (multiple sockets) test """
+
+ self.timeout = self.client_uni_dir_nsock_timeout
+ self.cut_thru_test("vcl_test_server", self.server_ipv6_args,
+ "vcl_test_client",
+ self.client_ipv6_uni_dir_nsock_test_args)
+
+ def test_vcl_ipv6_cut_thru_bi_dir_nsock(self):
+ """ run VCL IPv6 cut thru bi-directional (multiple sockets) test """
+
+ self.timeout = self.client_bi_dir_nsock_timeout
+ self.cut_thru_test("vcl_test_server", self.server_ipv6_args,
+ "vcl_test_client",
+ self.client_ipv6_bi_dir_nsock_test_args)
+
+
+class VCLIpv6ThruHostStackTestCase(VCLTestCase):
+ """ VCL IPv6 Thru Host Stack Tests """
+
+ def setUp(self):
+ super(VCLIpv6ThruHostStackTestCase, self).setUp()
+
+ self.thru_host_stack_ipv6_setup()
+ self.client_ipv6_echo_test_args = ["-6", "-E", self.echo_phrase, "-X",
+ self.loop0.local_ip6,
+ self.server_port]
+
+ def tearDown(self):
+ self.thru_host_stack_ipv6_tear_down()
+
+ super(VCLIpv6ThruHostStackTestCase, self).tearDown()
+
+ def test_ldp_ipv6_thru_host_stack_echo(self):
+ """ run LDP IPv6 thru host stack echo test """
+
+ self.thru_host_stack_test("sock_test_server",
+ self.server_ipv6_args,
+ "sock_test_client",
+ self.client_ipv6_echo_test_args)
+ # TBD: Remove these when VPP thru host teardown config bug is fixed.
+ self.thru_host_stack_test("vcl_test_server",
+ self.server_ipv6_args,
+ "vcl_test_client",
+ self.client_ipv6_echo_test_args)
+
+ def test_vcl_ipv6_thru_host_stack_echo(self):
+ """ run VCL IPv6 thru host stack echo test """
+
+# self.thru_host_stack_test("vcl_test_server",
+# self.server_ipv6_args,
+# "vcl_test_client",
+# self.client_ipv6_echo_test_args)
+
+ # TBD: Remove VCLIpv6ThruHostStackGroup*TestCase classes and move
+ # tests here when VPP thru host teardown/setup config bug
+ # is fixed.
+
+
+class VCLIpv6ThruHostStackGroupATestCase(VCLTestCase):
+ """ VCL IPv6 Thru Host Stack Group A Tests """
+
+ def setUp(self):
+ super(VCLIpv6ThruHostStackGroupATestCase, self).setUp()
+
+ self.thru_host_stack_ipv6_setup()
+ if self.vppDebug:
+ self.client_bi_dir_nsock_timeout = 20
+ self.client_ipv6_bi_dir_nsock_test_args = ["-N", "1000",
+ "-B", "-X", "-6",
+ "-I", "2",
+ self.loop0.local_ip6,
+ self.server_port]
+ else:
+ self.client_bi_dir_nsock_timeout = 20
+ self.client_ipv6_bi_dir_nsock_test_args = ["-N", "1000",
+ "-B", "-X", "-6",
+ "-I", "2",
+ self.loop0.local_ip6,
+ self.server_port]
+
+ def tearDown(self):
+ self.thru_host_stack_ipv6_tear_down()
+
+ super(VCLIpv6ThruHostStackGroupATestCase, self).tearDown()
+
+ def test_vcl_thru_host_stack_bi_dir_nsock(self):
+ """ run VCL thru host stack bi-directional (multiple sockets) test """
+
+ self.timeout = self.client_bi_dir_nsock_timeout
+ self.thru_host_stack_test("vcl_test_server", self.server_ipv6_args,
+ "vcl_test_client",
+ self.client_ipv6_bi_dir_nsock_test_args)
+
+
+class VCLIpv6ThruHostStackGroupBTestCase(VCLTestCase):
+ """ VCL IPv6 Thru Host Stack Group B Tests """
+
+ def setUp(self):
+ super(VCLIpv6ThruHostStackGroupBTestCase, self).setUp()
+
+ self.thru_host_stack_ipv6_setup()
+ if self.vppDebug:
+ self.client_bi_dir_nsock_timeout = 20
+ self.client_ipv6_bi_dir_nsock_test_args = ["-N", "1000",
+ "-B", "-X", "-6",
+ # OUCH! Host Stack Bug?
+ # "-I", "2",
+ self.loop0.local_ip6,
+ self.server_port]
+ else:
+ self.client_bi_dir_nsock_timeout = 20
+ self.client_ipv6_bi_dir_nsock_test_args = ["-N", "1000",
+ "-B", "-X", "-6",
+ # OUCH! Host Stack Bug?
+ # "-I", "2",
+ self.loop0.local_ip6,
+ self.server_port]
+
+ def tearDown(self):
+ self.thru_host_stack_ipv6_tear_down()
+
+ super(VCLIpv6ThruHostStackGroupBTestCase, self).tearDown()
+
+ def test_ldp_thru_host_stack_bi_dir_nsock(self):
+ """ run LDP thru host stack bi-directional (multiple sockets) test """
+
+ self.timeout = self.client_bi_dir_nsock_timeout
+ self.thru_host_stack_test("sock_test_server",
+ self.server_ipv6_args,
+ "sock_test_client",
+ self.client_ipv6_bi_dir_nsock_test_args)
+
+
+class VCLIpv6ThruHostStackGroupCTestCase(VCLTestCase):
+ """ VCL IPv6 Thru Host Stack Group C Tests """
+
+ def setUp(self):
+ super(VCLIpv6ThruHostStackGroupCTestCase, self).setUp()
+
+ self.thru_host_stack_ipv6_setup()
+ if self.vppDebug:
+ self.client_uni_dir_nsock_timeout = 20
+ self.numSockets = "2"
+ else:
+ self.client_uni_dir_nsock_timeout = 20
+ self.numSockets = "5"
+
+ self.client_ipv6_uni_dir_nsock_test_args = ["-N", "1000", "-U", "-X",
+ "-6",
+ "-I", self.numSockets,
+ self.loop0.local_ip6,
+ self.server_port]
+
+ def tearDown(self):
+ self.thru_host_stack_ipv6_tear_down()
+
+ super(VCLIpv6ThruHostStackGroupCTestCase, self).tearDown()
+
+ def test_ldp_thru_host_stack_uni_dir_nsock(self):
+ """ run LDP thru host stack uni-directional (multiple sockets) test """
+
+ self.timeout = self.client_uni_dir_nsock_timeout
+ self.thru_host_stack_test("sock_test_server",
+ self.server_ipv6_args,
+ "sock_test_client",
+ self.client_ipv6_uni_dir_nsock_test_args)
+
+
+class VCLIpv6ThruHostStackGroupDTestCase(VCLTestCase):
+ """ VCL IPv6 Thru Host Stack Group D Tests """
+
+ def setUp(self):
+ super(VCLIpv6ThruHostStackGroupDTestCase, self).setUp()
+
+ self.thru_host_stack_ipv6_setup()
+ if self.vppDebug:
+ self.client_uni_dir_nsock_timeout = 20
+ self.numSockets = "2"
+ else:
+ self.client_uni_dir_nsock_timeout = 20
+ self.numSockets = "5"
+
+ self.client_ipv6_uni_dir_nsock_test_args = ["-N", "1000", "-U", "-X",
+ "-6",
+ "-I", self.numSockets,
+ self.loop0.local_ip6,
+ self.server_port]
+
+ def tearDown(self):
+ self.thru_host_stack_ipv6_tear_down()
+
+ super(VCLIpv6ThruHostStackGroupDTestCase, self).tearDown()
+
+ def test_vcl_thru_host_stack_uni_dir_nsock(self):
+ """ run VCL thru host stack uni-directional (multiple sockets) test """
+
+ self.timeout = self.client_uni_dir_nsock_timeout
+ self.thru_host_stack_test("vcl_test_server", self.server_ipv6_args,
+ "vcl_test_client",
+ self.client_ipv6_uni_dir_nsock_test_args)
+
+
+class VCLIpv6ThruHostStackIperfTestCase(VCLTestCase):
+ """ VCL IPv6 Thru Host Stack Iperf Tests """
+
+ def setUp(self):
+ super(VCLIpv6ThruHostStackIperfTestCase, self).setUp()
+
+ self.thru_host_stack_ipv6_setup()
+ self.client_iperf3_timeout = 20
+ self.client_ipv6_iperf3_args = ["-V6d", "-t 5", "-c",
+ self.loop0.local_ip6]
+ self.server_ipv6_iperf3_args = ["-V6d", "-s"]
+
+ def tearDown(self):
+ self.thru_host_stack_ipv6_tear_down()
+
+ super(VCLIpv6ThruHostStackIperfTestCase, self).tearDown()
+
+ def test_ldp_thru_host_stack_iperf3(self):
+ """ run LDP thru host stack iperf3 test """
+
+ try:
+ subprocess.check_output(['iperf3', '-v'])
+ except subprocess.CalledProcessError:
+ self.logger.error("WARNING: 'iperf3' is not installed,")
+ self.logger.error(
+ " 'test_ldp_thru_host_stack_iperf3' not run!")
+ return
+
+ self.timeout = self.client_iperf3_timeout
+ self.thru_host_stack_test("iperf3", self.server_ipv6_iperf3_args,
+ "iperf3", self.client_ipv6_iperf3_args)
+