|  | # Copyright 2016 Hewlett Packard Enterprise Development Company, L.P. | 
|  | # | 
|  | # 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. | 
|  | import six | 
|  | from tempest import test | 
|  | from tempest import config | 
|  | from tempest.lib.common.utils import test_utils as utils | 
|  |  | 
|  | from designate_tempest_plugin.services.dns.query.query_client import \ | 
|  | QueryClient | 
|  |  | 
|  |  | 
|  | CONF = config.CONF | 
|  |  | 
|  |  | 
|  | class AssertRaisesDns(test.BaseTestCase): | 
|  | def __init__(self, test_class, exc, type_, code): | 
|  | self.test_class = test_class | 
|  | self.exc = exc | 
|  | self.type_ = type_ | 
|  | self.code = code | 
|  |  | 
|  | def __enter__(self): | 
|  | pass | 
|  |  | 
|  | def __exit__(self, exc_type, exc_value, traceback): | 
|  | if exc_type is None: | 
|  | try: | 
|  | exc_name = self.exc.__name__ | 
|  | except AttributeError: | 
|  | exc_name = str(self.exc) | 
|  | raise self.failureException( | 
|  | "{0} not raised".format(exc_name)) | 
|  |  | 
|  | if issubclass(exc_type, self.exc): | 
|  | self.test_class.assertEqual( | 
|  | self.code, exc_value.resp_body['code']) | 
|  |  | 
|  | self.test_class.assertEqual( | 
|  | self.type_, exc_value.resp_body['type']) | 
|  |  | 
|  | return True | 
|  |  | 
|  | # Unexpected exceptions will be reraised | 
|  | return False | 
|  |  | 
|  |  | 
|  | class BaseDnsTest(test.BaseTestCase): | 
|  | """Base class for DNS tests.""" | 
|  |  | 
|  | # NOTE(andreaf) credentials holds a list of the credentials to be allocated | 
|  | # at class setup time. Credential types can be 'primary', 'alt', 'admin' or | 
|  | # a list of roles - the first element of the list being a label, and the | 
|  | # rest the actual roles. | 
|  | # NOTE(kiall) primary will result in a manager @ cls.os_primary, alt will | 
|  | # have cls.os_alt, and admin will have cls.os_admin. | 
|  | # NOTE(kiall) We should default to only primary, and request additional | 
|  | # credentials in the tests that require them. | 
|  | credentials = ['primary'] | 
|  |  | 
|  | @classmethod | 
|  | def skip_checks(cls): | 
|  | super(BaseDnsTest, cls).skip_checks() | 
|  |  | 
|  | if not CONF.service_available.designate: | 
|  | skip_msg = ("%s skipped as designate is not available" | 
|  | % cls.__name__) | 
|  | raise cls.skipException(skip_msg) | 
|  |  | 
|  | @classmethod | 
|  | def setup_clients(cls): | 
|  | super(BaseDnsTest, cls).setup_clients() | 
|  | # The Query Client is not an OpenStack client which means | 
|  | # we should not set it up through the tempest client manager. | 
|  | # Set it up here so all tests have access to it. | 
|  | cls.query_client = QueryClient( | 
|  | nameservers=CONF.dns.nameservers, | 
|  | query_timeout=CONF.dns.query_timeout, | 
|  | build_interval=CONF.dns.build_interval, | 
|  | build_timeout=CONF.dns.build_timeout, | 
|  | ) | 
|  |  | 
|  | def assertExpected(self, expected, actual, excluded_keys): | 
|  | for key, value in six.iteritems(expected): | 
|  | if key not in excluded_keys: | 
|  | self.assertIn(key, actual) | 
|  | self.assertEqual(value, actual[key], key) | 
|  |  | 
|  | def assertRaisesDns(self, exc, type_, code, callable_=None, *args, | 
|  | **kwargs): | 
|  | """ | 
|  | Checks the response that a api call with a exception contains the | 
|  | expected data | 
|  |  | 
|  | Usable as both a ordinary function, and a context manager | 
|  | """ | 
|  | context = AssertRaisesDns(self, exc, type_, code) | 
|  |  | 
|  | if callable_ is None: | 
|  | return context | 
|  |  | 
|  | with context: | 
|  | callable_(*args, **kwargs) | 
|  |  | 
|  | def transfer_request_delete(self, transfer_client, transfer_request_id): | 
|  | return utils.call_and_ignore_notfound_exc( | 
|  | transfer_client.delete_transfer_request, transfer_request_id) | 
|  |  | 
|  | def wait_zone_delete(self, zone_client, zone_id, **kwargs): | 
|  | self._delete_zone(zone_client, zone_id, **kwargs) | 
|  | utils.call_until_true(self._check_zone_deleted, | 
|  | CONF.dns.build_timeout, | 
|  | CONF.dns.build_interval, | 
|  | zone_client, | 
|  | zone_id) | 
|  |  | 
|  | def _delete_zone(self, zone_client, zone_id, **kwargs): | 
|  | return utils.call_and_ignore_notfound_exc(zone_client.delete_zone, | 
|  | zone_id, **kwargs) | 
|  |  | 
|  | def _check_zone_deleted(self, zone_client, zone_id): | 
|  | return utils.call_and_ignore_notfound_exc(zone_client.show_zone, | 
|  | zone_id) is None | 
|  |  | 
|  |  | 
|  | class BaseDnsV2Test(BaseDnsTest): | 
|  | """Base class for DNS V2 API tests.""" | 
|  |  | 
|  | all_projects_header = {'X-Auth-All-Projects': True} | 
|  |  | 
|  | @classmethod | 
|  | def skip_checks(cls): | 
|  | super(BaseDnsV2Test, cls).skip_checks() | 
|  |  | 
|  | if not CONF.dns_feature_enabled.api_v2: | 
|  | skip_msg = ("%s skipped as designate v2 API is not available" | 
|  | % cls.__name__) | 
|  | raise cls.skipException(skip_msg) | 
|  |  | 
|  |  | 
|  | class BaseDnsAdminTest(BaseDnsTest): | 
|  | """Base class for DNS Admin API tests.""" | 
|  |  | 
|  | @classmethod | 
|  | def skip_checks(cls): | 
|  | super(BaseDnsAdminTest, cls).skip_checks() | 
|  | if not CONF.dns_feature_enabled.api_admin: | 
|  | skip_msg = ("%s skipped as designate admin API is not available" | 
|  | % cls.__name__) | 
|  | raise cls.skipException(skip_msg) |