From 5f791f19147754f45f52e88fc80cf729a884c906 Mon Sep 17 00:00:00 2001 From: Kenneth Giusti Date: Fri, 9 Feb 2024 16:00:51 -0500 Subject: [PATCH] Fixes #1409: port StuckDelivery and NoDelayedDelivery tests to TCP-lite --- tests/system_tests_tcp_adaptor.py | 39 +++++++++++++++++++++++++------ 1 file changed, 32 insertions(+), 7 deletions(-) diff --git a/tests/system_tests_tcp_adaptor.py b/tests/system_tests_tcp_adaptor.py index ba8b50476..1149599f1 100644 --- a/tests/system_tests_tcp_adaptor.py +++ b/tests/system_tests_tcp_adaptor.py @@ -1523,13 +1523,14 @@ class TcpAdaptorStuckDeliveryTest(TestCase): deliveries. See Dispatch-2036. """ @classmethod - def setUpClass(cls): + def setUpClass(cls, encap='legacy', test_name='TCPStuckDeliveryTest'): super(TcpAdaptorStuckDeliveryTest, cls).setUpClass() if DISABLE_SELECTOR_TESTS: return - cls.test_name = 'TCPStuckDeliveryTest' + cls.encapsulation = encap + cls.test_name = test_name # Topology: linear. # tcp-client->edge1->interior1->tcp-server @@ -1564,7 +1565,8 @@ def router(cls, name, mode, config): ('tcpConnector', {'host': "127.0.0.1", 'port': cls.interior_tcp_connector_port, - 'address': 'nostuck'})]) + 'address': 'nostuck', + 'encapsulation': cls.encapsulation})]) cls.i_router.wait_ready() cls.e_router = router(cls, "%s_E" % cls.test_name, @@ -1572,7 +1574,8 @@ def router(cls, name, mode, config): [('tcpListener', {'host': "0.0.0.0", 'port': cls.edge_tcp_listener_port, - 'address': 'nostuck'}), + 'address': 'nostuck', + 'encapsulation': cls.encapsulation}), ('connector', {'role': 'edge', 'port': cls.interior_edge_listener_port})]) @@ -1643,6 +1646,16 @@ def test_01_ignore_stuck_deliveries(self): "Stuck deliveries should not be logged!") +class TcpAdaptorStuckDeliveryLiteTest(TcpAdaptorStuckDeliveryTest): + """ + Verify that the routers stuck delivery detection is not applied to TCP + deliveries. See Dispatch-2036. + """ + @classmethod + def setUpClass(cls): + super(TcpAdaptorStuckDeliveryLiteTest, cls).setUpClass(encap='lite', test_name='TCPStuckDeliveryLiteTest') + + class TcpAdaptorManagementTest(TestCase): """ Test Creation and deletion of TCP management entities @@ -2635,9 +2648,10 @@ class TcpAdaptorNoDelayedDelivery(TestCase): Ensure long lived TCP sessions are not counted as delayed deliveries """ @classmethod - def setUpClass(cls): + def setUpClass(cls, encap="legacy"): super(TcpAdaptorNoDelayedDelivery, cls).setUpClass() + cls.encapsulation = encap cls.listener_port = cls.tester.get_port() cls.connector_port = cls.tester.get_port() config = [ @@ -2647,10 +2661,12 @@ def setUpClass(cls): 'port': cls.tester.get_port()}), ('tcpListener', {'host': "0.0.0.0", 'port': cls.listener_port, - 'address': "no/delay"}), + 'address': "no/delay", + 'encapsulation': cls.encapsulation}), ('tcpConnector', {'host': "127.0.0.1", 'port': cls.connector_port, - 'address': "no/delay"}), + 'address': "no/delay", + 'encapsulation': cls.encapsulation}), ('address', {'prefix': 'closest', 'distribution': 'closest'}), ('address', {'prefix': 'multicast', 'distribution': 'multicast'}), ] @@ -2720,6 +2736,15 @@ def test_01_check_delayed_deliveries(self): f"Expected delay counter to be zero, got {counters}") +class TcpAdaptorNoDelayedDeliveryLite(TcpAdaptorNoDelayedDelivery): + """ + Ensure long lived TCP sessions are not counted as delayed deliveries + """ + @classmethod + def setUpClass(cls): + super(TcpAdaptorNoDelayedDeliveryLite, cls).setUpClass(encap='lite') + + class TcpMisconfiguredLegacyLiteEncapsTest(TestCase): """ Ensure that the TCP adaptor can detect misconfiguration of the