Migration to utilize tempest plugin
This is a migration step to utilize tempest plugin system instead of directly calling functional api tests. This is the approach used by a number of other projects as well as an approved process by openstack-qa. The difference in execution is that we will need to execute tempest's tox instead of our own: tox -eall-plugin magnum.tests.functional.api.v1 -- --concurrency=1 Implements: blueprint magnum-tempest Change-Id: Ic3eadae7fb5d88b776f9ded9589ef25279a2e1be
This commit is contained in:
parent
b3425e35aa
commit
edc5b7c01e
@ -10,7 +10,10 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
import ConfigParser
|
from tempest import config
|
||||||
|
|
||||||
|
|
||||||
|
CONF = config.CONF
|
||||||
|
|
||||||
|
|
||||||
class Config(object):
|
class Config(object):
|
||||||
@ -19,77 +22,65 @@ class Config(object):
|
|||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def set_admin_creds(cls, config):
|
def set_admin_creds(cls, config):
|
||||||
cls.admin_user = config.get('admin', 'user')
|
cls.admin_user = CONF.auth.admin_username
|
||||||
cls.admin_passwd = config.get('admin', 'pass')
|
cls.admin_passwd = CONF.auth.admin_password
|
||||||
cls.admin_tenant = config.get('admin', 'tenant')
|
cls.admin_tenant = CONF.auth.admin_tenant_name
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def set_user_creds(cls, config):
|
def set_user_creds(cls, config):
|
||||||
# normal user creds
|
# normal user creds
|
||||||
cls.user = config.get('auth', 'username')
|
cls.user = CONF.identity.username
|
||||||
cls.passwd = config.get('auth', 'password')
|
cls.passwd = CONF.identity.password
|
||||||
cls.tenant = config.get('auth', 'tenant_name')
|
cls.tenant = CONF.identity.tenant_name
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def set_auth_version(cls, config):
|
def set_auth_version(cls, config):
|
||||||
# auth version for client authentication
|
# auth version for client authentication
|
||||||
if config.has_option('auth', 'auth_version'):
|
cls.auth_version = CONF.identity.auth_version
|
||||||
cls.auth_version = config.get('auth', 'auth_version')
|
|
||||||
else:
|
|
||||||
cls.auth_version = 'v3'
|
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def set_auth_url(cls, config):
|
def set_auth_url(cls, config):
|
||||||
# auth_url for client authentication
|
# auth_url for client authentication
|
||||||
if cls.auth_version == 'v3':
|
if cls.auth_version == 'v3':
|
||||||
if not config.has_option('auth', 'auth_v3_url'):
|
cls.auth_v3_url = CONF.identity.uri_v3
|
||||||
raise Exception('config missing auth_v3_url key')
|
|
||||||
cls.auth_v3_url = config.get('auth', 'auth_v3_url')
|
|
||||||
else:
|
else:
|
||||||
if not config.has_option('auth', 'auth_url'):
|
if 'uri' not in CONF.identity:
|
||||||
raise Exception('config missing auth_url key')
|
raise Exception('config missing auth_url key')
|
||||||
cls.auth_url = config.get('auth', 'auth_url')
|
cls.auth_url = CONF.identity.uri
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def set_region(cls, config):
|
def set_region(cls, config):
|
||||||
if config.has_option('auth', 'region'):
|
if 'region' in CONF.identity:
|
||||||
cls.region = config.get('auth', 'region')
|
cls.region = CONF.identity.region
|
||||||
else:
|
else:
|
||||||
cls.region = 'RegionOne'
|
cls.region = 'RegionOne'
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def set_image_id(cls, config):
|
def set_image_id(cls, config):
|
||||||
cls.image_id = config.get('magnum', 'image_id')
|
if 'image_id' not in CONF.magnum:
|
||||||
if not config.has_option('magnum', 'image_id'):
|
|
||||||
raise Exception('config missing image_id key')
|
raise Exception('config missing image_id key')
|
||||||
|
cls.image_id = CONF.magnum.image_id
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def set_nic_id(cls, config):
|
def set_nic_id(cls, config):
|
||||||
cls.nic_id = config.get('magnum', 'nic_id')
|
if 'nic_id' not in CONF.magnum:
|
||||||
if not config.has_option('magnum', 'nic_id'):
|
|
||||||
raise Exception('config missing nic_id key')
|
raise Exception('config missing nic_id key')
|
||||||
|
cls.nic_id = CONF.magnum.nic_id
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def set_keypair_id(cls, config):
|
def set_keypair_id(cls, config):
|
||||||
cls.keypair_id = config.get('magnum', 'keypair_id')
|
if 'keypair_id' not in CONF.magnum:
|
||||||
if not config.has_option('magnum', 'keypair_id'):
|
|
||||||
raise Exception('config missing keypair_id key')
|
raise Exception('config missing keypair_id key')
|
||||||
|
cls.keypair_id = CONF.magnum.keypair_id
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def setUp(cls):
|
def setUp(cls):
|
||||||
config = ConfigParser.RawConfigParser()
|
cls.set_admin_creds(config)
|
||||||
if config.read('functional_creds.conf'):
|
cls.set_user_creds(config)
|
||||||
cls.set_admin_creds(config)
|
cls.set_auth_version(config)
|
||||||
cls.set_user_creds(config)
|
cls.set_auth_url(config)
|
||||||
cls.set_auth_version(config)
|
|
||||||
cls.set_auth_url(config)
|
|
||||||
|
|
||||||
# optional magnum bypass url
|
cls.set_region(config)
|
||||||
cls.magnum_url = config.get('auth', 'magnum_url')
|
cls.set_image_id(config)
|
||||||
|
cls.set_nic_id(config)
|
||||||
cls.set_region(config)
|
cls.set_keypair_id(config)
|
||||||
cls.set_image_id(config)
|
|
||||||
cls.set_nic_id(config)
|
|
||||||
cls.set_keypair_id(config)
|
|
||||||
else:
|
|
||||||
raise Exception('missing functional_creds.conf file')
|
|
||||||
|
@ -61,7 +61,7 @@ def generate_random_port():
|
|||||||
|
|
||||||
|
|
||||||
def generate_random_docker_volume_size():
|
def generate_random_docker_volume_size():
|
||||||
return random.randrange(1, 100)
|
return random.randrange(1, 3)
|
||||||
|
|
||||||
|
|
||||||
def generate_fake_ssh_pubkey():
|
def generate_fake_ssh_pubkey():
|
||||||
|
0
magnum/tests/functional/tempest_tests/__init__.py
Normal file
0
magnum/tests/functional/tempest_tests/__init__.py
Normal file
46
magnum/tests/functional/tempest_tests/config.py
Normal file
46
magnum/tests/functional/tempest_tests/config.py
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
# 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 __future__ import print_function
|
||||||
|
|
||||||
|
from oslo_config import cfg
|
||||||
|
|
||||||
|
from tempest import config # noqa
|
||||||
|
|
||||||
|
service_available_group = cfg.OptGroup(name="service_available",
|
||||||
|
title="Available OpenStack Services")
|
||||||
|
|
||||||
|
ServiceAvailableGroup = [
|
||||||
|
cfg.BoolOpt("magnum",
|
||||||
|
default=True,
|
||||||
|
help="Whether or not magnum is expected to be available"),
|
||||||
|
]
|
||||||
|
|
||||||
|
magnum_group = cfg.OptGroup(name="magnum", title="Magnum Options")
|
||||||
|
|
||||||
|
MagnumGroup = [
|
||||||
|
cfg.StrOpt("image_id",
|
||||||
|
default="fedora-21-atomic-5",
|
||||||
|
help="Image id to be used for baymodel."),
|
||||||
|
|
||||||
|
cfg.StrOpt("nic_id",
|
||||||
|
default="public",
|
||||||
|
help="NIC id."),
|
||||||
|
|
||||||
|
cfg.StrOpt("keypair_id",
|
||||||
|
default="default",
|
||||||
|
help="Keypair id to use to log into nova instances."),
|
||||||
|
|
||||||
|
cfg.StrOpt("flavor_id",
|
||||||
|
default="m1.magnum",
|
||||||
|
help="Flavor id to use for baymodels."),
|
||||||
|
]
|
39
magnum/tests/functional/tempest_tests/plugin.py
Normal file
39
magnum/tests/functional/tempest_tests/plugin.py
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
# 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
|
||||||
|
|
||||||
|
from tempest import config
|
||||||
|
from tempest.test_discover import plugins
|
||||||
|
|
||||||
|
import magnum
|
||||||
|
from magnum.tests.functional.tempest_tests import config as magnum_config
|
||||||
|
|
||||||
|
|
||||||
|
class MagnumTempestPlugin(plugins.TempestPlugin):
|
||||||
|
def load_tests(self):
|
||||||
|
base_path = os.path.split(os.path.dirname(
|
||||||
|
os.path.abspath(magnum.__file__)))[0]
|
||||||
|
test_dir = "magnum/tests/functional/api/v1"
|
||||||
|
full_test_dir = os.path.join(base_path, test_dir)
|
||||||
|
return full_test_dir, base_path
|
||||||
|
|
||||||
|
def register_opts(self, conf):
|
||||||
|
config.register_opt_group(
|
||||||
|
conf, magnum_config.service_available_group,
|
||||||
|
magnum_config.ServiceAvailableGroup)
|
||||||
|
config.register_opt_group(conf, magnum_config.magnum_group,
|
||||||
|
magnum_config.MagnumGroup)
|
||||||
|
|
||||||
|
def get_opt_lists(self):
|
||||||
|
return [(magnum_config.magnum_group.name, magnum_config.MagnumGroup)]
|
Loading…
Reference in New Issue
Block a user