blob: 710163cf20c2d51945c5f2fa13396ae30f890782 [file] [log] [blame]
Filip Tehlar229f5fc2022-08-09 14:44:47 +00001package main
2
Adrian Villincee15aa2024-03-14 11:42:55 -04003func init() {
4 registerVethTests(EchoBuiltinTest)
5 registerSoloVethTests(TcpWithLossTest)
6}
7
8func EchoBuiltinTest(s *VethsSuite) {
Maros Ondrejickaffa3f602023-01-26 10:07:29 +01009 serverVpp := s.getContainerByName("server-vpp").vppInstance
adrianvillin28bd8f02024-02-13 06:00:02 -050010 serverVeth := s.getInterfaceByName(serverInterfaceName)
Maros Ondrejickaffa3f602023-01-26 10:07:29 +010011
Maros Ondrejicka2908f8c2023-02-02 08:58:04 +010012 serverVpp.vppctl("test echo server " +
Maros Ondrejickae7625d02023-02-28 16:55:01 +010013 " uri tcp://" + serverVeth.ip4AddressString() + "/1234")
Filip Tehlar229f5fc2022-08-09 14:44:47 +000014
Maros Ondrejickaffa3f602023-01-26 10:07:29 +010015 clientVpp := s.getContainerByName("client-vpp").vppInstance
Filip Tehlar229f5fc2022-08-09 14:44:47 +000016
Filip Tehlarefe875e2023-09-04 14:17:52 +020017 o := clientVpp.vppctl("test echo client nclients 100 bytes 1 verbose" +
18 " syn-timeout 100 test-timeout 100" +
19 " uri tcp://" + serverVeth.ip4AddressString() + "/1234")
Maros Ondrejicka87531802022-12-19 20:35:27 +010020 s.log(o)
Filip Tehlarefe875e2023-09-04 14:17:52 +020021 s.assertNotContains(o, "failed:")
22}
23
Adrian Villincee15aa2024-03-14 11:42:55 -040024func TcpWithLossTest(s *VethsSuite) {
Filip Tehlarefe875e2023-09-04 14:17:52 +020025 serverVpp := s.getContainerByName("server-vpp").vppInstance
26
adrianvillin28bd8f02024-02-13 06:00:02 -050027 serverVeth := s.getInterfaceByName(serverInterfaceName)
Filip Tehlarefe875e2023-09-04 14:17:52 +020028 serverVpp.vppctl("test echo server uri tcp://%s/20022",
29 serverVeth.ip4AddressString())
30
31 clientVpp := s.getContainerByName("client-vpp").vppInstance
32
Adrian Villincee15aa2024-03-14 11:42:55 -040033 // TODO: investigate why this ping was here:
34 // ---------
Filip Tehlarefe875e2023-09-04 14:17:52 +020035 // Ensure that VPP doesn't abort itself with NSIM enabled
36 // Warning: Removing this ping will make the test fail!
Adrian Villincee15aa2024-03-14 11:42:55 -040037 // clientVpp.vppctl("ping %s", serverVeth.ip4AddressString())
38 // ---------
Filip Tehlarefe875e2023-09-04 14:17:52 +020039
40 // Add loss of packets with Network Delay Simulator
41 clientVpp.vppctl("set nsim poll-main-thread delay 0.01 ms bandwidth 40 gbit" +
42 " packet-size 1400 packets-per-drop 1000")
43
adrianvillin28bd8f02024-02-13 06:00:02 -050044 clientVpp.vppctl("nsim output-feature enable-disable " + s.getInterfaceByName(clientInterfaceName).name)
Filip Tehlarefe875e2023-09-04 14:17:52 +020045
46 // Do echo test from client-vpp container
47 output := clientVpp.vppctl("test echo client uri tcp://%s/20022 verbose echo-bytes mbytes 50",
48 serverVeth.ip4AddressString())
49 s.log(output)
50 s.assertNotEqual(len(output), 0)
adrianvillin7c675472024-02-12 02:44:53 -050051 s.assertNotContains(output, "failed: timeout", output)
Filip Tehlar229f5fc2022-08-09 14:44:47 +000052}