Source code for identity.admin.v3.test_endpoints_negative

# Copyright 2013 IBM Corp.
# 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.api.identity import base
from tempest import config
from tempest.lib.common.utils import data_utils
from tempest.lib import decorators
from tempest.lib import exceptions as lib_exc

CONF = config.CONF


[docs] class EndpointsNegativeTestJSON(base.BaseIdentityV3AdminTest): """Negative tests of endpoint""" # NOTE: force_tenant_isolation is true in the base class by default but # overridden to false here to allow test execution for clouds using the # pre-provisioned credentials provider. force_tenant_isolation = False @classmethod def setup_clients(cls): super(EndpointsNegativeTestJSON, cls).setup_clients() cls.client = cls.endpoints_client @classmethod def resource_setup(cls): prefix = CONF.resource_name_prefix super(EndpointsNegativeTestJSON, cls).resource_setup() s_name = data_utils.rand_name(name='service', prefix=prefix) s_type = data_utils.rand_name(name='type', prefix=prefix) s_description = data_utils.rand_name(name='description', prefix=prefix) service_data = ( cls.services_client.create_service(name=s_name, type=s_type, description=s_description) ['service']) cls.addClassResourceCleanup(cls.services_client.delete_service, service_data['id']) cls.service_id = service_data['id']
[docs] @decorators.attr(type=['negative']) @decorators.idempotent_id('ac6c137e-4d3d-448f-8c83-4f13d0942651') def test_create_with_enabled_False(self): """Test creating endpoint with invalid enabled value 'False' Enabled should be a boolean, not a string like 'False' """ interface = 'public' url = data_utils.rand_url() region = data_utils.rand_name( name='region', prefix=CONF.resource_name_prefix) self.assertRaises(lib_exc.BadRequest, self.client.create_endpoint, service_id=self.service_id, interface=interface, url=url, region=region, enabled='False')
[docs] @decorators.attr(type=['negative']) @decorators.idempotent_id('9c43181e-0627-484a-8c79-923e8a59598b') def test_create_with_enabled_True(self): """Test creating endpoint with invalid enabled value 'True' Enabled should be a boolean, not a string like 'True' """ interface = 'public' url = data_utils.rand_url() region = data_utils.rand_name( name='region', prefix=CONF.resource_name_prefix) self.assertRaises(lib_exc.BadRequest, self.client.create_endpoint, service_id=self.service_id, interface=interface, url=url, region=region, enabled='True')
def _assert_update_raises_bad_request(self, enabled): # Create an endpoint region1_name = data_utils.rand_name( name='region', prefix=CONF.resource_name_prefix) url1 = data_utils.rand_url() interface1 = 'public' endpoint_for_update = ( self.client.create_endpoint(service_id=self.service_id, interface=interface1, url=url1, region=region1_name, enabled=True)['endpoint']) region1 = self.regions_client.show_region(region1_name)['region'] self.addCleanup(self.regions_client.delete_region, region1['id']) self.addCleanup(self.client.delete_endpoint, endpoint_for_update['id']) self.assertRaises(lib_exc.BadRequest, self.client.update_endpoint, endpoint_for_update['id'], enabled=enabled)
[docs] @decorators.attr(type=['negative']) @decorators.idempotent_id('65e41f32-5eb7-498f-a92a-a6ccacf7439a') def test_update_with_enabled_False(self): """Test updating endpoint with invalid enabled value 'False' Enabled should be a boolean, not a string like 'False' """ self._assert_update_raises_bad_request('False')
[docs] @decorators.attr(type=['negative']) @decorators.idempotent_id('faba3587-f066-4757-a48e-b4a3f01803bb') def test_update_with_enabled_True(self): """Test updating endpoint with invalid enabled value 'True' Enabled should be a boolean, not a string like 'True' """ self._assert_update_raises_bad_request('True')