|
| 1 | +import unittest |
| 2 | +from unittest.mock import patch, MagicMock |
| 3 | +import subprocess |
| 4 | +import syslog |
| 5 | +import sys |
| 6 | +import mgmt_oper_status |
| 7 | + |
| 8 | +class TestMgmtOperStatusCheck(unittest.TestCase): |
| 9 | + |
| 10 | + @patch('mgmt_oper_status.SonicV2Connector') |
| 11 | + @patch('mgmt_oper_status.subprocess.run') |
| 12 | + @patch('mgmt_oper_status.syslog.syslog') |
| 13 | + def test_main_no_mgmt_ports(self, mock_syslog, mock_subprocess, mock_SonicV2Connector): |
| 14 | + mock_db = MagicMock() |
| 15 | + mock_SonicV2Connector.return_value = mock_db |
| 16 | + mock_db.keys.return_value = [] |
| 17 | + |
| 18 | + mgmt_oper_status.main() |
| 19 | + |
| 20 | + mock_syslog.assert_called_with(syslog.LOG_DEBUG, 'No management interface found') |
| 21 | + |
| 22 | + @patch('mgmt_oper_status.SonicV2Connector') |
| 23 | + @patch('mgmt_oper_status.subprocess.run') |
| 24 | + @patch('mgmt_oper_status.syslog.syslog') |
| 25 | + def test_main_with_mgmt_ports(self, mock_syslog, mock_subprocess, mock_SonicV2Connector): |
| 26 | + mock_db = MagicMock() |
| 27 | + mock_SonicV2Connector.return_value = mock_db |
| 28 | + mgmt_ports_keys = ['MGMT_PORT|eth0', 'MGMT_PORT|eth1'] |
| 29 | + mock_db.keys.return_value = mgmt_ports_keys |
| 30 | + mock_db.set.return_value = None |
| 31 | + |
| 32 | + mock_subprocess.return_value = subprocess.CompletedProcess(args=['cat', '/sys/class/net/eth0/operstate'], returncode=0, stdout='up', stderr='') |
| 33 | + |
| 34 | + mgmt_oper_status.main() |
| 35 | + |
| 36 | + mock_syslog.assert_any_call(syslog.LOG_INFO, 'mgmt_oper_status: up') |
| 37 | + mock_syslog.assert_any_call(syslog.LOG_INFO, 'mgmt_oper_status: up') |
| 38 | + |
| 39 | + mock_db.set.assert_any_call(mock_db.STATE_DB, 'MGMT_PORT_TABLE|eth0', 'oper_status', 'up') |
| 40 | + mock_db.set.assert_any_call(mock_db.STATE_DB, 'MGMT_PORT_TABLE|eth1', 'oper_status', 'up') |
| 41 | + |
| 42 | + @patch('mgmt_oper_status.SonicV2Connector') |
| 43 | + @patch('mgmt_oper_status.subprocess.run') |
| 44 | + @patch('mgmt_oper_status.syslog.syslog') |
| 45 | + def test_main_with_mgmt_port_down(self, mock_syslog, mock_subprocess, mock_SonicV2Connector): |
| 46 | + mock_db = MagicMock() |
| 47 | + mock_SonicV2Connector.return_value = mock_db |
| 48 | + mgmt_ports_keys = ['MGMT_PORT|eth0'] |
| 49 | + mock_db.keys.return_value = mgmt_ports_keys |
| 50 | + mock_db.set.return_value = None |
| 51 | + |
| 52 | + mock_subprocess.return_value = subprocess.CompletedProcess(args=['cat', '/sys/class/net/eth0/operstate'], returncode=0, stdout='down', stderr='') |
| 53 | + |
| 54 | + mgmt_oper_status.main() |
| 55 | + |
| 56 | + mock_syslog.assert_any_call(syslog.LOG_WARNING, 'mgmt_oper_status: down') |
| 57 | + |
| 58 | + mock_db.set.assert_any_call(mock_db.STATE_DB, 'MGMT_PORT_TABLE|eth0', 'oper_status', 'down') |
| 59 | + |
| 60 | + |
| 61 | + @patch('mgmt_oper_status.SonicV2Connector') |
| 62 | + @patch('mgmt_oper_status.subprocess.run') |
| 63 | + @patch('mgmt_oper_status.syslog.syslog') |
| 64 | + def test_main_exception_handling(self, mock_syslog, mock_subprocess, mock_SonicV2Connector): |
| 65 | + mock_db = MagicMock() |
| 66 | + mock_SonicV2Connector.return_value = mock_db |
| 67 | + mgmt_ports_keys = ['MGMT_PORT|eth0'] |
| 68 | + mock_db.keys.return_value = mgmt_ports_keys |
| 69 | + mock_db.set.return_value = None |
| 70 | + |
| 71 | + mock_subprocess.side_effect = Exception("File not found") |
| 72 | + |
| 73 | + mgmt_oper_status.main() |
| 74 | + |
| 75 | + mock_syslog.assert_called_with(syslog.LOG_ERR, "mgmt_oper_status exception : File not found") |
| 76 | + mock_db.set.assert_any_call(mock_db.STATE_DB, 'MGMT_PORT_TABLE|eth0', 'oper_status', 'unknown') |
| 77 | + |
| 78 | +if __name__ == '__main__': |
| 79 | + unittest.main() |
0 commit comments