Merge "Incorporate capability for multiple mac generation"

This commit is contained in:
Zuul 2018-11-09 10:29:30 +00:00 committed by Gerrit Code Review
commit 094095b3d7
5 changed files with 26 additions and 10 deletions

View File

@ -15,6 +15,8 @@
import functools import functools
import six
from neutron_lib.api.definitions import network as net_def from neutron_lib.api.definitions import network as net_def
from neutron_lib.api.definitions import port as port_def from neutron_lib.api.definitions import port as port_def
from neutron_lib.api.definitions import subnet as subnet_def from neutron_lib.api.definitions import subnet as subnet_def
@ -88,8 +90,9 @@ class DbBasePluginCommon(common_db_mixin.CommonDbMixin):
""" """
@staticmethod @staticmethod
def _generate_mac(): def _generate_macs(mac_count=1):
return net.get_random_mac(cfg.CONF.base_mac.split(':')) mac_maker = net.random_mac_generator(cfg.CONF.base_mac.split(':'))
return [six.next(mac_maker) for x in range(mac_count)]
@db_api.CONTEXT_READER @db_api.CONTEXT_READER
def _is_mac_in_use(self, context, network_id, mac_address): def _is_mac_in_use(self, context, network_id, mac_address):

View File

@ -1274,7 +1274,7 @@ class NeutronDbPluginV2(db_base_plugin_common.DbBasePluginCommon,
raise exc.MacAddressInUse(net_id=port_data['network_id'], raise exc.MacAddressInUse(net_id=port_data['network_id'],
mac=mac_address) mac=mac_address)
else: else:
mac_address = self._generate_mac() mac_address = self._generate_macs()[0]
db_port = models_v2.Port(mac_address=mac_address, **port_data) db_port = models_v2.Port(mac_address=mac_address, **port_data)
context.session.add(db_port) context.session.add(db_port)
return db_port return db_port

View File

@ -41,7 +41,7 @@ from neutron.agent.linux import iptables_firewall
from neutron.agent.linux import utils from neutron.agent.linux import utils
from neutron.common import utils as common_utils from neutron.common import utils as common_utils
from neutron.conf.agent import common as config from neutron.conf.agent import common as config
from neutron.db import db_base_plugin_common from neutron.db import db_base_plugin_common as db_base
from neutron.plugins.ml2.drivers.linuxbridge.agent import \ from neutron.plugins.ml2.drivers.linuxbridge.agent import \
linuxbridge_neutron_agent as linuxbridge_agent linuxbridge_neutron_agent as linuxbridge_agent
from neutron.tests.common import base as common_base from neutron.tests.common import base as common_base
@ -687,8 +687,8 @@ class PortFixture(fixtures.Fixture):
super(PortFixture, self).__init__() super(PortFixture, self).__init__()
self.bridge = bridge self.bridge = bridge
self.namespace = namespace self.namespace = namespace
self.mac = ( self.mac = (mac or
mac or db_base_plugin_common.DbBasePluginCommon._generate_mac()) db_base.DbBasePluginCommon._generate_macs()[0])
self.port_id = port_id or uuidutils.generate_uuid() self.port_id = port_id or uuidutils.generate_uuid()
@abc.abstractmethod @abc.abstractmethod

View File

@ -1782,8 +1782,8 @@ fixed_ips=ip_address%%3D%s&fixed_ips=ip_address%%3D%s&fixed_ips=subnet_id%%3D%s
# simulate duplicate mac generation to make sure DBDuplicate is retried # simulate duplicate mac generation to make sure DBDuplicate is retried
responses = ['12:34:56:78:00:00', '12:34:56:78:00:00', responses = ['12:34:56:78:00:00', '12:34:56:78:00:00',
'12:34:56:78:00:01'] '12:34:56:78:00:01']
with mock.patch.object(net, 'get_random_mac', with mock.patch.object(net, 'random_mac_generator',
side_effect=responses) as grand_mac: return_value=itertools.cycle(responses)) as grand_mac:
with self.subnet() as s: with self.subnet() as s:
with self.port(subnet=s) as p1, self.port(subnet=s) as p2: with self.port(subnet=s) as p1, self.port(subnet=s) as p2:
self.assertEqual('12:34:56:78:00:00', self.assertEqual('12:34:56:78:00:00',

View File

@ -13,6 +13,7 @@
# See the License for the specific language governing permissions and # See the License for the specific language governing permissions and
# limitations under the License. # limitations under the License.
import re
import warnings import warnings
import mock import mock
@ -50,7 +51,7 @@ class Ml2DBTestCase(testlib_api.SqlTestCase):
network_obj.Network(self.ctx, id=network_id).create() network_obj.Network(self.ctx, id=network_id).create()
def _setup_neutron_port(self, network_id, port_id): def _setup_neutron_port(self, network_id, port_id):
mac_address = db_base_plugin_v2.NeutronDbPluginV2._generate_mac() mac_address = db_base_plugin_v2.NeutronDbPluginV2._generate_macs()[0]
port = port_obj.Port(self.ctx, port = port_obj.Port(self.ctx,
id=port_id, id=port_id,
network_id=network_id, network_id=network_id,
@ -287,6 +288,18 @@ class Ml2DBTestCase(testlib_api.SqlTestCase):
port['mac_address']) port['mac_address'])
self.assertEqual(port_id, observed_port.id) self.assertEqual(port_id, observed_port.id)
def test_generating_multiple_mac_addresses(self):
mac_regex = "^([0-9A-Fa-f]{2}[:-]){5}([0-9A-Fa-f]{2})$"
macs = db_base_plugin_v2.NeutronDbPluginV2._generate_macs()
self.assertEqual(1, len(macs))
self.assertIsNotNone(re.search(mac_regex, macs[0]))
macs = db_base_plugin_v2.NeutronDbPluginV2._generate_macs(5)
self.assertEqual(5, len(macs))
for mac in macs:
self.assertIsNotNone(re.search(mac_regex, mac))
class Ml2DvrDBTestCase(testlib_api.SqlTestCase): class Ml2DvrDBTestCase(testlib_api.SqlTestCase):
@ -301,7 +314,7 @@ class Ml2DvrDBTestCase(testlib_api.SqlTestCase):
ports = [] ports = []
for port_id in port_ids: for port_id in port_ids:
mac_address = (db_base_plugin_v2.NeutronDbPluginV2. mac_address = (db_base_plugin_v2.NeutronDbPluginV2.
_generate_mac()) _generate_macs()[0])
port = port_obj.Port(self.ctx, port = port_obj.Port(self.ctx,
id=port_id, id=port_id,
network_id=network_id, network_id=network_id,