Update trunk tests to use create_trunk method.

Change-Id: I5eed63cf454596c1b58f1ec9546669c03f234341
This commit is contained in:
Federico Ressi 2018-07-05 13:10:42 +02:00
parent 55dfb3193c
commit c9f5ec58ce
5 changed files with 189 additions and 272 deletions

View File

@ -212,13 +212,7 @@ class TagTrunkTestJSON(TagTestJSON):
def _create_resource(cls): def _create_resource(cls):
network = cls.create_network() network = cls.create_network()
parent_port = cls.create_port(network) parent_port = cls.create_port(network)
trunk = cls.client.create_trunk(parent_port['id'], None) return cls.create_trunk(parent_port)['id']
return trunk['trunk']['id']
@classmethod
def resource_cleanup(cls):
cls.client.delete_trunk(cls.res_id)
super(TagTrunkTestJSON, cls).resource_cleanup()
@decorators.attr(type='smoke') @decorators.attr(type='smoke')
@decorators.idempotent_id('4c63708b-c4c3-407c-8101-7a9593882f5f') @decorators.idempotent_id('4c63708b-c4c3-407c-8101-7a9593882f5f')
@ -467,14 +461,7 @@ class TagFilterTrunkTestJSON(TagFilterTestJSON):
def _create_resource(cls): def _create_resource(cls):
network = cls.create_network() network = cls.create_network()
parent_port = cls.create_port(network) parent_port = cls.create_port(network)
trunk = cls.client.create_trunk(parent_port['id'], None) return cls.create_trunk(parent_port)['id']
return trunk['trunk']['id']
@classmethod
def resource_cleanup(cls):
for res_id in cls.res_ids:
cls.client.delete_trunk(res_id)
super(TagFilterTrunkTestJSON, cls).resource_cleanup()
def _list_resource(self, filters): def _list_resource(self, filters):
res = self.client.list_trunks(**filters) res = self.client.list_trunks(**filters)

View File

@ -14,7 +14,6 @@
from tempest.common import utils from tempest.common import utils
from tempest.lib.common.utils import data_utils from tempest.lib.common.utils import data_utils
from tempest.lib.common.utils import test_utils
from tempest.lib import decorators from tempest.lib import decorators
from tempest.lib import exceptions as lib_exc from tempest.lib import exceptions as lib_exc
@ -22,18 +21,7 @@ from neutron_tempest_plugin.api import base
from neutron_tempest_plugin import config from neutron_tempest_plugin import config
def trunks_cleanup(client, trunks): CONF = config.CONF
for trunk in trunks:
# NOTE(armax): deleting a trunk with subports is permitted, however
# for testing purposes it is safer to be explicit and clean all the
# resources associated with the trunk beforehand.
subports = test_utils.call_and_ignore_notfound_exc(
client.get_subports, trunk['id'])
if subports:
client.remove_subports(
trunk['id'], subports['sub_ports'])
test_utils.call_and_ignore_notfound_exc(
client.delete_trunk, trunk['id'])
class TrunkTestJSONBase(base.BaseAdminNetworkTest): class TrunkTestJSONBase(base.BaseAdminNetworkTest):
@ -41,51 +29,51 @@ class TrunkTestJSONBase(base.BaseAdminNetworkTest):
required_extensions = ['trunk'] required_extensions = ['trunk']
def setUp(self): def setUp(self):
base.BaseAdminNetworkTest.setUp(self)
# This avoids problems due to user quotas
self.resource_setup()
self.addCleanup(self.resource_cleanup) self.addCleanup(self.resource_cleanup)
super(TrunkTestJSONBase, self).setUp()
@classmethod
def resource_setup(cls):
super(TrunkTestJSONBase, cls).resource_setup()
cls.trunks = []
@classmethod
def resource_cleanup(cls):
trunks_cleanup(cls.client, cls.trunks)
super(TrunkTestJSONBase, cls).resource_cleanup()
@classmethod @classmethod
def is_type_driver_enabled(cls, type_driver): def is_type_driver_enabled(cls, type_driver):
return (type_driver in return (type_driver in
config.CONF.neutron_plugin_options.available_type_drivers) CONF.neutron_plugin_options.available_type_drivers)
def _create_trunk_with_network_and_parent( @classmethod
self, subports, parent_network_type=None, **kwargs): def _create_trunk_with_network_and_parent(cls, subports=None,
parent_network_type=None,
**kwargs):
client = None client = None
network_kwargs = {} network_kwargs = {}
if parent_network_type: if parent_network_type:
client = self.admin_client client = cls.admin_client
network_kwargs = {"provider:network_type": parent_network_type, network_kwargs = {"provider:network_type": parent_network_type,
"tenant_id": self.client.tenant_id} "tenant_id": cls.client.tenant_id}
network = self.create_network(client=client, **network_kwargs) network = cls.create_network(client=client, **network_kwargs)
parent_port = self.create_port(network) parent_port = cls.create_port(network)
trunk = self.client.create_trunk(parent_port['id'], subports, **kwargs) return cls.create_trunk(parent_port, subports, **kwargs)
self.trunks.append(trunk['trunk'])
return trunk
def _show_trunk(self, trunk_id): @classmethod
return self.client.show_trunk(trunk_id) def _show_trunk(cls, trunk):
client = trunk.get('client') or cls.client
return client.show_trunk(trunk['id'])['trunk']
def _list_trunks(self): @classmethod
return self.client.list_trunks() def _update_trunk(cls, trunk, **kwargs):
client = trunk.get('client') or cls.client
return client.update_trunk(trunk['id'], **kwargs)['trunk']
@classmethod
def _list_trunks(cls):
return cls.client.list_trunks()['trunks']
class TrunkTestJSON(TrunkTestJSONBase): class TrunkTestJSON(TrunkTestJSONBase):
def _test_create_trunk(self, subports): def _test_create_trunk(self, subports):
trunk = self._create_trunk_with_network_and_parent(subports) trunk = self._create_trunk_with_network_and_parent(subports)
observed_trunk = self._show_trunk(trunk['trunk']['id']) observed_trunk = self._show_trunk(trunk)
self.assertEqual(trunk, observed_trunk) self.assertEqual(trunk, dict(observed_trunk, client=trunk['client']))
@decorators.idempotent_id('e1a6355c-4768-41f3-9bf8-0f1d192bd501') @decorators.idempotent_id('e1a6355c-4768-41f3-9bf8-0f1d192bd501')
def test_create_trunk_empty_subports_list(self): def test_create_trunk_empty_subports_list(self):
@ -97,79 +85,69 @@ class TrunkTestJSON(TrunkTestJSONBase):
@decorators.idempotent_id('7de46c22-e2b6-4959-ac5a-0e624632ab32') @decorators.idempotent_id('7de46c22-e2b6-4959-ac5a-0e624632ab32')
def test_create_show_delete_trunk(self): def test_create_show_delete_trunk(self):
trunk = self._create_trunk_with_network_and_parent(None) trunk = self._create_trunk_with_network_and_parent()
trunk_id = trunk['trunk']['id'] observed_trunk = self._show_trunk(trunk)
parent_port_id = trunk['trunk']['port_id'] self.assertEqual(trunk, dict(observed_trunk, client=trunk['client']))
res = self._show_trunk(trunk_id) self.delete_trunk(trunk)
self.assertEqual(trunk_id, res['trunk']['id']) self.assertRaises(lib_exc.NotFound, self._show_trunk, trunk)
self.assertEqual(parent_port_id, res['trunk']['port_id'])
self.client.delete_trunk(trunk_id)
self.assertRaises(lib_exc.NotFound, self._show_trunk, trunk_id)
@decorators.idempotent_id('8d83a6ca-662d-45b8-8062-d513077296aa') @decorators.idempotent_id('8d83a6ca-662d-45b8-8062-d513077296aa')
@utils.requires_ext(extension="project-id", service="network") @utils.requires_ext(extension="project-id", service="network")
def test_show_trunk_has_project_id(self): def test_show_trunk_has_project_id(self):
trunk = self._create_trunk_with_network_and_parent(None) trunk = self._create_trunk_with_network_and_parent()
body = self._show_trunk(trunk['trunk']['id']) observed_trunk = self._show_trunk(trunk)
show_trunk = body['trunk'] for key in ['project_id', 'tenant_id']:
self.assertIn('project_id', show_trunk) self.assertIn(key, observed_trunk)
self.assertIn('tenant_id', show_trunk) self.assertEqual(self.client.tenant_id, observed_trunk[key])
self.assertEqual(self.client.tenant_id, show_trunk['project_id'])
self.assertEqual(self.client.tenant_id, show_trunk['tenant_id'])
@decorators.idempotent_id('4ce46c22-a2b6-4659-bc5a-0ef2463cab32') @decorators.idempotent_id('4ce46c22-a2b6-4659-bc5a-0ef2463cab32')
def test_create_update_trunk(self): def test_create_update_trunk(self):
trunk = self._create_trunk_with_network_and_parent(None) trunk = self._create_trunk_with_network_and_parent()
rev = trunk['trunk']['revision_number'] observed_trunk = self._show_trunk(trunk)
trunk_id = trunk['trunk']['id'] self.assertTrue(observed_trunk['admin_state_up'])
res = self._show_trunk(trunk_id) self.assertEqual(trunk['revision_number'],
self.assertTrue(res['trunk']['admin_state_up']) observed_trunk['revision_number'])
self.assertEqual(rev, res['trunk']['revision_number']) self.assertEqual("", observed_trunk['name'])
self.assertEqual("", res['trunk']['name']) self.assertEqual("", observed_trunk['description'])
self.assertEqual("", res['trunk']['description']) updated_trunk = self._update_trunk(trunk, name='foo',
res = self.client.update_trunk( admin_state_up=False)
trunk_id, name='foo', admin_state_up=False) self.assertFalse(updated_trunk['admin_state_up'])
self.assertFalse(res['trunk']['admin_state_up']) self.assertEqual("foo", updated_trunk['name'])
self.assertEqual("foo", res['trunk']['name']) self.assertGreater(updated_trunk['revision_number'],
self.assertGreater(res['trunk']['revision_number'], rev) trunk['revision_number'])
# enable the trunk so that it can be managed
self.client.update_trunk(trunk_id, admin_state_up=True)
@decorators.idempotent_id('5ff46c22-a2b6-5559-bc5a-0ef2463cab32') @decorators.idempotent_id('5ff46c22-a2b6-5559-bc5a-0ef2463cab32')
def test_create_update_trunk_with_description(self): def test_create_update_trunk_with_description(self):
trunk = self._create_trunk_with_network_and_parent( trunk = self._create_trunk_with_network_and_parent(
None, description="foo description") description="foo description")
trunk_id = trunk['trunk']['id'] self.assertEqual("foo description", trunk['description'])
self.assertEqual("foo description", trunk['trunk']['description']) updated_trunk = self._update_trunk(trunk, description='')
trunk = self.client.update_trunk(trunk_id, description='') self.assertEqual('', updated_trunk['description'])
self.assertEqual('', trunk['trunk']['description'])
@decorators.idempotent_id('73365f73-bed6-42cd-960b-ec04e0c99d85') @decorators.idempotent_id('73365f73-bed6-42cd-960b-ec04e0c99d85')
def test_list_trunks(self): def test_list_trunks(self):
trunk1 = self._create_trunk_with_network_and_parent(None) trunk1 = self._create_trunk_with_network_and_parent()
trunk2 = self._create_trunk_with_network_and_parent(None) trunk2 = self._create_trunk_with_network_and_parent()
expected_trunks = {trunk1['trunk']['id']: trunk1['trunk'], expected_trunks = {trunk1['id']: trunk1,
trunk2['trunk']['id']: trunk2['trunk']} trunk2['id']: trunk2}
trunk_list = self._list_trunks()['trunks'] observed_trunks = {trunk['id']: dict(trunk, client=self.client)
matched_trunks = [x for x in trunk_list if x['id'] in expected_trunks] for trunk in self._list_trunks()
self.assertEqual(2, len(matched_trunks)) if trunk['id'] in expected_trunks}
for trunk in matched_trunks: self.assertEqual(expected_trunks, observed_trunks)
self.assertEqual(expected_trunks[trunk['id']], trunk)
@decorators.idempotent_id('bb5fcead-09b5-484a-bbe6-46d1e06d6cc0') @decorators.idempotent_id('bb5fcead-09b5-484a-bbe6-46d1e06d6cc0')
def test_add_subport(self): def test_add_subports(self):
trunk = self._create_trunk_with_network_and_parent([]) trunk = self._create_trunk_with_network_and_parent()
network = self.create_network() network = self.create_network()
port = self.create_port(network) port = self.create_port(network)
subports = [{'port_id': port['id'], subports = [{'port_id': port['id'],
'segmentation_type': 'vlan', 'segmentation_type': 'vlan',
'segmentation_id': 2}] 'segmentation_id': 2}]
self.client.add_subports(trunk['trunk']['id'], subports) added_subports = self.client.add_subports(trunk['id'],
trunk = self._show_trunk(trunk['trunk']['id']) subports)['sub_ports']
observed_subports = trunk['trunk']['sub_ports'] self.assertEqual(subports, added_subports)
self.assertEqual(1, len(observed_subports)) observed_trunk = self._show_trunk(trunk)
created_subport = observed_subports[0] self.assertEqual(subports, observed_trunk['sub_ports'])
self.assertEqual(subports[0], created_subport)
@decorators.idempotent_id('ee5fcead-1abf-483a-bce6-43d1e06d6aa0') @decorators.idempotent_id('ee5fcead-1abf-483a-bce6-43d1e06d6aa0')
def test_delete_trunk_with_subport_is_allowed(self): def test_delete_trunk_with_subport_is_allowed(self):
@ -179,38 +157,27 @@ class TrunkTestJSON(TrunkTestJSONBase):
'segmentation_type': 'vlan', 'segmentation_type': 'vlan',
'segmentation_id': 2}] 'segmentation_id': 2}]
trunk = self._create_trunk_with_network_and_parent(subports) trunk = self._create_trunk_with_network_and_parent(subports)
self.client.delete_trunk(trunk['trunk']['id']) self.client.delete_trunk(trunk['id'])
@decorators.idempotent_id('96eea398-a03c-4c3e-a99e-864392c2ca53') @decorators.idempotent_id('96eea398-a03c-4c3e-a99e-864392c2ca53')
def test_remove_subport(self): def test_remove_subport(self):
subport_parent1 = self.create_port(self.create_network()) subport1 = {'port_id': self.create_port(self.create_network())['id'],
subport_parent2 = self.create_port(self.create_network()) 'segmentation_type': 'vlan',
subports = [{'port_id': subport_parent1['id'], 'segmentation_id': 2}
'segmentation_type': 'vlan', subport2 = {'port_id': self.create_port(self.create_network())['id'],
'segmentation_id': 2}, 'segmentation_type': 'vlan',
{'port_id': subport_parent2['id'], 'segmentation_id': 4}
'segmentation_type': 'vlan', trunk = self._create_trunk_with_network_and_parent([subport1,
'segmentation_id': 4}] subport2])
trunk = self._create_trunk_with_network_and_parent(subports)
removed_subport = trunk['trunk']['sub_ports'][0]
expected_subport = None
for subport in subports:
if subport['port_id'] != removed_subport['port_id']:
expected_subport = subport
break
# Remove the subport and validate PUT response # Remove the subport and validate PUT response
res = self.client.remove_subports(trunk['trunk']['id'], subports_after_remove = self.client.remove_subports(
[removed_subport]) trunk['id'], [subport2])['sub_ports']
self.assertEqual(1, len(res['sub_ports'])) self.assertEqual([subport1], subports_after_remove)
self.assertEqual(expected_subport, res['sub_ports'][0])
# Validate the results of a subport list # Validate the results of a subport list
trunk = self._show_trunk(trunk['trunk']['id']) observed_trunk = self._show_trunk(trunk)
observed_subports = trunk['trunk']['sub_ports'] self.assertEqual([subport1], observed_trunk['sub_ports'])
self.assertEqual(1, len(observed_subports))
self.assertEqual(expected_subport, observed_subports[0])
@decorators.idempotent_id('bb5fcaad-09b5-484a-dde6-4cd1ea6d6ff0') @decorators.idempotent_id('bb5fcaad-09b5-484a-dde6-4cd1ea6d6ff0')
def test_get_subports(self): def test_get_subports(self):
@ -220,9 +187,8 @@ class TrunkTestJSON(TrunkTestJSONBase):
'segmentation_type': 'vlan', 'segmentation_type': 'vlan',
'segmentation_id': 2}] 'segmentation_id': 2}]
trunk = self._create_trunk_with_network_and_parent(subports) trunk = self._create_trunk_with_network_and_parent(subports)
trunk = self.client.get_subports(trunk['trunk']['id']) observed_subports = self.client.get_subports(trunk['id'])['sub_ports']
observed_subports = trunk['sub_ports'] self.assertEqual(subports, observed_subports)
self.assertEqual(1, len(observed_subports))
class TrunkTestInheritJSONBase(TrunkTestJSONBase): class TrunkTestInheritJSONBase(TrunkTestJSONBase):
@ -233,41 +199,43 @@ class TrunkTestInheritJSONBase(TrunkTestJSONBase):
def skip_checks(cls): def skip_checks(cls):
super(TrunkTestInheritJSONBase, cls).skip_checks() super(TrunkTestInheritJSONBase, cls).skip_checks()
if ("vlan" not in if ("vlan" not in
config.CONF.neutron_plugin_options.available_type_drivers): CONF.neutron_plugin_options.available_type_drivers):
raise cls.skipException("VLAN type_driver is not enabled") raise cls.skipException("VLAN type_driver is not enabled")
if not config.CONF.neutron_plugin_options.provider_vlans: if not CONF.neutron_plugin_options.provider_vlans:
raise cls.skipException("No provider VLAN networks available") raise cls.skipException("No provider VLAN networks available")
def create_provider_network(self): def create_provider_network(self):
foo_net = config.CONF.neutron_plugin_options.provider_vlans[0] foo_net = CONF.neutron_plugin_options.provider_vlans[0]
return self.create_network(name=data_utils.rand_name('vlan-net'), return self.create_network(name=data_utils.rand_name('vlan-net'),
provider_network_type='vlan', provider_network_type='vlan',
provider_physical_network=foo_net) provider_physical_network=foo_net)
@decorators.idempotent_id('0f05d98e-41f5-4629-dada-9aee269c9602') @decorators.idempotent_id('0f05d98e-41f5-4629-dada-9aee269c9602')
def test_add_subport(self): def test_add_subport(self):
trunk_network = self.create_provider_network() parent_network = self.create_provider_network()
trunk_port = self.create_port(trunk_network) parent_port = self.create_port(parent_network)
subport_networks = [ subport_network1 = self.create_provider_network()
self.create_provider_network(), segmentation_id1 = subport_network1['provider:segmentation_id']
self.create_provider_network(), subport_network2 = self.create_provider_network()
] segmentation_id2 = subport_network2['provider:segmentation_id']
subport1 = self.create_port(subport_networks[0]) subport1 = self.create_port(subport_network1)
subport2 = self.create_port(subport_networks[1]) subport2 = self.create_port(subport_network2)
subports = [{'port_id': subport1['id'], subports = [{'port_id': subport1['id'],
'segmentation_type': 'inherit', 'segmentation_type': 'inherit'},
'segmentation_id': subport1['id']},
{'port_id': subport2['id'], {'port_id': subport2['id'],
'segmentation_type': 'inherit', 'segmentation_type': 'inherit'}]
'segmentation_id': subport2['id']}]
trunk = self.client.create_trunk(trunk_port['id'], subports)['trunk'] trunk = self.create_trunk(parent_port, subports)
self.trunks.append(trunk)
expected_subports = [{'port_id': subport1['id'],
'segmentation_type': 'vlan',
'segmentation_id': segmentation_id1},
{'port_id': subport2['id'],
'segmentation_type': 'vlan',
'segmentation_id': segmentation_id2}]
# Validate that subport got segmentation details from the network # Validate that subport got segmentation details from the network
for i in range(2): self.assertEqual(expected_subports, trunk['sub_ports'])
self.assertEqual(subport_networks[i]['provider:network_type'],
trunk['sub_ports'][i]['segmentation_type'])
self.assertEqual(subport_networks[i]['provider:segmentation_id'],
trunk['sub_ports'][i]['segmentation_id'])
class TrunkTestMtusJSONBase(TrunkTestJSONBase): class TrunkTestMtusJSONBase(TrunkTestJSONBase):
@ -306,19 +274,16 @@ class TrunkTestMtusJSON(TrunkTestMtusJSONBase):
'segmentation_type': 'vlan', 'segmentation_type': 'vlan',
'segmentation_id': 2}] 'segmentation_id': 2}]
trunk = self.client.create_trunk(self.larger_mtu_port['id'], subports) self.create_trunk(self.larger_mtu_port, subports)
self.trunks.append(trunk['trunk'])
@decorators.idempotent_id('2004c5c6-e557-4c43-8100-c820ad4953e8') @decorators.idempotent_id('2004c5c6-e557-4c43-8100-c820ad4953e8')
def test_add_subport_with_mtu_smaller_than_trunk(self): def test_add_subport_with_mtu_greater_than_subport(self):
subports = [{'port_id': self.smaller_mtu_port['id'], subports = [{'port_id': self.smaller_mtu_port['id'],
'segmentation_type': 'vlan', 'segmentation_type': 'vlan',
'segmentation_id': 2}] 'segmentation_id': 2}]
trunk = self.client.create_trunk(self.larger_mtu_port['id'], None) trunk = self.create_trunk(self.larger_mtu_port)
self.trunks.append(trunk['trunk']) self.client.add_subports(trunk['id'], subports)
self.client.add_subports(trunk['trunk']['id'], subports)
@decorators.idempotent_id('22725101-f4bc-4e00-84ec-4e02cd7e0500') @decorators.idempotent_id('22725101-f4bc-4e00-84ec-4e02cd7e0500')
def test_create_trunk_with_mtu_equal_to_subport(self): def test_create_trunk_with_mtu_equal_to_subport(self):
@ -326,9 +291,7 @@ class TrunkTestMtusJSON(TrunkTestMtusJSONBase):
'segmentation_type': 'vlan', 'segmentation_type': 'vlan',
'segmentation_id': 2}] 'segmentation_id': 2}]
trunk = self.client.create_trunk(self.smaller_mtu_port_2['id'], self.create_trunk(self.smaller_mtu_port_2, subports)
subports)
self.trunks.append(trunk['trunk'])
@decorators.idempotent_id('175b05ae-66ad-44c7-857a-a12d16f1058f') @decorators.idempotent_id('175b05ae-66ad-44c7-857a-a12d16f1058f')
def test_add_subport_with_mtu_equal_to_trunk(self): def test_add_subport_with_mtu_equal_to_trunk(self):
@ -336,10 +299,8 @@ class TrunkTestMtusJSON(TrunkTestMtusJSONBase):
'segmentation_type': 'vlan', 'segmentation_type': 'vlan',
'segmentation_id': 2}] 'segmentation_id': 2}]
trunk = self.client.create_trunk(self.smaller_mtu_port_2['id'], None) trunk = self.create_trunk(self.smaller_mtu_port_2)
self.trunks.append(trunk['trunk']) self.client.add_subports(trunk['id'], subports)
self.client.add_subports(trunk['trunk']['id'], subports)
class TrunksSearchCriteriaTest(base.BaseSearchCriteriaTest): class TrunksSearchCriteriaTest(base.BaseSearchCriteriaTest):
@ -350,17 +311,10 @@ class TrunksSearchCriteriaTest(base.BaseSearchCriteriaTest):
@classmethod @classmethod
def resource_setup(cls): def resource_setup(cls):
super(TrunksSearchCriteriaTest, cls).resource_setup() super(TrunksSearchCriteriaTest, cls).resource_setup()
cls.trunks = []
net = cls.create_network(network_name='trunk-search-test-net') net = cls.create_network(network_name='trunk-search-test-net')
for name in cls.resource_names: for name in cls.resource_names:
parent_port = cls.create_port(net) parent_port = cls.create_port(net)
trunk = cls.client.create_trunk(parent_port['id'], [], name=name) cls.create_trunk(parent_port, name=name)
cls.trunks.append(trunk['trunk'])
@classmethod
def resource_cleanup(cls):
trunks_cleanup(cls.client, cls.trunks)
super(TrunksSearchCriteriaTest, cls).resource_cleanup()
@decorators.idempotent_id('fab73df4-960a-4ae3-87d3-60992b8d3e2d') @decorators.idempotent_id('fab73df4-960a-4ae3-87d3-60992b8d3e2d')
def test_list_sorts_asc(self): def test_list_sorts_asc(self):

View File

@ -23,14 +23,13 @@ class TestTrunkDetailsJSON(test_trunk.TrunkTestJSONBase):
@decorators.idempotent_id('f0bed24f-d36a-498b-b4e7-0d66e3fb7308') @decorators.idempotent_id('f0bed24f-d36a-498b-b4e7-0d66e3fb7308')
def test_port_resource_trunk_details_no_subports(self): def test_port_resource_trunk_details_no_subports(self):
trunk = self._create_trunk_with_network_and_parent([]) trunk = self._create_trunk_with_network_and_parent()
port = self.client.show_port(trunk['trunk']['port_id']) parent_port = self.client.show_port(trunk['port_id'])['port']
observed_trunk_details = parent_port.get('trunk_details')
expected_trunk_details = {'sub_ports': [], expected_trunk_details = {'sub_ports': [],
'trunk_id': trunk['trunk']['id']} 'trunk_id': trunk['id']}
observed_trunk_details = port['port'].get('trunk_details')
self.assertIsNotNone(observed_trunk_details) self.assertIsNotNone(observed_trunk_details)
self.assertEqual(expected_trunk_details, self.assertEqual(expected_trunk_details, observed_trunk_details)
observed_trunk_details)
@decorators.idempotent_id('544bcaf2-86fb-4930-93ab-ece1c3cc33df') @decorators.idempotent_id('544bcaf2-86fb-4930-93ab-ece1c3cc33df')
def test_port_resource_trunk_details_with_subport(self): def test_port_resource_trunk_details_with_subport(self):
@ -40,19 +39,19 @@ class TestTrunkDetailsJSON(test_trunk.TrunkTestJSONBase):
'segmentation_type': 'vlan', 'segmentation_type': 'vlan',
'segmentation_id': 2} 'segmentation_id': 2}
trunk = self._create_trunk_with_network_and_parent([subport_data]) trunk = self._create_trunk_with_network_and_parent([subport_data])
subport_data['mac_address'] = subport['mac_address'] parent_port = self.client.show_port(trunk['port_id'])['port']
parent_port = self.client.show_port(trunk['trunk']['port_id']) observed_trunk_details = parent_port.get('trunk_details')
expected_trunk_details = {'sub_ports': [subport_data], expected_subport_data = dict(subport_data,
'trunk_id': trunk['trunk']['id']} mac_address=subport['mac_address'])
observed_trunk_details = parent_port['port'].get('trunk_details') expected_trunk_details = {'sub_ports': [expected_subport_data],
'trunk_id': trunk['id']}
self.assertIsNotNone(observed_trunk_details) self.assertIsNotNone(observed_trunk_details)
self.assertEqual(expected_trunk_details, self.assertEqual(expected_trunk_details, observed_trunk_details)
observed_trunk_details)
@decorators.idempotent_id('fe6d865f-1d5c-432e-b65d-904157172f24') @decorators.idempotent_id('fe6d865f-1d5c-432e-b65d-904157172f24')
def test_port_resource_empty_trunk_details(self): def test_port_resource_empty_trunk_details(self):
network = self.create_network() network = self.create_network()
port = self.create_port(network) port = self.create_port(network)
port = self.client.show_port(port['id']) observed_port = self.client.show_port(port['id'])['port']
observed_trunk_details = port['port'].get('trunk_details') observed_trunk_details = observed_port.get('trunk_details')
self.assertIsNone(observed_trunk_details) self.assertIsNone(observed_trunk_details)

View File

@ -19,6 +19,9 @@ from tempest.lib import exceptions as lib_exc
import testtools import testtools
from neutron_tempest_plugin.api import test_trunk from neutron_tempest_plugin.api import test_trunk
from neutron_tempest_plugin import config
CONF = config.CONF
class TrunkTestJSON(test_trunk.TrunkTestJSONBase): class TrunkTestJSON(test_trunk.TrunkTestJSONBase):
@ -43,9 +46,9 @@ class TrunkTestJSON(test_trunk.TrunkTestJSONBase):
@decorators.attr(type='negative') @decorators.attr(type='negative')
@decorators.idempotent_id('a5c5200a-72a0-43c5-a11a-52f808490344') @decorators.idempotent_id('a5c5200a-72a0-43c5-a11a-52f808490344')
def test_create_subport_nonexistent_port_id(self): def test_create_subport_nonexistent_port_id(self):
trunk = self._create_trunk_with_network_and_parent([]) trunk = self._create_trunk_with_network_and_parent()
self.assertRaises(lib_exc.NotFound, self.client.add_subports, self.assertRaises(lib_exc.NotFound, self.client.add_subports,
trunk['trunk']['id'], trunk['id'],
[{'port_id': uuidutils.generate_uuid(), [{'port_id': uuidutils.generate_uuid(),
'segmentation_type': 'vlan', 'segmentation_type': 'vlan',
'segmentation_id': 2}]) 'segmentation_id': 2}])
@ -64,11 +67,11 @@ class TrunkTestJSON(test_trunk.TrunkTestJSONBase):
@decorators.attr(type='negative') @decorators.attr(type='negative')
@decorators.idempotent_id('7e0f99ab-fe37-408b-a889-9e44ef300084') @decorators.idempotent_id('7e0f99ab-fe37-408b-a889-9e44ef300084')
def test_create_subport_missing_segmentation_id(self): def test_create_subport_missing_segmentation_id(self):
trunk = self._create_trunk_with_network_and_parent([]) trunk = self._create_trunk_with_network_and_parent()
subport_network = self.create_network() subport_network = self.create_network()
parent_port = self.create_port(subport_network) parent_port = self.create_port(subport_network)
self.assertRaises(lib_exc.BadRequest, self.client.add_subports, self.assertRaises(lib_exc.BadRequest, self.client.add_subports,
trunk['trunk']['id'], trunk['id'],
[{'port_id': parent_port['id'], [{'port_id': parent_port['id'],
'segmentation_type': 'vlan'}]) 'segmentation_type': 'vlan'}])
@ -109,41 +112,43 @@ class TrunkTestJSON(test_trunk.TrunkTestJSONBase):
if not self.is_type_driver_enabled('vxlan'): if not self.is_type_driver_enabled('vxlan'):
msg = "Vxlan type driver must be enabled for this test." msg = "Vxlan type driver must be enabled for this test."
raise self.skipException(msg) raise self.skipException(msg)
if not CONF.neutron_plugin_options.provider_vlans:
raise self.skipException("No provider VLAN networks available")
trunk = self._create_trunk_with_network_and_parent( trunk = self._create_trunk_with_network_and_parent(
subports=[], parent_network_type='vxlan') parent_network_type='vxlan')
subport_network = self.create_network() subport_network = self.create_network()
parent_port = self.create_port(subport_network) subport = self.create_port(subport_network)
self.assertRaises(lib_exc.BadRequest, self.client.add_subports, self.assertRaises(lib_exc.BadRequest, self.client.add_subports,
trunk['trunk']['id'], trunk['id'],
[{'port_id': parent_port['id'], [{'port_id': subport['id'],
'segmentation_type': 'inherit', 'segmentation_type': 'inherit',
'segmentation_id': -1}]) 'segmentation_id': -1}])
@decorators.attr(type='negative') @decorators.attr(type='negative')
@decorators.idempotent_id('40aed9be-e976-47d0-a555-bde2c7e74e57') @decorators.idempotent_id('40aed9be-e976-47d0-a555-bde2c7e74e57')
def test_create_trunk_duplicate_subport_segmentation_ids(self): def test_create_trunk_duplicate_subport_segmentation_ids(self):
trunk = self._create_trunk_with_network_and_parent([]) trunk = self._create_trunk_with_network_and_parent()
subport_network1 = self.create_network() subport_network1 = self.create_network()
subport_network2 = self.create_network() subport_network2 = self.create_network()
parent_port1 = self.create_port(subport_network1) subport1 = self.create_port(subport_network1)
parent_port2 = self.create_port(subport_network2) subport2 = self.create_port(subport_network2)
self.assertRaises(lib_exc.BadRequest, self.client.create_trunk, self.assertRaises(lib_exc.BadRequest, self.client.create_trunk,
trunk['trunk']['id'], trunk['id'],
[{'port_id': parent_port1['id'], [{'port_id': subport1['id'],
'segmentation_id': 2, 'segmentation_id': 2,
'segmentation_type': 'vlan'}, 'segmentation_type': 'vlan'},
{'port_id': parent_port2['id'], {'port_id': subport2['id'],
'segmentation_id': 2, 'segmentation_id': 2,
'segmentation_type': 'vlan'}]) 'segmentation_type': 'vlan'}])
@decorators.attr(type='negative') @decorators.attr(type='negative')
@decorators.idempotent_id('6f132ccc-1380-42d8-9c44-50411612bd01') @decorators.idempotent_id('6f132ccc-1380-42d8-9c44-50411612bd01')
def test_add_subport_port_id_uses_trunk_port_id(self): def test_add_subport_port_id_uses_parent_port_id(self):
trunk = self._create_trunk_with_network_and_parent(None) trunk = self._create_trunk_with_network_and_parent()
self.assertRaises(lib_exc.Conflict, self.client.add_subports, self.assertRaises(lib_exc.Conflict, self.client.add_subports,
trunk['trunk']['id'], trunk['id'],
[{'port_id': trunk['trunk']['port_id'], [{'port_id': trunk['port_id'],
'segmentation_type': 'vlan', 'segmentation_type': 'vlan',
'segmentation_id': 2}]) 'segmentation_id': 2}])
@ -151,67 +156,54 @@ class TrunkTestJSON(test_trunk.TrunkTestJSONBase):
@decorators.idempotent_id('7f132ccc-1380-42d8-9c44-50411612bd01') @decorators.idempotent_id('7f132ccc-1380-42d8-9c44-50411612bd01')
def test_add_subport_port_id_disabled_trunk(self): def test_add_subport_port_id_disabled_trunk(self):
trunk = self._create_trunk_with_network_and_parent( trunk = self._create_trunk_with_network_and_parent(
None, admin_state_up=False) admin_state_up=False)
self.assertRaises(lib_exc.Conflict, self.assertRaises(lib_exc.Conflict, self.client.add_subports,
self.client.add_subports, trunk['id'], [{'port_id': trunk['port_id'],
trunk['trunk']['id'], 'segmentation_type': 'vlan',
[{'port_id': trunk['trunk']['port_id'], 'segmentation_id': 2}])
'segmentation_type': 'vlan',
'segmentation_id': 2}])
self.client.update_trunk(
trunk['trunk']['id'], admin_state_up=True)
@decorators.attr(type='negative') @decorators.attr(type='negative')
@decorators.idempotent_id('8f132ccc-1380-42d8-9c44-50411612bd01') @decorators.idempotent_id('8f132ccc-1380-42d8-9c44-50411612bd01')
def test_remove_subport_port_id_disabled_trunk(self): def test_remove_subport_port_id_disabled_trunk(self):
trunk = self._create_trunk_with_network_and_parent( trunk = self._create_trunk_with_network_and_parent(
None, admin_state_up=False) admin_state_up=False)
self.assertRaises(lib_exc.Conflict, self.assertRaises(lib_exc.Conflict, self.client.remove_subports,
self.client.remove_subports, trunk['id'], [{'port_id': trunk['port_id'],
trunk['trunk']['id'], 'segmentation_type': 'vlan',
[{'port_id': trunk['trunk']['port_id'], 'segmentation_id': 2}])
'segmentation_type': 'vlan',
'segmentation_id': 2}])
self.client.update_trunk(
trunk['trunk']['id'], admin_state_up=True)
@decorators.attr(type='negative') @decorators.attr(type='negative')
@decorators.idempotent_id('9f132ccc-1380-42d8-9c44-50411612bd01') @decorators.idempotent_id('9f132ccc-1380-42d8-9c44-50411612bd01')
def test_delete_trunk_disabled_trunk(self): def test_delete_trunk_disabled_trunk(self):
trunk = self._create_trunk_with_network_and_parent( trunk = self._create_trunk_with_network_and_parent(
None, admin_state_up=False) admin_state_up=False)
self.assertRaises(lib_exc.Conflict, self.assertRaises(lib_exc.Conflict, self.client.delete_trunk,
self.client.delete_trunk, trunk['id'])
trunk['trunk']['id'])
self.client.update_trunk(
trunk['trunk']['id'], admin_state_up=True)
@decorators.attr(type='negative') @decorators.attr(type='negative')
@decorators.idempotent_id('00cb40bb-1593-44c8-808c-72b47e64252f') @decorators.idempotent_id('00cb40bb-1593-44c8-808c-72b47e64252f')
def test_add_subport_duplicate_segmentation_details(self): def test_add_subport_duplicate_segmentation_details(self):
trunk = self._create_trunk_with_network_and_parent(None) trunk = self._create_trunk_with_network_and_parent()
network = self.create_network() network = self.create_network()
parent_port1 = self.create_port(network) subport1 = self.create_port(network)
parent_port2 = self.create_port(network) subport2 = self.create_port(network)
self.client.add_subports(trunk['trunk']['id'], self.client.add_subports(trunk['id'],
[{'port_id': parent_port1['id'], [{'port_id': subport1['id'],
'segmentation_type': 'vlan', 'segmentation_type': 'vlan',
'segmentation_id': 2}]) 'segmentation_id': 2}])
self.assertRaises(lib_exc.Conflict, self.client.add_subports, self.assertRaises(lib_exc.Conflict, self.client.add_subports,
trunk['trunk']['id'], trunk['id'], [{'port_id': subport2['id'],
[{'port_id': parent_port2['id'], 'segmentation_type': 'vlan',
'segmentation_type': 'vlan', 'segmentation_id': 2}])
'segmentation_id': 2}])
@decorators.attr(type='negative') @decorators.attr(type='negative')
@decorators.idempotent_id('4eac8c25-83ee-4051-9620-34774f565730') @decorators.idempotent_id('4eac8c25-83ee-4051-9620-34774f565730')
def test_add_subport_passing_dict(self): def test_add_subport_passing_dict(self):
trunk = self._create_trunk_with_network_and_parent(None) trunk = self._create_trunk_with_network_and_parent()
self.assertRaises(lib_exc.BadRequest, self.client.add_subports, self.assertRaises(lib_exc.BadRequest, self.client.add_subports,
trunk['trunk']['id'], trunk['id'], {'port_id': trunk['port_id'],
{'port_id': trunk['trunk']['port_id'], 'segmentation_type': 'vlan',
'segmentation_type': 'vlan', 'segmentation_id': 2})
'segmentation_id': 2})
@decorators.attr(type='negative') @decorators.attr(type='negative')
@decorators.idempotent_id('17ca7dd7-96a8-445a-941e-53c0c86c2fe2') @decorators.idempotent_id('17ca7dd7-96a8-445a-941e-53c0c86c2fe2')
@ -223,7 +215,7 @@ class TrunkTestJSON(test_trunk.TrunkTestJSONBase):
'segmentation_id': 2} 'segmentation_id': 2}
trunk = self._create_trunk_with_network_and_parent([subport_data]) trunk = self._create_trunk_with_network_and_parent([subport_data])
self.assertRaises(lib_exc.BadRequest, self.client.remove_subports, self.assertRaises(lib_exc.BadRequest, self.client.remove_subports,
trunk['trunk']['id'], subport_data) trunk['id'], subport_data)
@decorators.attr(type='negative') @decorators.attr(type='negative')
@decorators.idempotent_id('aaca7dd7-96b8-445a-931e-63f0d86d2fe2') @decorators.idempotent_id('aaca7dd7-96b8-445a-931e-63f0d86d2fe2')
@ -233,16 +225,16 @@ class TrunkTestJSON(test_trunk.TrunkTestJSONBase):
subport_data = {'port_id': parent_port['id'], subport_data = {'port_id': parent_port['id'],
'segmentation_type': 'vlan', 'segmentation_type': 'vlan',
'segmentation_id': 2} 'segmentation_id': 2}
trunk = self._create_trunk_with_network_and_parent([]) trunk = self._create_trunk_with_network_and_parent()
self.assertRaises(lib_exc.NotFound, self.client.remove_subports, self.assertRaises(lib_exc.NotFound, self.client.remove_subports,
trunk['trunk']['id'], [subport_data]) trunk['id'], [subport_data])
@decorators.attr(type='negative') @decorators.attr(type='negative')
@decorators.idempotent_id('6c9c5126-4f61-11e6-8248-40a8f063c891') @decorators.idempotent_id('6c9c5126-4f61-11e6-8248-40a8f063c891')
def test_delete_port_in_use_by_trunk(self): def test_delete_port_in_use_by_trunk(self):
trunk = self._create_trunk_with_network_and_parent(None) trunk = self._create_trunk_with_network_and_parent()
self.assertRaises(lib_exc.Conflict, self.client.delete_port, self.assertRaises(lib_exc.Conflict, self.client.delete_port,
trunk['trunk']['port_id']) trunk['port_id'])
@decorators.attr(type='negative') @decorators.attr(type='negative')
@decorators.idempotent_id('343a03d0-4f7c-11e6-97fa-40a8f063c891') @decorators.idempotent_id('343a03d0-4f7c-11e6-97fa-40a8f063c891')

View File

@ -59,9 +59,8 @@ class TrunkTest(base.BaseTempestTestCase):
def _create_server_with_trunk_port(self): def _create_server_with_trunk_port(self):
port = self.create_port(self.network, security_groups=[ port = self.create_port(self.network, security_groups=[
self.secgroup['security_group']['id']]) self.secgroup['security_group']['id']])
trunk = self.client.create_trunk(port['id'], subports=[])['trunk'] trunk = self.create_trunk(port)
server, fip = self._create_server_with_fip(port['id']) server, fip = self._create_server_with_fip(port['id'])
self.addCleanup(self._detach_and_delete_trunk, server, trunk)
return {'port': port, 'trunk': trunk, 'fip': fip, return {'port': port, 'trunk': trunk, 'fip': fip,
'server': server} 'server': server}
@ -78,18 +77,6 @@ class TrunkTest(base.BaseTempestTestCase):
**server_kwargs)['server'], **server_kwargs)['server'],
fip) fip)
def _detach_and_delete_trunk(self, server, trunk):
# we have to detach the interface from the server before
# the trunk can be deleted.
self.os_primary.compute.InterfacesClient().delete_interface(
server['id'], trunk['port_id'])
def is_port_detached():
p = self.client.show_port(trunk['port_id'])['port']
return p['device_id'] == ''
utils.wait_until_true(is_port_detached)
self.client.delete_trunk(trunk['id'])
def _is_port_down(self, port_id): def _is_port_down(self, port_id):
p = self.client.show_port(port_id)['port'] p = self.client.show_port(port_id)['port']
return p['status'] == 'DOWN' return p['status'] == 'DOWN'
@ -113,11 +100,9 @@ class TrunkTest(base.BaseTempestTestCase):
'port_id': port_for_subport['id'], 'port_id': port_for_subport['id'],
'segmentation_type': 'vlan', 'segmentation_type': 'vlan',
'segmentation_id': vlan_tag} 'segmentation_id': vlan_tag}
trunk = self.client.create_trunk( self.create_trunk(parent_port, [subport])
parent_port['id'], subports=[subport])['trunk']
server, fip = self._create_server_with_fip(parent_port['id']) server, fip = self._create_server_with_fip(parent_port['id'])
self.addCleanup(self._detach_and_delete_trunk, server, trunk)
server_ssh_client = ssh.Client( server_ssh_client = ssh.Client(
fip['floating_ip_address'], fip['floating_ip_address'],