Merge "Support tagging Neutron ports on creation"
This commit is contained in:
commit
51aee432d9
@ -91,6 +91,7 @@
|
|||||||
neutron-segments: true
|
neutron-segments: true
|
||||||
q-metering: true
|
q-metering: true
|
||||||
q-qos: true
|
q-qos: true
|
||||||
|
neutron-tag-ports-during-bulk-creation: true
|
||||||
tox_envlist: functional
|
tox_envlist: functional
|
||||||
|
|
||||||
- job:
|
- job:
|
||||||
|
@ -480,12 +480,23 @@ class CreatePort(command.ShowOne):
|
|||||||
if parsed_args.qos_policy:
|
if parsed_args.qos_policy:
|
||||||
attrs['qos_policy_id'] = client.find_qos_policy(
|
attrs['qos_policy_id'] = client.find_qos_policy(
|
||||||
parsed_args.qos_policy, ignore_missing=False).id
|
parsed_args.qos_policy, ignore_missing=False).id
|
||||||
|
|
||||||
|
set_tags_in_post = bool(
|
||||||
|
client.find_extension('tag-ports-during-bulk-creation'))
|
||||||
|
if set_tags_in_post:
|
||||||
|
if parsed_args.no_tag:
|
||||||
|
attrs['tags'] = []
|
||||||
|
if parsed_args.tags:
|
||||||
|
attrs['tags'] = list(set(parsed_args.tags))
|
||||||
|
|
||||||
with common.check_missing_extension_if_error(
|
with common.check_missing_extension_if_error(
|
||||||
self.app.client_manager.network, attrs):
|
self.app.client_manager.network, attrs):
|
||||||
obj = client.create_port(**attrs)
|
obj = client.create_port(**attrs)
|
||||||
|
|
||||||
|
if not set_tags_in_post:
|
||||||
# tags cannot be set when created, so tags need to be set later.
|
# tags cannot be set when created, so tags need to be set later.
|
||||||
_tag.update_tags_for_set(client, obj, parsed_args)
|
_tag.update_tags_for_set(client, obj, parsed_args)
|
||||||
|
|
||||||
display_columns, columns = _get_columns(obj)
|
display_columns, columns = _get_columns(obj)
|
||||||
data = utils.get_item_properties(obj, columns, formatters=_formatters)
|
data = utils.get_item_properties(obj, columns, formatters=_formatters)
|
||||||
|
|
||||||
|
@ -121,6 +121,7 @@ class TestCreatePort(TestPort):
|
|||||||
self.network.find_network = mock.Mock(return_value=fake_net)
|
self.network.find_network = mock.Mock(return_value=fake_net)
|
||||||
self.fake_subnet = network_fakes.FakeSubnet.create_one_subnet()
|
self.fake_subnet = network_fakes.FakeSubnet.create_one_subnet()
|
||||||
self.network.find_subnet = mock.Mock(return_value=self.fake_subnet)
|
self.network.find_subnet = mock.Mock(return_value=self.fake_subnet)
|
||||||
|
self.network.find_extension = mock.Mock(return_value=[])
|
||||||
# Get the command object to test
|
# Get the command object to test
|
||||||
self.cmd = port.CreatePort(self.app, self.namespace)
|
self.cmd = port.CreatePort(self.app, self.namespace)
|
||||||
|
|
||||||
@ -536,7 +537,7 @@ class TestCreatePort(TestPort):
|
|||||||
'name': 'test-port',
|
'name': 'test-port',
|
||||||
})
|
})
|
||||||
|
|
||||||
def _test_create_with_tag(self, add_tags=True):
|
def _test_create_with_tag(self, add_tags=True, add_tags_in_post=True):
|
||||||
arglist = [
|
arglist = [
|
||||||
'--network', self._port.network_id,
|
'--network', self._port.network_id,
|
||||||
'test-port',
|
'test-port',
|
||||||
@ -555,9 +556,33 @@ class TestCreatePort(TestPort):
|
|||||||
else:
|
else:
|
||||||
verifylist.append(('no_tag', True))
|
verifylist.append(('no_tag', True))
|
||||||
|
|
||||||
|
self.network.find_extension = mock.Mock(return_value=add_tags_in_post)
|
||||||
|
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
columns, data = (self.cmd.take_action(parsed_args))
|
columns, data = (self.cmd.take_action(parsed_args))
|
||||||
|
|
||||||
|
args = {
|
||||||
|
'admin_state_up': True,
|
||||||
|
'network_id': self._port.network_id,
|
||||||
|
'name': 'test-port',
|
||||||
|
}
|
||||||
|
if add_tags_in_post:
|
||||||
|
if add_tags:
|
||||||
|
args['tags'] = sorted(['red', 'blue'])
|
||||||
|
else:
|
||||||
|
args['tags'] = []
|
||||||
|
self.network.create_port.assert_called_once()
|
||||||
|
# Now we need to verify if arguments to call create_port are as
|
||||||
|
# expected,
|
||||||
|
# But we can't simply use assert_called_once_with() method because
|
||||||
|
# duplicates from 'tags' are removed with
|
||||||
|
# list(set(parsed_args.tags)) and that don't quarantee order of
|
||||||
|
# tags list which is used to call create_port().
|
||||||
|
create_port_call_kwargs = self.network.create_port.call_args[1]
|
||||||
|
create_port_call_kwargs['tags'] = sorted(
|
||||||
|
create_port_call_kwargs['tags'])
|
||||||
|
self.assertDictEqual(args, create_port_call_kwargs)
|
||||||
|
else:
|
||||||
self.network.create_port.assert_called_once_with(
|
self.network.create_port.assert_called_once_with(
|
||||||
admin_state_up=True,
|
admin_state_up=True,
|
||||||
network_id=self._port.network_id,
|
network_id=self._port.network_id,
|
||||||
@ -569,14 +594,21 @@ class TestCreatePort(TestPort):
|
|||||||
tests_utils.CompareBySet(['red', 'blue']))
|
tests_utils.CompareBySet(['red', 'blue']))
|
||||||
else:
|
else:
|
||||||
self.assertFalse(self.network.set_tags.called)
|
self.assertFalse(self.network.set_tags.called)
|
||||||
|
|
||||||
self.assertEqual(self.columns, columns)
|
self.assertEqual(self.columns, columns)
|
||||||
self.assertItemEqual(self.data, data)
|
self.assertItemEqual(self.data, data)
|
||||||
|
|
||||||
def test_create_with_tags(self):
|
def test_create_with_tags(self):
|
||||||
self._test_create_with_tag(add_tags=True)
|
self._test_create_with_tag(add_tags=True, add_tags_in_post=True)
|
||||||
|
|
||||||
def test_create_with_no_tag(self):
|
def test_create_with_no_tag(self):
|
||||||
self._test_create_with_tag(add_tags=False)
|
self._test_create_with_tag(add_tags=False, add_tags_in_post=True)
|
||||||
|
|
||||||
|
def test_create_with_tags_using_put(self):
|
||||||
|
self._test_create_with_tag(add_tags=True, add_tags_in_post=False)
|
||||||
|
|
||||||
|
def test_create_with_no_tag_using_put(self):
|
||||||
|
self._test_create_with_tag(add_tags=False, add_tags_in_post=False)
|
||||||
|
|
||||||
def _test_create_with_uplink_status_propagation(self, enable=True):
|
def _test_create_with_uplink_status_propagation(self, enable=True):
|
||||||
arglist = [
|
arglist = [
|
||||||
|
Loading…
x
Reference in New Issue
Block a user