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

TestMain.test_used_unused_vlan()   A

Complexity

Conditions 1

Size

Total Lines 26
Code Lines 23

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 23
CRAP Score 1

Importance

Changes 0
Metric Value
cc 1
eloc 23
nop 1
dl 0
loc 26
ccs 23
cts 23
cp 1
crap 1
rs 9.328
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.used_unused_vlan')
203 1
    @patch('requests.delete')
204 1
    @patch('requests.post')
205 1
    def test_handle_lldp_flows(self, mock_post, mock_delete, use_vlan_mock):
206
        """Test handle_lldp_flow method."""
207 1
        use_vlan_mock.return_value = True
208 1
        dpid = "00:00:00:00:00:00:00:01"
209 1
        switch = get_switch_mock("00:00:00:00:00:00:00:01", 0x04)
210 1
        self.napp.controller.switches = {dpid: switch}
211 1
        event_post = get_kytos_event_mock(name='kytos/topology.switch.enabled',
212
                                          content={'dpid': dpid})
213
214 1
        event_del = get_kytos_event_mock(name='kytos/topology.switch.disabled',
215
                                         content={'dpid': dpid})
216
217 1
        mock_post.return_value = MagicMock(status_code=202)
218 1
        mock_delete.return_value = MagicMock(status_code=202)
219
220 1
        self.napp._handle_lldp_flows(event_post)
221 1
        mock_post.assert_called()
222
223 1
        self.napp._handle_lldp_flows(event_del)
224 1
        mock_delete.assert_called()
225
226 1
    @patch("time.sleep")
227 1
    @patch("requests.post")
228 1
    def test_handle_lldp_flows_retries(self, mock_post, _):
229
        """Test handle_lldp_flow method retries."""
230 1
        dpid = "00:00:00:00:00:00:00:01"
231 1
        switch = get_switch_mock("00:00:00:00:00:00:00:01", 0x04)
232 1
        self.napp.controller.switches = {dpid: switch}
233 1
        event_post = get_kytos_event_mock(name="kytos/topology.switch.enabled",
234
                                          content={"dpid": dpid})
235
236 1
        mock = MagicMock()
237 1
        mock.request.method = "POST"
238 1
        mock.status_code = 500
239 1
        mock.text = "some_err"
240 1
        mock_post.return_value = mock
241 1
        self.napp._handle_lldp_flows(event_post)
242 1
        assert mock_post.call_count == 3
243
244 1
    @patch('napps.kytos.of_lldp.main.PO13')
245 1
    @patch('napps.kytos.of_lldp.main.AO13')
246 1
    def test_build_lldp_packet_out(self, *args):
247
        """Test _build_lldp_packet_out method."""
248 1
        (mock_ao13, mock_po13) = args
249
250 1
        ao13 = MagicMock()
251 1
        po13 = MagicMock()
252 1
        po13.actions = []
253
254 1
        mock_ao13.return_value = ao13
255 1
        mock_po13.return_value = po13
256
257 1
        packet_out13 = self.napp._build_lldp_packet_out(0x04, 2, 'data2')
258 1
        packet_out14 = self.napp._build_lldp_packet_out(0x05, 3, 'data3')
259
260 1
        assert packet_out13.data == 'data2'
261 1
        assert packet_out13.actions == [ao13]
262 1
        assert packet_out13.actions[0].port == 2
263 1
        assert packet_out14 is None
264
265 1
    @patch('napps.kytos.of_lldp.main.settings')
266 1
    @patch('napps.kytos.of_lldp.main.EtherType')
267 1
    @patch('napps.kytos.of_lldp.main.Port13')
268 1
    def test_build_lldp_flow(self, *args):
269
        """Test _build_lldp_flow method."""
270 1
        (mock_v0x04_port, mock_ethertype,
271
         mock_settings) = args
272 1
        self.napp.vlan_id = None
273 1
        mock_v0x04_port.OFPP_CONTROLLER = 1234
274
275 1
        mock_ethertype.LLDP = 10
276 1
        mock_settings.FLOW_VLAN_VID = None
277 1
        mock_settings.FLOW_PRIORITY = 1500
278 1
        dpid = "00:00:00:00:00:00:00:01"
279
280 1
        flow = {}
281 1
        match = {}
282 1
        flow['priority'] = 1500
283 1
        flow['table_id'] = 0
284 1
        match['dl_type'] = 10
285
286 1
        flow['match'] = match
287 1
        expected_flow_v0x04 = flow.copy()
288 1
        expected_flow_v0x04['cookie'] = get_cookie(dpid)
289 1
        expected_flow_v0x04['cookie_mask'] = 0xffffffffffffffff
290
291 1
        expected_flow_v0x04['actions'] = [{'action_type': 'output',
292
                                           'port': 1234}]
293 1
        expected_flow_v0x04['table_group'] = 'base'
294 1
        expected_flow_v0x04['owner'] = 'of_lldp'
295
296 1
        flow_mod10 = self.napp._build_lldp_flow(0x01, get_cookie(dpid))
297 1
        flow_mod13 = self.napp._build_lldp_flow(0x04, get_cookie(dpid))
298
299 1
        assert flow_mod10 is None
300 1
        assert flow_mod13 == expected_flow_v0x04
301
302 1
    def test_unpack_non_empty(self):
303
        """Test _unpack_non_empty method."""
304 1
        desired_class = MagicMock()
305 1
        data = MagicMock()
306 1
        data.value = 'data'
307
308 1
        obj = self.napp._unpack_non_empty(desired_class, data)
309
310 1
        obj.unpack.assert_called_with('data')
311
312 1
    def test_get_data(self, monkeypatch):
313
        """Test _get_data method."""
314 1
        interfaces = ['00:00:00:00:00:00:00:01:1', '00:00:00:00:00:00:00:01:2']
315 1
        monkeypatch.setattr("napps.kytos.of_lldp.main.get_json_or_400",
316
                            lambda req, loop: {"interfaces": interfaces})
317 1
        data = self.napp._get_data(MagicMock())
318 1
        assert data == interfaces
319
320 1
    def test_load_liveness(self) -> None:
321
        """Test load_liveness."""
322 1
        self.napp.load_liveness()
323 1
        count = self.napp.liveness_controller.get_enabled_interfaces.call_count
324 1
        assert count == 1
325
326 1
    def test_handle_topology_loaded(self) -> None:
327
        """Test handle_topology_loaded."""
328 1
        event = KytosEvent("kytos/topology.topology_loaded",
329
                           content={"topology": {}})
330 1
        self.napp.load_liveness = MagicMock()
331 1
        self.napp.loop_manager.handle_topology_loaded = MagicMock()
332 1
        self.napp.handle_topology_loaded(event)
333 1
        assert self.napp.loop_manager.handle_topology_loaded.call_count == 1
334 1
        assert self.napp.load_liveness.call_count == 1
335
336 1
    def test_publish_liveness_status(self) -> None:
337
        """Test publish_liveness_status."""
338 1
        self.napp.controller.buffers.app.put = MagicMock()
339 1
        event_suffix, interfaces = "up", [MagicMock(id=1), MagicMock(id=2)]
340 1
        self.napp.publish_liveness_status(event_suffix, interfaces)
341 1
        assert self.napp.controller.buffers.app.put.call_count == 1
342 1
        event = self.napp.controller.buffers.app.put.call_args[0][0]
343 1
        assert event.name == f"kytos/of_lldp.liveness.{event_suffix}"
344 1
        assert event.content["interfaces"] == interfaces
345
346 1
    def test_get_interfaces(self):
347
        """Test _get_interfaces method."""
348 1
        expected_interfaces = self.get_topology_interfaces()
349 1
        interfaces = self.napp._get_interfaces()
350 1
        assert interfaces == expected_interfaces
351
352 1
    def test_get_interfaces_dict(self):
353
        """Test _get_interfaces_dict method."""
354 1
        interfaces = self.napp._get_interfaces()
355 1
        expected_interfaces = {inter.id: inter for inter in interfaces}
356 1
        interfaces_dict = self.napp._get_interfaces_dict(interfaces)
357 1
        assert interfaces_dict == expected_interfaces
358
359 1
    def test_get_lldp_interfaces(self):
360
        """Test _get_lldp_interfaces method."""
361 1
        lldp_interfaces = self.napp._get_lldp_interfaces()
362 1
        expected_interfaces = ['00:00:00:00:00:00:00:01:1',
363
                               '00:00:00:00:00:00:00:01:2',
364
                               '00:00:00:00:00:00:00:02:1',
365
                               '00:00:00:00:00:00:00:02:2']
366 1
        assert lldp_interfaces == expected_interfaces
367
368 1
    async def test_rest_get_lldp_interfaces(self):
369
        """Test get_lldp_interfaces method."""
370 1
        endpoint = f"{self.base_endpoint}/interfaces"
371 1
        response = await self.api_client.get(endpoint)
372 1
        expected_data = {"interfaces": ['00:00:00:00:00:00:00:01:1',
373
                                        '00:00:00:00:00:00:00:01:2',
374
                                        '00:00:00:00:00:00:00:02:1',
375
                                        '00:00:00:00:00:00:00:02:2']}
376 1
        assert response.status_code == 200
377 1
        assert response.json() == expected_data
378
379 1
    async def test_enable_disable_lldp_200(self, event_loop):
380
        """Test 200 response for enable_lldp and disable_lldp methods."""
381 1
        data = {"interfaces": ['00:00:00:00:00:00:00:01:1',
382
                               '00:00:00:00:00:00:00:01:2',
383
                               '00:00:00:00:00:00:00:02:1',
384
                               '00:00:00:00:00:00:00:02:2']}
385 1
        self.napp.controller.loop = event_loop
386 1
        self.napp.publish_liveness_status = MagicMock()
387 1
        endpoint = f"{self.base_endpoint}/interfaces/disable"
388 1
        response = await self.api_client.post(endpoint, json=data)
389 1
        assert response.status_code == 200
390 1
        assert self.napp.liveness_controller.disable_interfaces.call_count == 1
391 1
        assert self.napp.publish_liveness_status.call_count == 1
392 1
        endpoint = f"{self.base_endpoint}/interfaces/enable"
393 1
        response = await self.api_client.post(endpoint, json=data)
394 1
        assert response.status_code == 200
395
396 1
    async def test_enable_disable_lldp_404(self):
397
        """Test 404 response for enable_lldp and disable_lldp methods."""
398 1
        data = {"interfaces": []}
399 1
        self.napp.controller.switches = {}
400 1
        endpoint = f"{self.base_endpoint}/disable"
401 1
        response = await self.api_client.post(endpoint, json=data)
402 1
        assert response.status_code == 404
403 1
        endpoint = f"{self.base_endpoint}/enable"
404 1
        response = await self.api_client.post(endpoint, json=data)
405 1
        assert response.status_code == 404
406
407 1
    async def test_enable_disable_lldp_400(self, event_loop):
408
        """Test 400 response for enable_lldp and disable_lldp methods."""
409 1
        data = {"interfaces": ['00:00:00:00:00:00:00:01:1',
410
                               '00:00:00:00:00:00:00:01:2',
411
                               '00:00:00:00:00:00:00:02:1',
412
                               '00:00:00:00:00:00:00:02:2',
413
                               '00:00:00:00:00:00:00:03:1',
414
                               '00:00:00:00:00:00:00:03:2',
415
                               '00:00:00:00:00:00:00:04:1']}
416 1
        self.napp.controller.loop = event_loop
417 1
        self.napp.publish_liveness_status = MagicMock()
418 1
        url = f'{self.base_endpoint}/interfaces/disable'
419 1
        response = await self.api_client.post(url, json=data)
420 1
        assert response.status_code == 400
421 1
        assert self.napp.publish_liveness_status.call_count == 1
422
423 1
        url = f'{self.base_endpoint}/interfaces/enable'
424 1
        response = await self.api_client.post(url, json=data)
425 1
        assert response.status_code == 400
426
427 1
    async def test_get_time(self):
428
        """Test get polling time."""
429 1
        url = f"{self.base_endpoint}/polling_time"
430 1
        response = await self.api_client.get(url)
431 1
        assert response.status_code == 200
432
433 1
    async def test_set_polling_time(self):
434
        """Test update polling time."""
435 1
        url = f"{self.base_endpoint}/polling_time"
436 1
        data = {'polling_time': 5}
437 1
        response = await self.api_client.post(url, json=data)
438 1
        assert response.status_code == 200
439
440 1
    async def test_set_time_400(self):
441
        """Test fail case the update polling time."""
442 1
        url = f"{self.base_endpoint}/polling_time"
443 1
        data = {'polling_time': 'A'}
444 1
        response = await self.api_client.post(url, json=data)
445 1
        assert response.status_code == 400
446
447 1
    async def test_endpoint_enable_liveness(self, event_loop):
448
        """Test POST v1/liveness/enable."""
449 1
        self.napp.controller.loop = event_loop
450 1
        self.napp.liveness_manager.enable = MagicMock()
451 1
        self.napp.publish_liveness_status = MagicMock()
452 1
        url = f"{self.base_endpoint}/liveness/enable"
453 1
        data = {"interfaces": ["00:00:00:00:00:00:00:01:1"]}
454 1
        response = await self.api_client.post(url, json=data)
455 1
        assert response.status_code == 200
456 1
        assert response.json() == {}
457 1
        assert self.napp.liveness_controller.enable_interfaces.call_count == 1
458 1
        assert self.napp.liveness_manager.enable.call_count == 1
459 1
        assert self.napp.publish_liveness_status.call_count == 1
460
461 1
    async def test_endpoint_disable_liveness(self, event_loop):
462
        """Test POST v1/liveness/disable."""
463 1
        self.napp.controller.loop = event_loop
464 1
        self.napp.liveness_manager.disable = MagicMock()
465 1
        self.napp.publish_liveness_status = MagicMock()
466 1
        url = f"{self.base_endpoint}/liveness/disable"
467 1
        data = {"interfaces": ["00:00:00:00:00:00:00:01:1"]}
468 1
        response = await self.api_client.post(url, json=data)
469 1
        assert response.status_code == 200
470 1
        assert response.json() == {}
471 1
        assert self.napp.liveness_controller.disable_interfaces.call_count == 1
472 1
        assert self.napp.liveness_manager.disable.call_count == 1
473 1
        assert self.napp.publish_liveness_status.call_count == 1
474
475 1
    async def test_endpoint_get_liveness(self):
476
        """Test GET v1/liveness/."""
477 1
        self.napp.liveness_manager.enable = MagicMock()
478 1
        self.napp.publish_liveness_status = MagicMock()
479 1
        url = f"{self.base_endpoint}/liveness/"
480 1
        response = await self.api_client.get(url)
481 1
        assert response.status_code == 200
482 1
        assert response.json() == {"interfaces": []}
483
484 1
    async def test_endpoint_get_pair_liveness(self):
485
        """Test GET v1/liveness//pair."""
486 1
        self.napp.liveness_manager.enable = MagicMock()
487 1
        self.napp.publish_liveness_status = MagicMock()
488 1
        url = f"{self.base_endpoint}/liveness/pair"
489 1
        response = await self.api_client.get(url)
490 1
        assert response.status_code == 200
491 1
        assert response.json() == {"pairs": []}
492
493 1
    def test_set_flow_table_group_owner(self):
494
        """Test set_flow_table_group_owner"""
495 1
        self.napp.table_group = {"base": 2}
496 1
        flow = {}
497 1
        self.napp.set_flow_table_group_owner(flow, "base")
498 1
        assert "table_group" in flow
499 1
        assert "owner" in flow
500 1
        assert flow["table_id"] == 2
501
502 1
    def test_used_unused_vlan(self):
503
        """Test used_unused_vlan"""
504 1
        event_name = "kytos/topology.switch.enabled"
505 1
        switch = get_switch_mock("00:00:00:00:00:00:00:01", 0x04)
506 1
        interface_a = get_interface_mock("mock_a", 1, switch)
507 1
        interface_a.use_tags = MagicMock()
508 1
        interface_b = get_interface_mock("mock_b", 2, switch)
509 1
        interface_b.use_tags = MagicMock()
510 1
        switch.interfaces = {1: interface_a, 2: interface_b}
511 1
        self.napp.used_unused_vlan(switch, event_name)
512 1
        assert interface_a.use_tags.call_count == 1
513 1
        assert interface_b.use_tags.call_count == 1
514
515 1
        event_name = "kytos/topology.switch.disabled"
516 1
        interface_a.make_tags_available = MagicMock()
517 1
        interface_b.make_tags_available = MagicMock()
518 1
        self.napp.used_unused_vlan(switch, event_name)
519 1
        assert interface_a.make_tags_available.call_count == 1
520 1
        assert interface_b.make_tags_available.call_count == 1
521
522 1
        self.napp.vlan_id = None
523 1
        self.napp.used_unused_vlan(switch, event_name)
524 1
        assert interface_a.use_tags.call_count == 1
525 1
        assert interface_b.use_tags.call_count == 1
526 1
        assert interface_a.make_tags_available.call_count == 1
527
        assert interface_b.make_tags_available.call_count == 1
528