Merge "Scan for MAC through all devices in macvtap agent"
This commit is contained in:
commit
a6997efae6
@ -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)
|
||||||
|
@ -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())
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user