8800f732f8
- Make framework.py classes a subset of asfframework.py classes - Remove all packet related code from asfframework.py - Add test class and test case set up debug output to log - Repatriate packet tests from asf to test directory - Remove non-packet related code from framework.py and inherit them from asfframework.py classes - Clean up unused import variables - Re-enable BFD tests on Ubuntu 22.04 and fix intermittent test failures in echo_looped_back testcases (where # control packets verified but not guaranteed to be received during test) - Re-enable Wireguard tests on Ubuntu 22.04 and fix intermittent test failures in handshake ratelimiting testcases and event testcase - Run Wiregard testcase suites solo - Improve debug output in log.txt - Increase VCL/LDP post sleep timeout to allow iperf server to finish cleanly. - Fix pcap history files to be sorted by suite and testcase and ensure order/timestamp is correct based on creation in the testcase. - Decode pcap files for each suite and testcase for all errors or if configured via comandline option / env var - Improve vpp corefile detection to allow complete corefile generation - Disable vm vpp interfaces testcases on debian11 - Clean up failed unittest dir when retrying failed testcases and unify testname directory and failed linknames into framwork functions Type: test Change-Id: I0764f79ea5bb639d278bf635ed2408d4d5220e1e Signed-off-by: Dave Wallace <dwallacelf@gmail.com>
62 lines
1.7 KiB
Python
62 lines
1.7 KiB
Python
import unittest
|
|
from asfframework import VppAsfTestCase, VppTestRunner
|
|
import json
|
|
import shutil
|
|
|
|
|
|
class TestJsonApiTrace(VppAsfTestCase):
|
|
"""JSON API trace related tests"""
|
|
|
|
@classmethod
|
|
def setUpClass(cls):
|
|
super(TestJsonApiTrace, cls).setUpClass()
|
|
|
|
def setUp(self):
|
|
self.vapi.cli("api trace free")
|
|
self.vapi.cli("api trace on")
|
|
self.vapi.cli("api trace tx on")
|
|
|
|
@classmethod
|
|
def tearDownClass(cls):
|
|
super(TestJsonApiTrace, cls).tearDownClass()
|
|
|
|
def test_json_api_trace_save(self):
|
|
self.vapi.show_version()
|
|
|
|
fname = "test_api_trace-%d.json" % self.vpp.pid
|
|
tmp_api_trace = "/tmp/%s" % fname
|
|
fpath = "%s/%s" % (self.tempdir, fname)
|
|
self.vapi.cli("api trace save-json {}".format(fname))
|
|
shutil.move(tmp_api_trace, fpath)
|
|
with open(fpath, encoding="utf-8") as f:
|
|
s = f.read()
|
|
trace = json.loads(s)
|
|
found = False
|
|
for o in trace:
|
|
if o["_msgname"] == "show_version":
|
|
found = True
|
|
break
|
|
self.assertTrue(found)
|
|
self.assertEquals(o["_msgname"], "show_version")
|
|
|
|
def test_json_api_trace_replay(self):
|
|
fname = "/tmp/create_loop.json"
|
|
req = """
|
|
[
|
|
{
|
|
"_msgname": "create_loopback",
|
|
"_crc": "42bb5d22",
|
|
"mac_address": "00:00:00:00:00:00"
|
|
}]
|
|
"""
|
|
with open(fname, "w") as f:
|
|
f.write(req)
|
|
self.vapi.cli("api trace replay-json {}".format(fname))
|
|
r = self.vapi.sw_interface_dump(name_filter="loop", name_filter_valid=True)
|
|
self.assertEqual(len(r), 1)
|
|
self.assertEqual(r[0].interface_name, "loop0")
|
|
|
|
|
|
if __name__ == "__main__":
|
|
unittest.main(testRunner=VppTestRunner)
|