tests: added simple CT6 plugin tests
Type: test Change-Id: I77f119ac982170627484d792dc456753c9847af8 Signed-off-by: adrianvillin <avillin@cisco.com>
This commit is contained in:
parent
449c677440
commit
22b4a9c732
72
test/test_ct6.py
Normal file
72
test/test_ct6.py
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
from config import config
|
||||||
|
from framework import VppTestCase
|
||||||
|
from asfframework import VppTestRunner
|
||||||
|
import unittest
|
||||||
|
from scapy.layers.l2 import Ether
|
||||||
|
from scapy.layers.inet import UDP
|
||||||
|
from scapy.layers.inet6 import IPv6
|
||||||
|
from random import randint
|
||||||
|
|
||||||
|
|
||||||
|
# TODO: get an actual output from "show ip6 connection-tracker"
|
||||||
|
@unittest.skipIf("ct6" in config.excluded_plugins, "Exclude CT6 plugin tests")
|
||||||
|
class TestCt6(VppTestCase):
|
||||||
|
"""CT6 plugin tests"""
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def setUpClass(cls):
|
||||||
|
super(TestCt6, cls).setUpClass()
|
||||||
|
try:
|
||||||
|
cls.create_pg_interfaces(range(2))
|
||||||
|
for i in cls.pg_interfaces:
|
||||||
|
i.config_ip6().resolve_ndp()
|
||||||
|
i.admin_up()
|
||||||
|
except Exception:
|
||||||
|
cls.tearDownClass()
|
||||||
|
raise
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def tearDownClass(cls):
|
||||||
|
super(TestCt6, cls).tearDownClass()
|
||||||
|
|
||||||
|
def create_stream(self, src_if, dst_if, count):
|
||||||
|
packets = []
|
||||||
|
for i in range(count):
|
||||||
|
p = (
|
||||||
|
Ether(src=src_if.remote_mac, dst=src_if.local_mac)
|
||||||
|
/ IPv6(src=src_if.remote_ip6, dst=dst_if.remote_ip6)
|
||||||
|
/ UDP(sport=randint(49152, 65535), dport=5678, chksum=0)
|
||||||
|
)
|
||||||
|
packets.append(p)
|
||||||
|
return packets
|
||||||
|
|
||||||
|
def test_ct6_vapi(self):
|
||||||
|
self.vapi.ct6_enable_disable(enable_disable=True, is_inside=True, sw_if_index=1)
|
||||||
|
self.vapi.ct6_enable_disable(
|
||||||
|
enable_disable=True, is_inside=False, sw_if_index=1
|
||||||
|
)
|
||||||
|
|
||||||
|
packets = self.create_stream(self.pg0, self.pg1, 5)
|
||||||
|
self.pg0.add_stream(packets)
|
||||||
|
self.pg_start()
|
||||||
|
|
||||||
|
self.vapi.ct6_enable_disable(1234, 567, True, True, "pg0", "disable")
|
||||||
|
|
||||||
|
def test_ct6_cli(self):
|
||||||
|
self.vapi.cli("set ct6 outside pg1")
|
||||||
|
self.vapi.cli("set ct6 inside pg1")
|
||||||
|
|
||||||
|
packets = self.create_stream(self.pg0, self.pg1, 5)
|
||||||
|
self.pg0.add_stream(packets)
|
||||||
|
self.pg_start()
|
||||||
|
|
||||||
|
reply = self.vapi.cli("show ip6 connection-tracker")
|
||||||
|
self.assertIn("Thread 0", reply)
|
||||||
|
reply = self.vapi.cli("test ip6 connection-tracker")
|
||||||
|
self.assertIn("End state", reply)
|
||||||
|
|
||||||
|
self.vapi.cli("set ct6 inside pg1 disable")
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
unittest.main(testRunner=VppTestRunner)
|
Loading…
x
Reference in New Issue
Block a user