Merge "Allow specification of only neutron net without subnet"

This commit is contained in:
Jenkins 2017-08-05 02:25:30 +00:00 committed by Gerrit Code Review
commit 30fab2df12
4 changed files with 66 additions and 71 deletions

View File

@ -56,8 +56,7 @@ def get_project_assigned_network(request):
return []
def get_available_networks(request, include_subnets=True,
filter=None, murano_networks=None):
def get_available_networks(request, filter=None, murano_networks=None):
if murano_networks:
env_names = [e.name for e in env_api.environments_list(request)]
@ -94,21 +93,20 @@ def get_available_networks(request, include_subnets=True,
else:
netname = _("Network of '%s'") % env
if include_subnets:
for subnet in net.subnets:
if not netname:
full_name = (
"%(net)s: %(cidr)s %(subnet)s" %
dict(net=net.name_or_id,
cidr=subnet.cidr,
subnet=subnet.name_or_id))
for subnet in net.subnets:
if not netname:
full_name = (
"%(net)s: %(cidr)s %(subnet)s" %
dict(net=net.name_or_id,
cidr=subnet.cidr,
subnet=subnet.name_or_id))
network_choices.append(
((net.id, subnet.id), netname or full_name))
network_choices.append(
((net.id, subnet.id), netname or full_name))
else:
netname = netname or net.name_or_id
network_choices.append(((net.id, None), netname))
netname = _("%s: random subnet") % (
netname or net.name_or_id)
network_choices.append(((net.id, None), netname))
return network_choices

View File

@ -490,7 +490,6 @@ class ImageChoiceField(ChoiceField):
class NetworkChoiceField(ChoiceField):
def __init__(self,
include_subnets=True,
filter=None,
murano_networks=None,
allow_auto=True,
@ -501,7 +500,6 @@ class NetworkChoiceField(ChoiceField):
if murano_networks.lower() not in ["exclude", "translate"]:
raise ValueError(_("Invalid value of 'murano_nets' option"))
self.murano_networks = murano_networks
self.include_subnets = include_subnets
self.allow_auto = allow_auto
super(NetworkChoiceField, self).__init__(*args,
**kwargs)
@ -514,7 +512,6 @@ class NetworkChoiceField(ChoiceField):
rendered
"""
network_choices = net.get_available_networks(request,
self.include_subnets,
self.filter,
self.murano_networks)
if self.allow_auto:

View File

@ -51,12 +51,12 @@ class TestNet(testtools.TestCase):
test_filter = '^foo\-[\w]+'
result = net.get_available_networks(self.mock_request,
include_subnets=True,
filter=test_filter,
murano_networks='include')
expected_result = [
(('foo-network-id', 'foo-subnet-id'), "Network of 'foo'")
(('foo-network-id', 'foo-subnet-id'), "Network of 'foo'"),
(('foo-network-id', None), "Network of 'foo': random subnet"),
]
self.assertEqual(expected_result, result)
@ -84,14 +84,15 @@ class TestNet(testtools.TestCase):
test_filter = '^[\w]+\-[\w]+'
result = net.get_available_networks(self.mock_request,
include_subnets=True,
filter=test_filter,
murano_networks='include')
expected_result = [
(('foo-network-id', 'foo-subnet-id'), "Network of 'foo'"),
(('foo-network-id', None), "Network of 'foo': random subnet"),
(('bar-network-id', 'bar-subnet-id'),
'bar-network: 255.0.0.0 bar-subnet')
'bar-network: 255.0.0.0 bar-subnet'),
(('bar-network-id', None), "bar-network: random subnet"),
]
self.assertEqual(expected_result, result)
@ -101,60 +102,60 @@ class TestNet(testtools.TestCase):
self.mock_request)
@mock.patch.object(net, 'neutron', autospec=True)
def test_get_available_networks_with_exclude(self, mock_neutron):
foo_mock_network = mock.Mock(router__external=False,
id='foo-network-id',
subnets=[mock.Mock(id='foo-subnet-id')])
foo_mock_network.configure_mock(name='foo-network')
bar_mock_subnet = mock.Mock(
id='bar-subnet-id', name_or_id='bar-subnet', cidr='255.0.0.0')
bar_mock_network = mock.Mock(router__external=False,
id='bar-network-id',
name_or_id='bar-network',
subnets=[bar_mock_subnet])
bar_mock_network.configure_mock(name='bar-network')
def test_get_available_networks(self, mock_neutron):
foo_subnets = [
type('%s-subnet' % k, (object, ),
{'id': '%s-subnet-id' % k, 'cidr': '255.0.0.0',
'name_or_id': '%s-name-or-id' % k})
for k in ('fake1', 'fake2')]
bar_subnets = [
type('fake3-subnet', (object, ),
{'id': 'fake3-subnet-id', 'cidr': '255.255.0.0',
'name_or_id': 'fake3-name-or-id'})]
foo_network = type('FooNetwork', (object, ), {
'router__external': False,
'id': 'foo-network-id',
'subnets': foo_subnets,
'name': 'foo-network-name',
'name_or_id': 'foo-network-name-or-id',
})
bar_network = type('BarNetwork', (object, ), {
'router__external': False,
'id': 'bar-network-id',
'subnets': bar_subnets,
'name': 'bar-network-name',
'name_or_id': 'bar-network-name-or-id',
})
mock_neutron.network_list_for_tenant.return_value = [
foo_mock_network, bar_mock_network
foo_network, bar_network,
]
result = net.get_available_networks(self.mock_request,
include_subnets=True,
filter=None,
murano_networks='exclude')
result = net.get_available_networks(
self.mock_request, filter=None, murano_networks='exclude')
expected_result = [
(('bar-network-id', 'bar-subnet-id'),
'bar-network: 255.0.0.0 bar-subnet')
((foo_network.id, foo_subnets[0].id),
'%s: %s %s' % (
foo_network.name_or_id, foo_subnets[0].cidr,
foo_subnets[0].name_or_id)),
((foo_network.id, foo_subnets[1].id),
'%s: %s %s' % (
foo_network.name_or_id, foo_subnets[1].cidr,
foo_subnets[1].name_or_id)),
((foo_network.id, None),
'%s: random subnet' % foo_network.name_or_id),
((bar_network.id, bar_subnets[0].id),
'%s: %s %s' % (
bar_network.name_or_id, bar_subnets[0].cidr,
bar_subnets[0].name_or_id)),
((bar_network.id, None),
'%s: random subnet' % bar_network.name_or_id),
]
self.assertEqual(expected_result, result)
mock_neutron.network_list_for_tenant.assert_called_once_with(
self.mock_request, tenant_id='foo_tenant_id')
self.mock_env_api.environments_list.assert_called_once_with(
self.mock_request)
@mock.patch.object(net, 'neutron', autospec=True)
def test_get_available_networks_without_include_subnet(self, mock_neutron):
mock_netwok = mock.Mock(router__external=False,
id='foo-network-id',
subnets=[mock.Mock(id='foo-subnet-id')])
mock_netwok.configure_mock(name='foo-network')
mock_neutron.network_list_for_tenant.return_value = [
mock_netwok
]
result = net.get_available_networks(self.mock_request,
include_subnets=False,
filter=None,
murano_networks='include')
# Subnet specified in mock_network should be None with include_subnets
# set to False.
expected_result = [
(('foo-network-id', None), "Network of 'foo'")
]
self.assertEqual(expected_result, result)
self.assertIsInstance(result, list)
self.assertEqual(len(expected_result), len(result))
for choice in expected_result:
self.assertIn(choice, result)
mock_neutron.network_list_for_tenant.assert_called_once_with(
self.mock_request, tenant_id='foo_tenant_id')
self.mock_env_api.environments_list.assert_called_once_with(

View File

@ -648,7 +648,6 @@ class TestNetworkChoiceField(testtools.TestCase):
def setUp(self):
super(TestNetworkChoiceField, self).setUp()
self.network_choice_field = fields.NetworkChoiceField(
include_subnets=True,
filter=None,
murano_networks='exclude',
allow_auto=True)
@ -667,7 +666,7 @@ class TestNetworkChoiceField(testtools.TestCase):
self.network_choice_field.update(self.request)
self.assertEqual(expected_choices, self.network_choice_field.choices)
mock_net.get_available_networks.assert_called_once_with(
self.request['request'], True, None, 'exclude')
self.request['request'], None, 'exclude')
def test_to_python(self):
self.assertEqual({'foo': 'bar'},