vpp/test/asf/test_api_trace.py
Dave Wallace 8800f732f8 tests: refactor asf framework code
- 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>
2023-11-03 05:06:43 +00:00

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)