# Copyright 2012 OpenStack Foundation # All Rights Reserved. # # Licensed under the Apache License, Version 2.0 (the "License"); you may # not use this file except in compliance with the License. You may obtain # a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the # License for the specific language governing permissions and limitations # under the License. from tempest.common import utils from tempest.lib import decorators import testtools from neutron_tempest_plugin.api import base from neutron_tempest_plugin import config class NetworksTestJSON(base.BaseNetworkTest): """ Tests the following operations in the Neutron API using the REST client for Neutron: list tenant's networks show a network show a tenant network details v2.0 of the Neutron API is assumed. """ @classmethod def resource_setup(cls): super(NetworksTestJSON, cls).resource_setup() cls.network = cls.create_network() @decorators.idempotent_id('2bf13842-c93f-4a69-83ed-717d2ec3b44e') def test_show_network(self): # Verify the details of a network body = self.client.show_network(self.network['id']) network = body['network'] fields = ['id', 'name'] if utils.is_extension_enabled('net-mtu', 'network'): fields.append('mtu') for key in fields: self.assertEqual(network[key], self.network[key]) project_id = self.client.tenant_id self.assertEqual(project_id, network['tenant_id']) if utils.is_extension_enabled('project-id', 'network'): self.assertEqual(project_id, network['project_id']) @decorators.idempotent_id('26f2b7a5-2cd1-4f3a-b11f-ad259b099b11') @utils.requires_ext(extension="project-id", service="network") def test_show_network_fields_keystone_v3(self): def _check_show_network_fields(fields, expect_project_id, expect_tenant_id): params = {} if fields: params['fields'] = fields body = self.client.show_network(self.network['id'], **params) network = body['network'] self.assertEqual(expect_project_id, 'project_id' in network) self.assertEqual(expect_tenant_id, 'tenant_id' in network) _check_show_network_fields(None, True, True) _check_show_network_fields(['tenant_id'], False, True) _check_show_network_fields(['project_id'], True, False) _check_show_network_fields(['project_id', 'tenant_id'], True, True) @decorators.idempotent_id('0cc0552f-afaf-4231-b7a7-c2a1774616da') @utils.requires_ext(extension="project-id", service="network") def test_create_network_with_project(self): project_id = self.client.tenant_id name = 'created-with-project_id' network = self.create_network(name, project_id=project_id) self.assertEqual(name, network['name']) self.assertEqual(project_id, network['project_id']) self.assertEqual(project_id, network['tenant_id']) observed_network = self.client.list_networks( id=network['id'])['networks'][0] self.assertEqual(name, observed_network['name']) new_name = 'create-with-project_id-2' updated_network = self.client.update_network( network['id'], name=new_name)['network'] self.assertEqual(new_name, updated_network['name']) self.assertEqual(project_id, updated_network['project_id']) self.assertEqual(project_id, updated_network['tenant_id']) @decorators.idempotent_id('94e2a44c-3367-4253-8c2a-22deaf59e96c') @utils.requires_ext(extension="dns-integration", service="network") def test_create_update_network_dns_domain(self): domain1 = 'test.org.' body = self.create_network(dns_domain=domain1) self.assertEqual(domain1, body['dns_domain']) net_id = body['id'] body = self.client.list_networks(id=net_id)['networks'][0] self.assertEqual(domain1, body['dns_domain']) domain2 = 'd.org.' body = self.client.update_network(net_id, dns_domain=domain2) self.assertEqual(domain2, body['network']['dns_domain']) body = self.client.show_network(net_id)['network'] self.assertEqual(domain2, body['dns_domain']) @decorators.idempotent_id('a23186b9-aa6f-4b08-b877-35ca3b9cd54c') @utils.requires_ext(extension="project-id", service="network") def test_list_networks_fields_keystone_v3(self): def _check_list_networks_fields(fields, expect_project_id, expect_tenant_id): params = {} if fields: params['fields'] = fields body = self.client.list_networks(**params) networks = body['networks'] self.assertNotEmpty(networks, "Network list returned is empty") for network in networks: self.assertEqual(expect_project_id, 'project_id' in network) self.assertEqual(expect_tenant_id, 'tenant_id' in network) _check_list_networks_fields(None, True, True) _check_list_networks_fields(['tenant_id'], False, True) _check_list_networks_fields(['project_id'], True, False) _check_list_networks_fields(['project_id', 'tenant_id'], True, True) # TODO(ihrachys): check that bad mtu is not allowed; current API extension # definition doesn't enforce values # TODO(ihrachys): check that new segment reservation updates mtu, once # https://review.openstack.org/#/c/353115/ is merged class NetworksMtuTestJSON(base.BaseNetworkTest): required_extensions = ['net-mtu', 'net-mtu-writable'] @decorators.idempotent_id('c79dbf94-ee26-420f-a56f-382aaccb1a41') def test_create_network_custom_mtu(self): # 68 should be supported by all implementations, as per api-ref network = self.create_network(mtu=68) body = self.client.show_network(network['id'])['network'] self.assertEqual(68, body['mtu']) @decorators.idempotent_id('2d35d49d-9d16-465c-92c7-4768eb717688') @testtools.skipUnless(config.CONF.network_feature_enabled.ipv6, 'IPv6 is not enabled') def test_update_network_custom_mtu(self): # 68 should be supported by all implementations, as per api-ref network = self.create_network(mtu=68) body = self.client.show_network(network['id'])['network'] self.assertEqual(68, body['mtu']) # 1280 should be supported by all ipv6 compliant implementations self.client.update_network(network['id'], mtu=1280) body = self.client.show_network(network['id'])['network'] self.assertEqual(1280, body['mtu']) class NetworksSearchCriteriaTest(base.BaseSearchCriteriaTest): resource = 'network' list_kwargs = {'shared': False, 'router:external': False} @classmethod def resource_setup(cls): super(NetworksSearchCriteriaTest, cls).resource_setup() for name in cls.resource_names: cls.create_network(network_name=name) @decorators.idempotent_id('de27d34a-bd9d-4516-83d6-81ef723f7d0d') def test_list_sorts_asc(self): self._test_list_sorts_asc() @decorators.idempotent_id('e767a160-59f9-4c4b-8dc1-72124a68640a') def test_list_sorts_desc(self): self._test_list_sorts_desc() @decorators.idempotent_id('71389852-f57b-49f2-b109-77b705e9e8af') def test_list_pagination(self): self._test_list_pagination() @decorators.idempotent_id('b7e153d2-37c3-48d4-8390-ec13498fee3d') def test_list_pagination_with_marker(self): self._test_list_pagination_with_marker() @decorators.idempotent_id('8a9c89df-0ee7-4c0d-8f1d-ec8f27cf362f') def test_list_pagination_with_href_links(self): self._test_list_pagination_with_href_links() @decorators.idempotent_id('79a52810-2156-4ab6-b577-9e46e58d4b58') def test_list_pagination_page_reverse_asc(self): self._test_list_pagination_page_reverse_asc() @decorators.idempotent_id('36a4671f-a542-442f-bc44-a8873ee778d1') def test_list_pagination_page_reverse_desc(self): self._test_list_pagination_page_reverse_desc() @decorators.idempotent_id('13eb066c-aa90-406d-b4c3-39595bf8f910') def test_list_pagination_page_reverse_with_href_links(self): self._test_list_pagination_page_reverse_with_href_links() @decorators.idempotent_id('f1867fc5-e1d6-431f-bc9f-8b882e43a7f9') def test_list_no_pagination_limit_0(self): self._test_list_no_pagination_limit_0() @decorators.idempotent_id('3574ec9b-a8b8-43e3-9c11-98f5875df6a9') def test_list_validation_filters(self): self._test_list_validation_filters(self.list_kwargs) self._test_list_validation_filters({ 'unknown_filter': 'value'}, filter_is_valid=False)