diff options
author | adrianvillin <avillin@cisco.com> | 2023-10-19 12:15:52 +0200 |
---|---|---|
committer | Dave Wallace <dwallacelf@gmail.com> | 2023-10-25 01:53:43 +0000 |
commit | 4450aed056d0f096944d81c230bc33d9bd8497e3 (patch) | |
tree | f6a0f3f2751e45c1290b45b9c0b093d062552e2d /test/test_snort.py | |
parent | 51880abac14379b06d0c8ff8f17d0b2cd502bbc0 (diff) |
tests: Added a simple Snort plugin test to increase coverage.
Type: test
Change-Id: I96ec8b4347210672bc587407ab2fd0f0305ea486
Signed-off-by: adrianvillin <avillin@cisco.com>
Diffstat (limited to 'test/test_snort.py')
-rw-r--r-- | test/test_snort.py | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/test/test_snort.py b/test/test_snort.py new file mode 100644 index 00000000000..67c98a83d31 --- /dev/null +++ b/test/test_snort.py @@ -0,0 +1,53 @@ +from framework import VppTestCase, VppTestRunner +import unittest +from config import config + + +@unittest.skipIf("snort" in config.excluded_plugins, "Exclude snort plugin test") +class TestSnort(VppTestCase): + """Simple Snort plugin test""" + + @classmethod + def setUpClass(cls): + super(TestSnort, cls).setUpClass() + try: + cls.create_pg_interfaces(range(2)) + for i in cls.pg_interfaces: + i.config_ip4().resolve_arp() + i.admin_up() + except Exception: + cls.tearDownClass() + raise + + @classmethod + def tearDownClass(cls): + for i in cls.pg_interfaces: + i.unconfig_ip4() + i.admin_down() + super(TestSnort, cls).tearDownClass() + + def test_snort_cli(self): + # TODO: add a test with packets + # { cli command : part of the expected reply } + commands_replies = { + "snort create-instance name snortTest queue-size 16 on-disconnect drop": "", + "snort create-instance name snortTest2 queue-size 16 on-disconnect pass": "", + "snort attach instance snortTest interface pg0 output": "", + "snort attach instance snortTest2 interface pg1 input": "", + "show snort instances": "snortTest", + "show snort interfaces": "pg0", + "show snort clients": "number of clients", + "show snort mode": "input mode: interrupt", + "snort mode polling": "", + "snort mode interrupt": "", + "snort detach interface pg0": "", + "snort detach interface pg1": "", + } + + for command, reply in commands_replies.items(): + actual_reply = self.vapi.cli(command) + self.assertIn(reply, actual_reply) + + +if __name__ == "__main__": + unittest.main(testRunner=VppTestRunner) |