Merge "Scan for MAC through all devices in macvtap agent"

This commit is contained in:
Zuul 2018-11-03 12:11:18 +00:00 committed by Gerrit Code Review
commit a6997efae6
2 changed files with 18 additions and 7 deletions

View File

@ -112,10 +112,10 @@ class MacvtapManager(amb.CommonAgentManagerBase):
def get_agent_id(self): def get_agent_id(self):
devices = ip_lib.IPWrapper().get_devices(True) devices = ip_lib.IPWrapper().get_devices(True)
if devices: for device in devices:
mac = ip_lib.get_device_mac(devices[0].name) mac = ip_lib.get_device_mac(device.name)
if mac:
return 'macvtap%s' % mac.replace(":", "") return 'macvtap%s' % mac.replace(":", "")
else:
LOG.error("Unable to obtain MAC address for unique ID. " LOG.error("Unable to obtain MAC address for unique ID. "
"Agent terminated!") "Agent terminated!")
sys.exit(1) sys.exit(1)

View File

@ -146,6 +146,17 @@ class TestMacvtapManager(base.BaseTestCase):
self.mgr.get_agent_id() self.mgr.get_agent_id()
mock_exit.assert_called_once_with(1) mock_exit.assert_called_once_with(1)
def test_get_agent_id_no_mac(self):
mock_devices = [ip_lib.IPDevice('macvtap0'),
ip_lib.IPDevice('macvtap1')]
with mock.patch.object(ip_lib.IPWrapper, 'get_devices',
return_value=mock_devices),\
mock.patch.object(ip_lib, 'get_device_mac',
side_effect=[None, 'foo:bar:1']) as mock_gdm:
self.assertEqual('macvtapfoobar1', self.mgr.get_agent_id())
mock_gdm.assert_has_calls([mock.call('macvtap0'),
mock.call('macvtap1')])
def test_get_extension_driver_type(self): def test_get_extension_driver_type(self):
self.assertEqual('macvtap', self.mgr.get_extension_driver_type()) self.assertEqual('macvtap', self.mgr.get_extension_driver_type())