# Copyright 2016 NEC Corporation. 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. import os import mock from tempest import config from tempest import test as test from mistral_tempest_tests.services import base as service_base from mistral_tempest_tests.services.v2 import mistral_client CONF = config.CONF class TestCase(test.BaseTestCase): credentials = ['primary', 'alt'] @classmethod def skip_checks(cls): super(TestCase, cls).skip_checks() if not CONF.service_available.mistral: raise cls.skipException("Mistral support is required.") @classmethod def resource_setup(cls): """Client authentication. This method allows to initialize authentication before each test case and define parameters of Mistral API Service. """ super(TestCase, cls).resource_setup() if 'WITHOUT_AUTH' in os.environ: cls.mgr = mock.MagicMock() cls.mgr.auth_provider = service_base.AuthProv() cls.alt_mgr = cls.mgr else: cls.mgr = cls.manager cls.alt_mgr = cls.alt_manager if cls._service == 'workflowv2': cls.client = mistral_client.MistralClientV2( cls.mgr.auth_provider, cls._service) cls.alt_client = mistral_client.MistralClientV2( cls.alt_mgr.auth_provider, cls._service) def setUp(self): super(TestCase, self).setUp() def tearDown(self): super(TestCase, self).tearDown() for wb in self.client.workbooks: self.client.delete_obj('workbooks', wb) self.client.workbooks = [] class TestCaseAdvanced(TestCase): @classmethod def resource_setup(cls): super(TestCaseAdvanced, cls).resource_setup() cls.image_ref = CONF.compute.image_ref cls.flavor_ref = CONF.compute.flavor_ref def tearDown(self): for wb in self.client.workbooks: self.client.delete_obj('workbooks', wb) self.client.workbooks = [] for ex in self.client.executions: self.client.delete_obj('executions', ex) self.client.executions = [] super(TestCaseAdvanced, self).tearDown()