Support Murano plugin in fuel-qa framework
- Add test for basic Murano validation in plugin installation - Fix test names in Murano-related box-install tests since Murano using GLARE backend as default now. - Turn off SSL deployment for Murano due bug: #1590633 Change-Id: Iac71f4706db4b8eb67a7f98b2932fbb31032bc9f Related-Bug: #1584791 Targets: blueprint murano-fuel-plugin
This commit is contained in:
parent
b4ba7a3af1
commit
dbd6c8f8ba
|
@ -571,6 +571,11 @@ Zabbix tests
|
||||||
.. automodule:: fuelweb_test.tests.plugins.plugin_zabbix.test_plugin_zabbix
|
.. automodule:: fuelweb_test.tests.plugins.plugin_zabbix.test_plugin_zabbix
|
||||||
:members:
|
:members:
|
||||||
|
|
||||||
|
Murano Tests
|
||||||
|
------------
|
||||||
|
.. automodule:: fuelweb_test.tests.plugins.plugin_murano.test_plugin_murano
|
||||||
|
:members:
|
||||||
|
|
||||||
Patching tests
|
Patching tests
|
||||||
==============
|
==============
|
||||||
|
|
||||||
|
|
|
@ -492,6 +492,7 @@ SEPARATE_SERVICE_HAPROXY_PLUGIN_PATH = os.environ.get(
|
||||||
'SEPARATE_SERVICE_HAPROXY_PLUGIN_PATH')
|
'SEPARATE_SERVICE_HAPROXY_PLUGIN_PATH')
|
||||||
SEPARATE_SERVICE_BALANCER_PLUGIN_PATH = os.environ.get(
|
SEPARATE_SERVICE_BALANCER_PLUGIN_PATH = os.environ.get(
|
||||||
'SEPARATE_SERVICE_BALANCER_PLUGIN_PATH')
|
'SEPARATE_SERVICE_BALANCER_PLUGIN_PATH')
|
||||||
|
MURANO_PLUGIN_PATH = os.environ.get('MURANO_PLUGIN_PATH')
|
||||||
|
|
||||||
FUEL_STATS_CHECK = get_var_as_bool('FUEL_STATS_CHECK', False)
|
FUEL_STATS_CHECK = get_var_as_bool('FUEL_STATS_CHECK', False)
|
||||||
FUEL_STATS_ENABLED = get_var_as_bool('FUEL_STATS_ENABLED', True)
|
FUEL_STATS_ENABLED = get_var_as_bool('FUEL_STATS_ENABLED', True)
|
||||||
|
|
|
@ -0,0 +1,133 @@
|
||||||
|
# Copyright 2016 Mirantis, Inc.
|
||||||
|
#
|
||||||
|
# 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 proboscis.asserts import assert_true
|
||||||
|
from proboscis import test
|
||||||
|
|
||||||
|
from fuelweb_test.helpers.checkers import check_plugin_path_env
|
||||||
|
from fuelweb_test.helpers import utils
|
||||||
|
from fuelweb_test.helpers.decorators import log_snapshot_after_test
|
||||||
|
from fuelweb_test import settings
|
||||||
|
from fuelweb_test import logger
|
||||||
|
from fuelweb_test.tests.base_test_case import SetupEnvironment
|
||||||
|
from fuelweb_test.tests.base_test_case import TestBasic
|
||||||
|
|
||||||
|
|
||||||
|
@test(groups=["plugins", "murano_plugin"])
|
||||||
|
class MuranoPlugin(TestBasic):
|
||||||
|
"""Murano Plugin Tests."""
|
||||||
|
def __init__(self):
|
||||||
|
super(MuranoPlugin, self).__init__()
|
||||||
|
check_plugin_path_env(
|
||||||
|
var_name='MURANO_PLUGIN_PATH',
|
||||||
|
plugin_path=settings.MURANO_PLUGIN_PATH
|
||||||
|
)
|
||||||
|
|
||||||
|
def setup_murano_plugin(self,
|
||||||
|
cluster_id,
|
||||||
|
murano_user='murano',
|
||||||
|
murano_db_password='murano_password',
|
||||||
|
cfapi=False,
|
||||||
|
glare=False,
|
||||||
|
apps_url='http://storage.apps.openstack.org/'):
|
||||||
|
plugin_name = 'detach_murano'
|
||||||
|
|
||||||
|
assert_true(
|
||||||
|
self.fuel_web.check_plugin_exists(cluster_id, plugin_name),
|
||||||
|
"Plugin couldn't be enabled. Check plugin version. Test aborted")
|
||||||
|
plugin_options = {
|
||||||
|
'metadata/enabled': True,
|
||||||
|
'metadata/versions/murano_user_password': murano_user,
|
||||||
|
'metadata/versions/murano_db_password': murano_db_password,
|
||||||
|
'metadata/versions/murano_glance_artifacts/value': glare,
|
||||||
|
'metadata/versions/murano_cfapi/value': cfapi,
|
||||||
|
'metadata/versions/murano_repo_url/value': apps_url
|
||||||
|
}
|
||||||
|
self.fuel_web.update_plugin_data(
|
||||||
|
cluster_id, plugin_name, plugin_options)
|
||||||
|
|
||||||
|
@test(depends_on=[SetupEnvironment.prepare_slaves_5],
|
||||||
|
groups=["deploy_murano_with_glare_ha_one_controller"])
|
||||||
|
@log_snapshot_after_test
|
||||||
|
def deploy_murano_with_glare_ha_one_controller(self):
|
||||||
|
"""Deploy cluster in ha mode with murano plugin
|
||||||
|
|
||||||
|
Scenario:
|
||||||
|
1. Upload plugin to the master node
|
||||||
|
2. Install plugin
|
||||||
|
3. Create cluster
|
||||||
|
4. Add 1 nodes with controller role
|
||||||
|
5. Add 1 node with compute role
|
||||||
|
6. Add 1 node with cinder role
|
||||||
|
7. Add 1 node with murano role
|
||||||
|
8. Deploy the cluster
|
||||||
|
9. Run network verification
|
||||||
|
10. Run sanity OSTF
|
||||||
|
11. Run Murano Platform OSTF
|
||||||
|
|
||||||
|
Duration 150m
|
||||||
|
Snapshot deploy_murano_with_glare_ha_one_controller
|
||||||
|
"""
|
||||||
|
self.env.revert_snapshot("ready_with_5_slaves")
|
||||||
|
|
||||||
|
utils.upload_tarball(
|
||||||
|
ip=self.ssh_manager.admin_ip,
|
||||||
|
tar_path=settings.MURANO_PLUGIN_PATH,
|
||||||
|
tar_target="/var")
|
||||||
|
utils.install_plugin_check_code(
|
||||||
|
ip=self.ssh_manager.admin_ip,
|
||||||
|
plugin=os.path.basename(settings.MURANO_PLUGIN_PATH))
|
||||||
|
|
||||||
|
cluster_id = self.fuel_web.create_cluster(
|
||||||
|
name=self.__class__.__name__,
|
||||||
|
mode=settings.DEPLOYMENT_MODE,
|
||||||
|
configure_ssl=False
|
||||||
|
)
|
||||||
|
|
||||||
|
self.setup_murano_plugin(cluster_id, glare=True)
|
||||||
|
|
||||||
|
self.fuel_web.update_nodes(
|
||||||
|
cluster_id,
|
||||||
|
{
|
||||||
|
"slave-01": ["controller"],
|
||||||
|
"slave-02": ["compute"],
|
||||||
|
"slave-03": ["cinder"],
|
||||||
|
"slave-04": ["murano-node"]
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
self.fuel_web.deploy_cluster_wait(cluster_id)
|
||||||
|
self.fuel_web.verify_network(cluster_id)
|
||||||
|
self.fuel_web.run_ostf(cluster_id=cluster_id, test_sets=['sanity'])
|
||||||
|
|
||||||
|
logger.debug('Run OSTF platform tests')
|
||||||
|
|
||||||
|
test_class_main = ('fuel_health.tests.tests_platform'
|
||||||
|
'.test_murano_linux.MuranoDeployLinuxServicesTests')
|
||||||
|
tests_names = ['test_deploy_dummy_app_with_glare']
|
||||||
|
|
||||||
|
test_classes = []
|
||||||
|
|
||||||
|
for test_name in tests_names:
|
||||||
|
test_classes.append('{0}.{1}'.format(test_class_main,
|
||||||
|
test_name))
|
||||||
|
|
||||||
|
for test_name in test_classes:
|
||||||
|
self.fuel_web.run_single_ostf_test(
|
||||||
|
cluster_id=cluster_id, test_sets=['tests_platform'],
|
||||||
|
test_name=test_name, timeout=60 * 20)
|
||||||
|
|
||||||
|
self.env.make_snapshot("deploy_murano_with_glare_ha_one_controller")
|
|
@ -276,7 +276,12 @@ class MuranoHAOneController(TestBasic):
|
||||||
cluster_id = self.fuel_web.create_cluster(
|
cluster_id = self.fuel_web.create_cluster(
|
||||||
name=self.__class__.__name__,
|
name=self.__class__.__name__,
|
||||||
mode=settings.DEPLOYMENT_MODE,
|
mode=settings.DEPLOYMENT_MODE,
|
||||||
settings=data)
|
settings=data,
|
||||||
|
configure_ssl=False
|
||||||
|
)
|
||||||
|
# TODO(freerunner): Need to configure SSL again when root cause for
|
||||||
|
# TODO(freerunner): https://bugs.launchpad.net/fuel/+bug/1590633
|
||||||
|
# TODO(freerunner): will be found and fixed
|
||||||
|
|
||||||
self.fuel_web.update_nodes(
|
self.fuel_web.update_nodes(
|
||||||
cluster_id,
|
cluster_id,
|
||||||
|
@ -287,26 +292,17 @@ class MuranoHAOneController(TestBasic):
|
||||||
)
|
)
|
||||||
|
|
||||||
self.fuel_web.deploy_cluster_wait(cluster_id)
|
self.fuel_web.deploy_cluster_wait(cluster_id)
|
||||||
os_conn = os_actions.OpenStackActions(
|
|
||||||
self.fuel_web.get_public_vip(cluster_id),
|
|
||||||
data['user'], data['password'], data['tenant'])
|
|
||||||
self.fuel_web.assert_cluster_ready(os_conn, smiles_count=5)
|
|
||||||
_ip = self.fuel_web.get_nailgun_node_by_name("slave-01")['ip']
|
_ip = self.fuel_web.get_nailgun_node_by_name("slave-01")['ip']
|
||||||
checkers.verify_service(_ip, service_name='murano-api')
|
checkers.verify_service(_ip, service_name='murano-api')
|
||||||
|
|
||||||
logger.debug('Run sanity and functional Murano OSTF tests')
|
logger.debug('Run sanity and functional Murano OSTF tests')
|
||||||
self.fuel_web.run_single_ostf_test(
|
self.fuel_web.run_ostf(cluster_id=cluster_id, test_sets=['sanity'])
|
||||||
cluster_id=self.fuel_web.get_last_created_cluster(),
|
|
||||||
test_sets=['sanity'],
|
|
||||||
test_name=('fuel_health.tests.sanity.test_sanity_murano.'
|
|
||||||
'MuranoSanityTests.test_create_and_delete_service')
|
|
||||||
)
|
|
||||||
|
|
||||||
logger.debug('Run OSTF platform tests')
|
logger.debug('Run OSTF platform tests')
|
||||||
|
|
||||||
test_class_main = ('fuel_health.tests.tests_platform'
|
test_class_main = ('fuel_health.tests.tests_platform'
|
||||||
'.test_murano_linux.MuranoDeployLinuxServicesTests')
|
'.test_murano_linux.MuranoDeployLinuxServicesTests')
|
||||||
tests_names = ['test_deploy_dummy_app', ]
|
tests_names = ['test_deploy_dummy_app_with_glare', ]
|
||||||
|
|
||||||
test_classes = []
|
test_classes = []
|
||||||
|
|
||||||
|
@ -360,7 +356,12 @@ class MuranoHA(TestBasic):
|
||||||
cluster_id = self.fuel_web.create_cluster(
|
cluster_id = self.fuel_web.create_cluster(
|
||||||
name=self.__class__.__name__,
|
name=self.__class__.__name__,
|
||||||
mode=settings.DEPLOYMENT_MODE,
|
mode=settings.DEPLOYMENT_MODE,
|
||||||
settings=data)
|
settings=data,
|
||||||
|
configure_ssl=False
|
||||||
|
)
|
||||||
|
# TODO(freerunner): Need to configure SSL again when root cause for
|
||||||
|
# TODO(freerunner): https://bugs.launchpad.net/fuel/+bug/1590633
|
||||||
|
# TODO(freerunner): will be found and fixed
|
||||||
|
|
||||||
self.fuel_web.update_nodes(
|
self.fuel_web.update_nodes(
|
||||||
cluster_id,
|
cluster_id,
|
||||||
|
@ -372,27 +373,18 @@ class MuranoHA(TestBasic):
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
self.fuel_web.deploy_cluster_wait(cluster_id)
|
self.fuel_web.deploy_cluster_wait(cluster_id)
|
||||||
cluster_vip = self.fuel_web.get_public_vip(cluster_id)
|
|
||||||
os_conn = os_actions.OpenStackActions(
|
|
||||||
cluster_vip, data['user'], data['password'], data['tenant'])
|
|
||||||
self.fuel_web.assert_cluster_ready(os_conn, smiles_count=13)
|
|
||||||
for slave in ["slave-01", "slave-02", "slave-03"]:
|
for slave in ["slave-01", "slave-02", "slave-03"]:
|
||||||
_ip = self.fuel_web.get_nailgun_node_by_name(slave)['ip']
|
_ip = self.fuel_web.get_nailgun_node_by_name(slave)['ip']
|
||||||
checkers.verify_service(_ip, service_name='murano-api')
|
checkers.verify_service(_ip, service_name='murano-api')
|
||||||
|
|
||||||
logger.debug('Run sanity and functional Murano OSTF tests')
|
logger.debug('Run sanity and functional Murano OSTF tests')
|
||||||
self.fuel_web.run_single_ostf_test(
|
self.fuel_web.run_ostf(cluster_id=cluster_id, test_sets=['sanity'])
|
||||||
cluster_id=self.fuel_web.get_last_created_cluster(),
|
|
||||||
test_sets=['sanity'],
|
|
||||||
test_name=('fuel_health.tests.sanity.test_sanity_murano.'
|
|
||||||
'MuranoSanityTests.test_create_and_delete_service')
|
|
||||||
)
|
|
||||||
|
|
||||||
logger.debug('Run OSTF platform tests')
|
logger.debug('Run OSTF platform tests')
|
||||||
|
|
||||||
test_class_main = ('fuel_health.tests.tests_platform'
|
test_class_main = ('fuel_health.tests.tests_platform'
|
||||||
'.test_murano_linux.MuranoDeployLinuxServicesTests')
|
'.test_murano_linux.MuranoDeployLinuxServicesTests')
|
||||||
tests_names = ['test_deploy_dummy_app', ]
|
tests_names = ['test_deploy_dummy_app_with_glare']
|
||||||
|
|
||||||
test_classes = []
|
test_classes = []
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue