1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
|
#!/usr/bin/env python3
"""CLI functional tests"""
import datetime
import time
import unittest
from vpp_papi import VPPIOError
from framework import VppTestCase, VppTestRunner
class TestCLI(VppTestCase):
"""CLI Test Case"""
maxDiff = None
@classmethod
def setUpClass(cls):
# using the framework default
cls.vapi_response_timeout = 5
super(TestCLI, cls).setUpClass()
@classmethod
def tearDownClass(cls):
super(TestCLI, cls).tearDownClass()
def setUp(self):
super(TestCLI, self).setUp()
def tearDown(self):
super(TestCLI, self).tearDown()
def test_cli_retval(self):
"""CLI inband retval"""
rv = self.vapi.papi.cli_inband(cmd="this command does not exist")
self.assertNotEqual(rv.retval, 0)
rv = self.vapi.papi.cli_inband(cmd="show version")
self.assertEqual(rv.retval, 0)
def test_long_cli_delay(self):
"""Test that VppApiClient raises VppIOError if timeout.""" # noqa
with self.assertRaises(VPPIOError) as ctx:
rv = self.vapi.papi.cli_inband(cmd="wait 10")
def test_long_cli_delay_override(self):
"""Test per-command _timeout option.""" # noqa
rv = self.vapi.papi.cli_inband(cmd="wait 10", _timeout=15)
self.assertEqual(rv.retval, 0)
class TestCLIExtendedVapiTimeout(VppTestCase):
maxDiff = None
@classmethod
def setUpClass(cls):
cls.vapi_response_timeout = 15
cls.__doc__ = (
" CLI Test Case w/ Extended (%ssec) Vapi Timeout "
% cls.vapi_response_timeout
)
super(TestCLIExtendedVapiTimeout, cls).setUpClass()
@classmethod
def tearDownClass(cls):
super(TestCLIExtendedVapiTimeout, cls).tearDownClass()
def setUp(self):
super(TestCLIExtendedVapiTimeout, self).setUp()
def tearDown(self):
super(TestCLIExtendedVapiTimeout, self).tearDown()
def test_long_cli_delay(self):
"""Test that delayed result returns with extended timeout."""
wait_secs = self.vapi_response_timeout - 1
# get vpp time as float
start = self.vapi.papi.show_vpe_system_time(
_no_type_conversion=True
).vpe_system_time
rv = self.vapi.papi.cli_inband(cmd="wait %s" % wait_secs)
now = self.vapi.papi.show_vpe_system_time(
_no_type_conversion=True
).vpe_system_time
# assume that the overhead of the measurement is not more that .5 sec.
self.assertEqual(round(now - start), wait_secs)
if __name__ == "__main__":
unittest.main(testRunner=VppTestRunner)
|