Merge "Implementation of create_subnet() varies in manila-tempest-plugin"
This commit is contained in:
commit
fcef5a2b11
@ -18,6 +18,7 @@ import os
|
|||||||
import subprocess
|
import subprocess
|
||||||
|
|
||||||
import netaddr
|
import netaddr
|
||||||
|
|
||||||
from oslo_log import log
|
from oslo_log import log
|
||||||
from oslo_serialization import jsonutils as json
|
from oslo_serialization import jsonutils as json
|
||||||
from oslo_utils import netutils
|
from oslo_utils import netutils
|
||||||
@ -1098,6 +1099,8 @@ class NetworkScenarioTest(ScenarioTest):
|
|||||||
:Keyword Arguments:
|
:Keyword Arguments:
|
||||||
|
|
||||||
* *ip_version = ip version of the given network,
|
* *ip_version = ip version of the given network,
|
||||||
|
use_default_subnetpool = default subnetpool to
|
||||||
|
manage IPv6 addresses range.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
if not subnets_client:
|
if not subnets_client:
|
||||||
@ -1120,43 +1123,65 @@ class NetworkScenarioTest(ScenarioTest):
|
|||||||
network_id=ext_net['id'], cidr=cidr)['subnets'])
|
network_id=ext_net['id'], cidr=cidr)['subnets'])
|
||||||
return len(tenant_subnets + external_subnets) != 0
|
return len(tenant_subnets + external_subnets) != 0
|
||||||
|
|
||||||
|
def _make_create_subnet_request(namestart, network,
|
||||||
|
ip_version, subnets_client, **kwargs):
|
||||||
|
|
||||||
|
subnet = dict(
|
||||||
|
name=data_utils.rand_name(namestart),
|
||||||
|
network_id=network['id'],
|
||||||
|
project_id=network['project_id'],
|
||||||
|
ip_version=ip_version,
|
||||||
|
**kwargs
|
||||||
|
)
|
||||||
|
|
||||||
|
if ip_version == 6:
|
||||||
|
subnet['ipv6_address_mode'] = 'slaac'
|
||||||
|
subnet['ipv6_ra_mode'] = 'slaac'
|
||||||
|
|
||||||
|
try:
|
||||||
|
return subnets_client.create_subnet(**subnet)
|
||||||
|
except lib_exc.Conflict as e:
|
||||||
|
if 'overlaps with another subnet' not in str(e):
|
||||||
|
raise
|
||||||
|
|
||||||
|
result = None
|
||||||
|
str_cidr = None
|
||||||
|
|
||||||
|
use_default_subnetpool = kwargs.get('use_default_subnetpool', False)
|
||||||
ip_version = kwargs.pop('ip_version', 4)
|
ip_version = kwargs.pop('ip_version', 4)
|
||||||
|
|
||||||
|
if not use_default_subnetpool:
|
||||||
|
|
||||||
if ip_version == 6:
|
if ip_version == 6:
|
||||||
tenant_cidr = netaddr.IPNetwork(
|
tenant_cidr = netaddr.IPNetwork(
|
||||||
CONF.network.project_network_v6_cidr)
|
CONF.network.project_network_v6_cidr)
|
||||||
num_bits = CONF.network.project_network_v6_mask_bits
|
num_bits = CONF.network.project_network_v6_mask_bits
|
||||||
else:
|
else:
|
||||||
tenant_cidr = netaddr.IPNetwork(CONF.network.project_network_cidr)
|
tenant_cidr = netaddr.IPNetwork(
|
||||||
|
CONF.network.project_network_cidr)
|
||||||
num_bits = CONF.network.project_network_mask_bits
|
num_bits = CONF.network.project_network_mask_bits
|
||||||
|
|
||||||
result = None
|
|
||||||
str_cidr = None
|
|
||||||
# Repeatedly attempt subnet creation with sequential cidr
|
# Repeatedly attempt subnet creation with sequential cidr
|
||||||
# blocks until an unallocated block is found.
|
# blocks until an unallocated block is found.
|
||||||
for subnet_cidr in tenant_cidr.subnet(num_bits):
|
for subnet_cidr in tenant_cidr.subnet(num_bits):
|
||||||
str_cidr = str(subnet_cidr)
|
str_cidr = str(subnet_cidr)
|
||||||
if cidr_in_use(str_cidr, project_id=network['project_id']):
|
if cidr_in_use(str_cidr, project_id=network['project_id']):
|
||||||
continue
|
continue
|
||||||
|
result = _make_create_subnet_request(
|
||||||
|
namestart, network, ip_version, subnets_client,
|
||||||
|
cidr=str_cidr, **kwargs)
|
||||||
|
|
||||||
subnet = dict(
|
if result is not None:
|
||||||
name=data_utils.rand_name(namestart),
|
|
||||||
network_id=network['id'],
|
|
||||||
project_id=network['project_id'],
|
|
||||||
cidr=str_cidr,
|
|
||||||
ip_version=ip_version,
|
|
||||||
**kwargs
|
|
||||||
)
|
|
||||||
try:
|
|
||||||
result = subnets_client.create_subnet(**subnet)
|
|
||||||
break
|
break
|
||||||
except lib_exc.Conflict as e:
|
|
||||||
is_overlapping_cidr = 'overlaps with another subnet' in str(e)
|
else:
|
||||||
if not is_overlapping_cidr:
|
result = _make_create_subnet_request(
|
||||||
raise
|
namestart, network, ip_version, subnets_client,
|
||||||
|
**kwargs)
|
||||||
self.assertIsNotNone(result, 'Unable to allocate tenant network')
|
self.assertIsNotNone(result, 'Unable to allocate tenant network')
|
||||||
|
|
||||||
subnet = result['subnet']
|
subnet = result['subnet']
|
||||||
|
if str_cidr is not None:
|
||||||
self.assertEqual(subnet['cidr'], str_cidr)
|
self.assertEqual(subnet['cidr'], str_cidr)
|
||||||
|
|
||||||
self.addCleanup(test_utils.call_and_ignore_notfound_exc,
|
self.addCleanup(test_utils.call_and_ignore_notfound_exc,
|
||||||
|
Loading…
Reference in New Issue
Block a user