Merge "Incorporate capability for multiple mac generation"
This commit is contained in:
commit
094095b3d7
@ -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):
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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',
|
||||||
|
@ -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,
|
||||||
|
Loading…
Reference in New Issue
Block a user