Passed
Pull Request — master (#96)
by
unknown
03:25
created

TestMain.test_make_vlan_available()   A

Complexity

Conditions 1

Size

Total Lines 16
Code Lines 14

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 14
CRAP Score 1

Importance

Changes 0
Metric Value
cc 1
eloc 14
nop 1
dl 0
loc 16
ccs 14
cts 14
cp 1
crap 1
rs 9.7
c 0
b 0
f 0
1
"""Test Main methods."""
2 1
from unittest.mock import AsyncMock, MagicMock, call, patch
3
4 1
from kytos.lib.helpers import (get_controller_mock, get_kytos_event_mock,
5
                               get_switch_mock, get_test_client,
6
                               get_interface_mock)
7
8 1
from kytos.core.events import KytosEvent
9 1
from napps.kytos.of_lldp.utils import get_cookie
10 1
from tests.helpers import get_topology_mock
11
12
13 1 View Code Duplication
@patch('kytos.core.controller.Controller.get_switch_by_dpid')
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated in your project.
Loading history...
14 1
@patch('napps.kytos.of_lldp.main.Main._unpack_non_empty')
15 1
@patch('napps.kytos.of_lldp.main.UBInt32')
16 1
@patch('napps.kytos.of_lldp.main.DPID')
17 1
@patch('napps.kytos.of_lldp.main.LLDP')
18 1
@patch('napps.kytos.of_lldp.main.Ethernet')
19 1
async def test_on_ofpt_packet_in(*args):
20
    """Test on_ofpt_packet_in."""
21 1
    (mock_ethernet, mock_lldp, mock_dpid, mock_ubint32,
22
     mock_unpack_non_empty, mock_get_switch_by_dpid) = args
23
24
    # pylint: disable=bad-option-value, import-outside-toplevel
25 1
    from napps.kytos.of_lldp.main import Main
26 1
    Main.get_liveness_controller = MagicMock()
27 1
    topology = get_topology_mock()
28 1
    controller = get_controller_mock()
29 1
    controller.buffers.app.aput = AsyncMock()
30 1
    controller.switches = topology.switches
31 1
    napp = Main(controller)
32 1
    napp.loop_manager.process_if_looped = AsyncMock()
33 1
    napp.liveness_manager.consume_hello_if_enabled = AsyncMock()
34
35 1
    switch = get_switch_mock("00:00:00:00:00:00:00:01", 0x04)
36 1
    message = MagicMock(in_port=1, data='data')
37 1
    event = KytosEvent('ofpt_packet_in', content={'source': switch.connection,
38
                       'message': message})
39
40 1
    mocked, ethernet, lldp, dpid, port_b = [MagicMock() for _ in range(5)]
41 1
    mocked.value = 1
42 1
    mock_ubint32.return_value = mocked
43 1
    ethernet.ether_type = 0x88CC
44 1
    ethernet.data = 'eth_data'
45 1
    lldp.chassis_id.sub_value = 'chassis_id'
46 1
    lldp.port_id.sub_value = 'port_id'
47 1
    dpid.value = "00:00:00:00:00:00:00:02"
48 1
    port_b.value = 2
49
50 1
    mock_unpack_non_empty.side_effect = [ethernet, lldp, dpid, port_b]
51 1
    mock_get_switch_by_dpid.return_value = get_switch_mock(dpid.value,
52
                                                           0x04)
53 1
    await napp.on_ofpt_packet_in(event)
54
55 1
    calls = [call(mock_ethernet, message.data),
56
             call(mock_lldp, ethernet.data),
57
             call(mock_dpid, lldp.chassis_id.sub_value),
58
             call(mock_ubint32, lldp.port_id.sub_value)]
59 1
    mock_unpack_non_empty.assert_has_calls(calls)
60 1
    assert napp.loop_manager.process_if_looped.call_count == 1
61 1
    assert napp.liveness_manager.consume_hello_if_enabled.call_count == 1
62 1
    assert controller.buffers.app.aput.call_count == 1
63
64
65 1 View Code Duplication
@patch('kytos.core.controller.Controller.get_switch_by_dpid')
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated in your project.
Loading history...
66 1
@patch('napps.kytos.of_lldp.main.Main._unpack_non_empty')
67 1
@patch('napps.kytos.of_lldp.main.UBInt32')
68 1
@patch('napps.kytos.of_lldp.main.DPID')
69 1
@patch('napps.kytos.of_lldp.main.LLDP')
70 1
@patch('napps.kytos.of_lldp.main.Ethernet')
71 1
async def test_on_ofpt_packet_in_early_intf(*args):
72
    """Test on_ofpt_packet_in early intf return."""
73 1
    (mock_ethernet, mock_lldp, mock_dpid, mock_ubint32,
74
     mock_unpack_non_empty, mock_get_switch_by_dpid) = args
75
76
    # pylint: disable=bad-option-value, import-outside-toplevel
77 1
    from napps.kytos.of_lldp.main import Main
78 1
    Main.get_liveness_controller = MagicMock()
79 1
    topology = get_topology_mock()
80 1
    controller = get_controller_mock()
81 1
    controller.buffers.app.aput = AsyncMock()
82 1
    controller.switches = topology.switches
83 1
    napp = Main(controller)
84 1
    napp.loop_manager.process_if_looped = AsyncMock()
85 1
    napp.liveness_manager.consume_hello_if_enabled = AsyncMock()
86
87 1
    switch = get_switch_mock("00:00:00:00:00:00:00:01", 0x04)
88 1
    message = MagicMock(in_port=1, data='data')
89 1
    event = KytosEvent('ofpt_packet_in', content={'source': switch.connection,
90
                       'message': message})
91
92 1
    mocked, ethernet, lldp, dpid, port_b = [MagicMock() for _ in range(5)]
93 1
    mocked.value = 1
94 1
    mock_ubint32.return_value = mocked
95 1
    ethernet.ether_type = 0x88CC
96 1
    ethernet.data = 'eth_data'
97 1
    lldp.chassis_id.sub_value = 'chassis_id'
98 1
    lldp.port_id.sub_value = 'port_id'
99 1
    dpid.value = "00:00:00:00:00:00:00:02"
100 1
    port_b.value = 2
101
102 1
    mock_unpack_non_empty.side_effect = [ethernet, lldp, dpid, port_b]
103 1
    mock_get_switch_by_dpid.return_value = get_switch_mock(dpid.value,
104
                                                           0x04)
105 1
    switch.get_interface_by_port_no = MagicMock(return_value=None)
106 1
    await napp.on_ofpt_packet_in(event)
107
108 1
    calls = [call(mock_ethernet, message.data),
109
             call(mock_lldp, ethernet.data),
110
             call(mock_dpid, lldp.chassis_id.sub_value),
111
             call(mock_ubint32, lldp.port_id.sub_value)]
112 1
    mock_unpack_non_empty.assert_has_calls(calls)
113 1
    switch.get_interface_by_port_no.assert_called()
114
    # early return shouldn't allow these to get called
115 1
    assert napp.loop_manager.process_if_looped.call_count == 0
116 1
    assert napp.liveness_manager.consume_hello_if_enabled.call_count == 0
117 1
    assert controller.buffers.app.aput.call_count == 0
118
119
120 1
async def test_on_table_enabled():
121
    """Test on_table_enabled"""
122
    # pylint: disable=bad-option-value, import-outside-toplevel
123 1
    from napps.kytos.of_lldp.main import Main
124 1
    controller = get_controller_mock()
125 1
    controller.buffers.app.aput = AsyncMock()
126 1
    napp = Main(controller)
127
128
    # Succesfully setting table groups
129 1
    content = {"of_lldp": {"base": 123}}
130 1
    event = KytosEvent(name="kytos/of_multi_table.enable_table",
131
                       content=content)
132 1
    await napp.on_table_enabled(event)
133 1
    assert napp.table_group == content["of_lldp"]
134 1
    assert controller.buffers.app.aput.call_count == 1
135
136
    # Failure at setting table groups
137 1
    content = {"of_lldp": {"unknown": 123}}
138 1
    event = KytosEvent(name="kytos/of_multi_table.enable_table",
139
                       content=content)
140 1
    await napp.on_table_enabled(event)
141 1
    assert controller.buffers.app.aput.call_count == 1
142
143
144
# pylint: disable=protected-access,too-many-public-methods
145 1
class TestMain:
146
    """Tests for the Main class."""
147
148 1
    def setup_method(self):
149
        """Execute steps before each tests."""
150
        # patch('kytos.core.helpers.run_on_thread', lambda x: x).start()
151
        # pylint: disable=bad-option-value, import-outside-toplevel
152 1
        from napps.kytos.of_lldp.main import Main
153 1
        Main.get_liveness_controller = MagicMock()
154 1
        self.topology = get_topology_mock()
155 1
        controller = get_controller_mock()
156 1
        controller.switches = self.topology.switches
157 1
        self.base_endpoint = "kytos/of_lldp/v1"
158 1
        self.napp = Main(controller)
159 1
        self.api_client = get_test_client(controller, self.napp)
160
161 1
    def teardown_method(self) -> None:
162
        """Teardown."""
163 1
        patch.stopall()
164
165 1
    def get_topology_interfaces(self):
166
        """Return interfaces present in topology."""
167 1
        interfaces = []
168 1
        for switch in list(self.topology.switches.values()):
169 1
            interfaces += list(switch.interfaces.values())
170 1
        return interfaces
171
172 1
    @patch('napps.kytos.of_lldp.main.of_msg_prio')
173 1
    @patch('napps.kytos.of_lldp.main.KytosEvent')
174 1
    @patch('napps.kytos.of_lldp.main.VLAN')
175 1
    @patch('napps.kytos.of_lldp.main.Ethernet')
176 1
    @patch('napps.kytos.of_lldp.main.DPID')
177 1
    @patch('napps.kytos.of_lldp.main.LLDP')
178 1
    def test_execute(self, *args):
179
        """Test execute method."""
180 1
        (_, _, mock_ethernet, _, mock_kytos_event, mock_of_msg_prio) = args
181 1
        mock_buffer_put = MagicMock()
182 1
        self.napp.controller.buffers.msg_out.put = mock_buffer_put
183
184 1
        ethernet = MagicMock()
185 1
        ethernet.pack.return_value = 'pack'
186 1
        interfaces = self.get_topology_interfaces()
187 1
        po_args = [(interface.switch.connection.protocol.version,
188
                    interface.port_number, 'pack') for interface in interfaces]
189
190 1
        mock_ethernet.return_value = ethernet
191 1
        mock_kytos_event.side_effect = po_args
192
193 1
        mock_publish_stopped = MagicMock()
194 1
        self.napp.try_to_publish_stopped_loops = mock_publish_stopped
195 1
        self.napp.execute()
196
197 1
        mock_of_msg_prio.assert_called()
198 1
        mock_buffer_put.assert_has_calls([call(arg)
199
                                          for arg in po_args])
200 1
        mock_publish_stopped.assert_called()
201
202 1
    @patch('napps.kytos.of_lldp.main.Main.get_flows_by_switch')
203 1
    @patch('httpx.request')
204 1
    @patch('httpx.post')
205 1
    def test_handle_lldp_flows(self, mock_post, mock_request, mock_flows):
206
        """Test handle_lldp_flow method."""
207 1
        dpid = "00:00:00:00:00:00:00:01"
208 1
        switch = get_switch_mock("00:00:00:00:00:00:00:01", 0x04)
209 1
        self.napp.controller.switches = {dpid: switch}
210 1
        event_post = get_kytos_event_mock(name='kytos/topology.switch.enabled',
211
                                          content={'dpid': dpid})
212
213 1
        event_del = get_kytos_event_mock(name='kytos/topology.switch.disabled',
214
                                         content={'dpid': dpid})
215
216 1
        mock_post.return_value = MagicMock(status_code=202)
217 1
        mock_request.return_value = MagicMock(status_code=202)
218
219 1
        mock_flows.return_value = {}
220 1
        self.napp._handle_lldp_flows(event_post)
221 1
        mock_post.assert_called()
222
223 1
        mock_flows.return_value = {"flows": "mocked_flows"}
224 1
        self.napp._handle_lldp_flows(event_del)
225 1
        mock_request.assert_called()
226
227 1
    @patch('napps.kytos.of_lldp.main.Main.get_flows_by_switch')
228 1
    @patch("time.sleep")
229 1
    @patch("httpx.post")
230 1
    def test_handle_lldp_flows_retries(self, mock_post, _, mock_flows):
231
        """Test handle_lldp_flow method retries."""
232 1
        dpid = "00:00:00:00:00:00:00:01"
233 1
        switch = get_switch_mock("00:00:00:00:00:00:00:01", 0x04)
234 1
        mock_flows.return_value = {}
235 1
        self.napp.controller.switches = {dpid: switch}
236 1
        event_post = get_kytos_event_mock(name="kytos/topology.switch.enabled",
237
                                          content={"dpid": dpid})
238
239 1
        mock = MagicMock()
240 1
        mock.request.method = "POST"
241 1
        mock.status_code = 500
242 1
        mock.text = "some_err"
243 1
        mock_post.return_value = mock
244 1
        self.napp._handle_lldp_flows(event_post)
245 1
        assert mock_post.call_count == 3
246
247 1
    @patch('napps.kytos.of_lldp.main.PO13')
248 1
    @patch('napps.kytos.of_lldp.main.AO13')
249 1
    def test_build_lldp_packet_out(self, *args):
250
        """Test _build_lldp_packet_out method."""
251 1
        (mock_ao13, mock_po13) = args
252
253 1
        ao13 = MagicMock()
254 1
        po13 = MagicMock()
255 1
        po13.actions = []
256
257 1
        mock_ao13.return_value = ao13
258 1
        mock_po13.return_value = po13
259
260 1
        packet_out13 = self.napp._build_lldp_packet_out(0x04, 2, 'data2')
261 1
        packet_out14 = self.napp._build_lldp_packet_out(0x05, 3, 'data3')
262
263 1
        assert packet_out13.data == 'data2'
264 1
        assert packet_out13.actions == [ao13]
265 1
        assert packet_out13.actions[0].port == 2
266 1
        assert packet_out14 is None
267
268 1
    @patch('napps.kytos.of_lldp.main.settings')
269 1
    @patch('napps.kytos.of_lldp.main.EtherType')
270 1
    @patch('napps.kytos.of_lldp.main.Port13')
271 1
    def test_build_lldp_flow(self, *args):
272
        """Test _build_lldp_flow method."""
273 1
        (mock_v0x04_port, mock_ethertype,
274
         mock_settings) = args
275 1
        self.napp.vlan_id = None
276 1
        mock_v0x04_port.OFPP_CONTROLLER = 1234
277
278 1
        mock_ethertype.LLDP = 10
279 1
        mock_settings.FLOW_VLAN_VID = None
280 1
        mock_settings.FLOW_PRIORITY = 1500
281 1
        dpid = "00:00:00:00:00:00:00:01"
282
283 1
        flow = {}
284 1
        match = {}
285 1
        flow['priority'] = 1500
286 1
        flow['table_id'] = 0
287 1
        match['dl_type'] = 10
288
289 1
        flow['match'] = match
290 1
        expected_flow_v0x04 = flow.copy()
291 1
        expected_flow_v0x04['cookie'] = get_cookie(dpid)
292 1
        expected_flow_v0x04['cookie_mask'] = 0xffffffffffffffff
293
294 1
        expected_flow_v0x04['actions'] = [{'action_type': 'output',
295
                                           'port': 1234}]
296 1
        expected_flow_v0x04['table_group'] = 'base'
297 1
        expected_flow_v0x04['owner'] = 'of_lldp'
298
299 1
        flow_mod10 = self.napp._build_lldp_flow(0x01, get_cookie(dpid))
300 1
        flow_mod13 = self.napp._build_lldp_flow(0x04, get_cookie(dpid))
301
302 1
        assert flow_mod10 is None
303 1
        assert flow_mod13 == expected_flow_v0x04
304
305 1
    def test_unpack_non_empty(self):
306
        """Test _unpack_non_empty method."""
307 1
        desired_class = MagicMock()
308 1
        data = MagicMock()
309 1
        data.value = 'data'
310
311 1
        obj = self.napp._unpack_non_empty(desired_class, data)
312
313 1
        obj.unpack.assert_called_with('data')
314
315 1
    def test_get_data(self, monkeypatch):
316
        """Test _get_data method."""
317 1
        interfaces = ['00:00:00:00:00:00:00:01:1', '00:00:00:00:00:00:00:01:2']
318 1
        monkeypatch.setattr("napps.kytos.of_lldp.main.get_json_or_400",
319
                            lambda req, loop: {"interfaces": interfaces})
320 1
        data = self.napp._get_data(MagicMock())
321 1
        assert data == interfaces
322
323 1
    def test_load_liveness(self) -> None:
324
        """Test load_liveness."""
325 1
        self.napp.load_liveness()
326 1
        count = self.napp.liveness_controller.get_enabled_interfaces.call_count
327 1
        assert count == 1
328
329 1
    def test_handle_topology_loaded(self) -> None:
330
        """Test handle_topology_loaded."""
331 1
        event = KytosEvent("kytos/topology.topology_loaded",
332
                           content={"topology": {}})
333 1
        self.napp.load_liveness = MagicMock()
334 1
        self.napp.loop_manager.handle_topology_loaded = MagicMock()
335 1
        self.napp.handle_topology_loaded(event)
336 1
        assert self.napp.loop_manager.handle_topology_loaded.call_count == 1
337 1
        assert self.napp.load_liveness.call_count == 1
338
339 1
    def test_publish_liveness_status(self) -> None:
340
        """Test publish_liveness_status."""
341 1
        self.napp.controller.buffers.app.put = MagicMock()
342 1
        event_suffix, interfaces = "up", [MagicMock(id=1), MagicMock(id=2)]
343 1
        self.napp.publish_liveness_status(event_suffix, interfaces)
344 1
        assert self.napp.controller.buffers.app.put.call_count == 1
345 1
        event = self.napp.controller.buffers.app.put.call_args[0][0]
346 1
        assert event.name == f"kytos/of_lldp.liveness.{event_suffix}"
347 1
        assert event.content["interfaces"] == interfaces
348
349 1
    def test_get_interfaces(self):
350
        """Test _get_interfaces method."""
351 1
        expected_interfaces = self.get_topology_interfaces()
352 1
        interfaces = self.napp._get_interfaces()
353 1
        assert interfaces == expected_interfaces
354
355 1
    def test_get_interfaces_dict(self):
356
        """Test _get_interfaces_dict method."""
357 1
        interfaces = self.napp._get_interfaces()
358 1
        expected_interfaces = {inter.id: inter for inter in interfaces}
359 1
        interfaces_dict = self.napp._get_interfaces_dict(interfaces)
360 1
        assert interfaces_dict == expected_interfaces
361
362 1
    def test_get_lldp_interfaces(self):
363
        """Test _get_lldp_interfaces method."""
364 1
        lldp_interfaces = self.napp._get_lldp_interfaces()
365 1
        expected_interfaces = ['00:00:00:00:00:00:00:01:1',
366
                               '00:00:00:00:00:00:00:01:2',
367
                               '00:00:00:00:00:00:00:02:1',
368
                               '00:00:00:00:00:00:00:02:2']
369 1
        assert lldp_interfaces == expected_interfaces
370
371 1
    async def test_rest_get_lldp_interfaces(self):
372
        """Test get_lldp_interfaces method."""
373 1
        endpoint = f"{self.base_endpoint}/interfaces"
374 1
        response = await self.api_client.get(endpoint)
375 1
        expected_data = {"interfaces": ['00:00:00:00:00:00:00:01:1',
376
                                        '00:00:00:00:00:00:00:01:2',
377
                                        '00:00:00:00:00:00:00:02:1',
378
                                        '00:00:00:00:00:00:00:02:2']}
379 1
        assert response.status_code == 200
380 1
        assert response.json() == expected_data
381
382 1
    async def test_enable_disable_lldp_200(self, event_loop):
383
        """Test 200 response for enable_lldp and disable_lldp methods."""
384 1
        data = {"interfaces": ['00:00:00:00:00:00:00:01:1',
385
                               '00:00:00:00:00:00:00:01:2',
386
                               '00:00:00:00:00:00:00:02:1',
387
                               '00:00:00:00:00:00:00:02:2']}
388 1
        self.napp.controller.loop = event_loop
389 1
        self.napp.publish_liveness_status = MagicMock()
390 1
        endpoint = f"{self.base_endpoint}/interfaces/disable"
391 1
        response = await self.api_client.post(endpoint, json=data)
392 1
        assert response.status_code == 200
393 1
        assert self.napp.liveness_controller.disable_interfaces.call_count == 1
394 1
        assert self.napp.publish_liveness_status.call_count == 1
395 1
        endpoint = f"{self.base_endpoint}/interfaces/enable"
396 1
        response = await self.api_client.post(endpoint, json=data)
397 1
        assert response.status_code == 200
398
399 1
    async def test_enable_disable_lldp_404(self):
400
        """Test 404 response for enable_lldp and disable_lldp methods."""
401 1
        data = {"interfaces": []}
402 1
        self.napp.controller.switches = {}
403 1
        endpoint = f"{self.base_endpoint}/disable"
404 1
        response = await self.api_client.post(endpoint, json=data)
405 1
        assert response.status_code == 404
406 1
        endpoint = f"{self.base_endpoint}/enable"
407 1
        response = await self.api_client.post(endpoint, json=data)
408 1
        assert response.status_code == 404
409
410 1
    async def test_enable_disable_lldp_400(self, event_loop):
411
        """Test 400 response for enable_lldp and disable_lldp methods."""
412 1
        data = {"interfaces": ['00:00:00:00:00:00:00:01:1',
413
                               '00:00:00:00:00:00:00:01:2',
414
                               '00:00:00:00:00:00:00:02:1',
415
                               '00:00:00:00:00:00:00:02:2',
416
                               '00:00:00:00:00:00:00:03:1',
417
                               '00:00:00:00:00:00:00:03:2',
418
                               '00:00:00:00:00:00:00:04:1']}
419 1
        self.napp.controller.loop = event_loop
420 1
        self.napp.publish_liveness_status = MagicMock()
421 1
        url = f'{self.base_endpoint}/interfaces/disable'
422 1
        response = await self.api_client.post(url, json=data)
423 1
        assert response.status_code == 400
424 1
        assert self.napp.publish_liveness_status.call_count == 1
425
426 1
        url = f'{self.base_endpoint}/interfaces/enable'
427 1
        response = await self.api_client.post(url, json=data)
428 1
        assert response.status_code == 400
429
430 1
    async def test_get_time(self):
431
        """Test get polling time."""
432 1
        url = f"{self.base_endpoint}/polling_time"
433 1
        response = await self.api_client.get(url)
434 1
        assert response.status_code == 200
435
436 1
    async def test_set_polling_time(self):
437
        """Test update polling time."""
438 1
        url = f"{self.base_endpoint}/polling_time"
439 1
        data = {'polling_time': 5}
440 1
        response = await self.api_client.post(url, json=data)
441 1
        assert response.status_code == 200
442
443 1
    async def test_set_time_400(self):
444
        """Test fail case the update polling time."""
445 1
        url = f"{self.base_endpoint}/polling_time"
446 1
        data = {'polling_time': 'A'}
447 1
        response = await self.api_client.post(url, json=data)
448 1
        assert response.status_code == 400
449
450 1
    async def test_endpoint_enable_liveness(self, event_loop):
451
        """Test POST v1/liveness/enable."""
452 1
        self.napp.controller.loop = event_loop
453 1
        self.napp.liveness_manager.enable = MagicMock()
454 1
        self.napp.publish_liveness_status = MagicMock()
455 1
        url = f"{self.base_endpoint}/liveness/enable"
456 1
        data = {"interfaces": ["00:00:00:00:00:00:00:01:1"]}
457 1
        response = await self.api_client.post(url, json=data)
458 1
        assert response.status_code == 200
459 1
        assert response.json() == {}
460 1
        assert self.napp.liveness_controller.enable_interfaces.call_count == 1
461 1
        assert self.napp.liveness_manager.enable.call_count == 1
462 1
        assert self.napp.publish_liveness_status.call_count == 1
463
464 1
    async def test_endpoint_disable_liveness(self, event_loop):
465
        """Test POST v1/liveness/disable."""
466 1
        self.napp.controller.loop = event_loop
467 1
        self.napp.liveness_manager.disable = MagicMock()
468 1
        self.napp.publish_liveness_status = MagicMock()
469 1
        url = f"{self.base_endpoint}/liveness/disable"
470 1
        data = {"interfaces": ["00:00:00:00:00:00:00:01:1"]}
471 1
        response = await self.api_client.post(url, json=data)
472 1
        assert response.status_code == 200
473 1
        assert response.json() == {}
474 1
        assert self.napp.liveness_controller.disable_interfaces.call_count == 1
475 1
        assert self.napp.liveness_manager.disable.call_count == 1
476 1
        assert self.napp.publish_liveness_status.call_count == 1
477
478 1
    async def test_endpoint_get_liveness(self):
479
        """Test GET v1/liveness/."""
480 1
        self.napp.liveness_manager.enable = MagicMock()
481 1
        self.napp.publish_liveness_status = MagicMock()
482 1
        url = f"{self.base_endpoint}/liveness/"
483 1
        response = await self.api_client.get(url)
484 1
        assert response.status_code == 200
485 1
        assert response.json() == {"interfaces": []}
486
487 1
    async def test_endpoint_get_pair_liveness(self):
488
        """Test GET v1/liveness//pair."""
489 1
        self.napp.liveness_manager.enable = MagicMock()
490 1
        self.napp.publish_liveness_status = MagicMock()
491 1
        url = f"{self.base_endpoint}/liveness/pair"
492 1
        response = await self.api_client.get(url)
493 1
        assert response.status_code == 200
494 1
        assert response.json() == {"pairs": []}
495
496 1
    def test_set_flow_table_group_owner(self):
497
        """Test set_flow_table_group_owner"""
498 1
        self.napp.table_group = {"base": 2}
499 1
        flow = {}
500 1
        self.napp.set_flow_table_group_owner(flow, "base")
501 1
        assert "table_group" in flow
502 1
        assert "owner" in flow
503 1
        assert flow["table_id"] == 2
504
505 1
    def test_use_vlan(self):
506
        """Test use_vlan"""
507 1
        switch = get_switch_mock("00:00:00:00:00:00:00:01", 0x04)
508 1
        interface_a = get_interface_mock("mock_a", 1, switch)
509 1
        interface_a.use_tags = MagicMock()
510 1
        interface_b = get_interface_mock("mock_b", 2, switch)
511 1
        interface_b.use_tags = MagicMock()
512 1
        switch.interfaces = {1: interface_a, 2: interface_b}
513 1
        self.napp.use_vlan(switch)
514 1
        assert interface_a.use_tags.call_count == 1
515 1
        assert interface_b.use_tags.call_count == 1
516
517 1
        self.napp.vlan_id = None
518 1
        self.napp.use_vlan(switch)
519 1
        assert interface_a.use_tags.call_count == 1
520 1
        assert interface_b.use_tags.call_count == 1
521
522 1
    def test_make_vlan_available(self):
523
        """Test make_vlan_available"""
524 1
        switch = get_switch_mock("00:00:00:00:00:00:00:01", 0x04)
525 1
        interface_a = get_interface_mock("mock_a", 1, switch)
526 1
        interface_a.make_tags_available = MagicMock()
527 1
        interface_b = get_interface_mock("mock_b", 2, switch)
528 1
        interface_b.make_tags_available = MagicMock()
529 1
        switch.interfaces = {1: interface_a, 2: interface_b}
530 1
        self.napp.make_vlan_available(switch)
531 1
        assert interface_a.make_tags_available.call_count == 1
532 1
        assert interface_b.make_tags_available.call_count == 1
533
534 1
        self.napp.vlan_id = None
535 1
        self.napp.make_vlan_available(switch)
536 1
        assert interface_a.make_tags_available.call_count == 1
537
        assert interface_b.make_tags_available.call_count == 1
538