X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=test%2Ftest_vlib.py;h=89ccb396ecd24747e88f881e3692afb1d6992e98;hb=af2cc6425;hp=36a4340fa57cb44f18d219a9f6d366c8d78ac93c;hpb=c17fc44735b509b22476e8663e33be62678837a2;p=vpp.git diff --git a/test/test_vlib.py b/test/test_vlib.py index 36a4340fa57..89ccb396ecd 100644 --- a/test/test_vlib.py +++ b/test/test_vlib.py @@ -1,8 +1,11 @@ #!/usr/bin/env python3 import unittest - +import pexpect +import time +import signal from framework import VppTestCase, VppTestRunner, running_extended_tests +from framework import running_gcov_tests from vpp_ip_route import VppIpTable, VppIpRoute, VppRoutePath @@ -24,8 +27,7 @@ class TestVlib(VppTestCase): def tearDown(self): super(TestVlib, self).tearDown() - # @unittest.skipUnless(running_extended_tests, "part of extended tests") - + @unittest.skipUnless(running_gcov_tests, "part of code coverage tests") def test_vlib_main_unittest(self): """ Vlib main.c Code Coverage Test """ @@ -40,15 +42,14 @@ class TestVlib(VppTestCase): " IP6: 00:d0:2d:5e:86:85 -> 00:0d:ea:d0:00:00\n" " ICMP: db00::1 -> db00::2\n" " incrementing 30\n" - " }\n", + " }\n" "}\n", - "elog trace dispatch", + "event-logger trace dispatch", "event-logger stop", "event-logger clear", "event-logger resize 102400", "event-logger restart", "pcap dispatch trace on max 100 buffer-trace pg-input 15", - "set pmc instructions-per-clock", "pa en", "show event-log 100 all", "event-log save", @@ -67,6 +68,7 @@ class TestVlib(VppTestCase): else: self.logger.info(cmd + " FAIL retval " + str(r.retval)) + @unittest.skipUnless(running_gcov_tests, "part of code coverage tests") def test_vlib_node_cli_unittest(self): """ Vlib node_cli.c Code Coverage Test """ @@ -81,7 +83,7 @@ class TestVlib(VppTestCase): " IP6: 00:d0:2d:5e:86:85 -> 00:0d:ea:d0:00:00\n" " ICMP: db00::1 -> db00::2\n" " incrementing 30\n" - " }\n", + " }\n" "}\n", "show vlib graph", "show vlib graph ethernet-input", @@ -100,6 +102,7 @@ class TestVlib(VppTestCase): "set node function ethernet-input default", "set node function ethernet-input bozo", "set node function ethernet-input", + "show \t", ] for cmd in cmds: @@ -110,6 +113,7 @@ class TestVlib(VppTestCase): else: self.logger.info(cmd + " FAIL retval " + str(r.retval)) + @unittest.skipUnless(running_gcov_tests, "part of code coverage tests") def test_vlib_buffer_c_unittest(self): """ Vlib buffer.c Code Coverage Test """ @@ -124,11 +128,55 @@ class TestVlib(VppTestCase): " IP6: 00:d0:2d:5e:86:85 -> 00:0d:ea:d0:00:00\n" " ICMP: db00::1 -> db00::2\n" " incrementing 30\n" - " }\n", + " }\n" "}\n", + "event-logger trace", + "event-logger trace enable", + "event-logger trace api cli barrier", "pa en", + "show interface bogus", + "event-logger trace disable api cli barrier", + "event-logger trace circuit-node ethernet-input", + "event-logger trace circuit-node ethernet-input disable", + "clear interfaces", "test vlib", + "test vlib2", + "show memory api-segment stats-segment main-heap verbose", + "leak-check { show memory }", + "show cpu", + "memory-trace main-heap", + "memory-trace main-heap api-segment stats-segment", + "leak-check { show version }", + "show version ?", + "comment { show version }", + "uncomment { show version }", + "show memory main-heap", + "show memory bogus", + "choices", + "test heap-validate", + "memory-trace main-heap disable", "show buffers", + "show eve", + "show help", + "show ip ", + ] + + for cmd in cmds: + r = self.vapi.cli_return_response(cmd) + if r.retval != 0: + if hasattr(r, 'reply'): + self.logger.info(cmd + " FAIL reply " + r.reply) + else: + self.logger.info(cmd + " FAIL retval " + str(r.retval)) + + @unittest.skipUnless(running_gcov_tests, "part of code coverage tests") + def test_vlib_format_unittest(self): + """ Vlib format.c Code Coverage Test """ + + cmds = ["loopback create", + "classify filter pcap mask l2 proto match l2 proto 0x86dd", + "classify filter pcap del", + "test format-vlib", ] for cmd in cmds: @@ -139,5 +187,21 @@ class TestVlib(VppTestCase): else: self.logger.info(cmd + " FAIL retval " + str(r.retval)) + @unittest.skipUnless(running_gcov_tests, "part of code coverage tests") + def test_vlib_main_unittest(self): + """ Private Binary API Segment Test (takes 70 seconds) """ + + vat_path = self.vpp_bin + '_api_test' + vat = pexpect.spawn(vat_path, ['socket-name', self.api_sock]) + vat.expect("vat# ", timeout=10) + vat.sendline('sock_init_shm') + vat.expect("vat# ", timeout=10) + vat.sendline('sh api cli') + vat.kill(signal.SIGKILL) + vat.wait() + self.logger.info("vat terminated, 70 second wait for the Reaper") + time.sleep(70) + self.logger.info("Reaper should be complete...") + if __name__ == '__main__': unittest.main(testRunner=VppTestRunner)