22fbf79fe9
* Neutron used * Segment type vlan by default and managed by env var NEUTRON_SEGMENT_TYPE * class HAOneControllerFlatRestart renamed to HAOneControllerNeutronRestart * def ha_one_controller_flat_warm_restart renamed to ha_one_controller_neutron_warm_restart * remove duplicated sanity test Change-Id: I99945b370b0efe5655d0b547e15ddd9d023bd4f6 Closes-Bug: #1478817
253 lines
9.1 KiB
Python
253 lines
9.1 KiB
Python
# Copyright 2013 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 time
|
|
|
|
from fuelweb_test.helpers.decorators import log_snapshot_after_test
|
|
from fuelweb_test import logger
|
|
from fuelweb_test import ostf_test_mapping as map_ostf
|
|
from fuelweb_test.settings import DEPLOYMENT_MODE
|
|
from fuelweb_test.settings import NEUTRON_SEGMENT_TYPE
|
|
from fuelweb_test.tests.base_test_case import SetupEnvironment
|
|
from fuelweb_test.tests.base_test_case import TestBasic
|
|
|
|
from devops.helpers.helpers import wait
|
|
from proboscis import test
|
|
|
|
|
|
@test(groups=["thread_3", "ceph"])
|
|
class CephRestart(TestBasic):
|
|
"""CephRestart.""" # TODO documentation
|
|
|
|
@test(depends_on_groups=['ceph_ha_one_controller_with_cinder'],
|
|
groups=["ceph_ha_one_controller_with_cinder_restart"])
|
|
@log_snapshot_after_test
|
|
def ceph_ha_one_controller_with_cinder_restart(self):
|
|
"""Restart cluster with ceph and cinder in ha mode
|
|
Scenario:
|
|
|
|
1. Create cluster in ha mode with 1 controller
|
|
2. Add 1 node with controller and ceph OSD roles
|
|
3. Add 1 node with compute role
|
|
4. Add 2 nodes with cinder and ceph OSD roles
|
|
5. Deploy the cluster
|
|
6. Warm restart
|
|
7. Check ceph status
|
|
|
|
Duration 90m
|
|
Snapshot None
|
|
"""
|
|
self.env.revert_snapshot("ceph_ha_one_controller_with_cinder")
|
|
|
|
cluster_id = self.fuel_web.get_last_created_cluster()
|
|
|
|
# Warm restart
|
|
self.fuel_web.warm_restart_nodes(
|
|
self.env.d_env.nodes().slaves[:4])
|
|
|
|
# Wait for HA services ready
|
|
self.fuel_web.assert_ha_services_ready(cluster_id)
|
|
# Wait until OpenStack services are UP
|
|
self.fuel_web.assert_os_services_ready(cluster_id)
|
|
|
|
self.fuel_web.run_ceph_task(cluster_id, offline_nodes=[])
|
|
self.fuel_web.check_ceph_status(cluster_id)
|
|
|
|
# Wait until Cinder services UP on a controller
|
|
self.fuel_web.wait_cinder_is_up(['slave-01'])
|
|
|
|
try:
|
|
self.fuel_web.run_single_ostf_test(
|
|
cluster_id, test_sets=['smoke'],
|
|
test_name=map_ostf.OSTF_TEST_MAPPING.get(
|
|
'Create volume and attach it to instance'))
|
|
except AssertionError:
|
|
logger.debug("Test failed from first probe,"
|
|
" we sleep 60 second try one more time "
|
|
"and if it fails again - test will fails ")
|
|
time.sleep(60)
|
|
self.fuel_web.run_single_ostf_test(
|
|
cluster_id, test_sets=['smoke'],
|
|
test_name=map_ostf.OSTF_TEST_MAPPING.get(
|
|
'Create volume and attach it to instance'))
|
|
|
|
self.fuel_web.run_ostf(cluster_id=cluster_id)
|
|
|
|
@test(depends_on_groups=['ceph_ha'],
|
|
groups=["ceph_ha_restart"])
|
|
@log_snapshot_after_test
|
|
def ceph_ha_restart(self):
|
|
"""Destructive ceph test in HA mode
|
|
|
|
Scenario:
|
|
1. Revert from ceph_ha
|
|
2. Waiting up galera and cinder
|
|
3. Check ceph status
|
|
4. Run OSTF
|
|
5. Destroy osd-node
|
|
6. Check ceph status
|
|
7. Run OSTF
|
|
8. Destroy one compute node
|
|
9. Check ceph status
|
|
10. Run OSTF
|
|
11. Cold restart
|
|
12. Waiting up galera and cinder
|
|
13. Run single OSTF - Create volume and attach it to instance
|
|
14. Run OSTF
|
|
|
|
Duration 30m
|
|
Snapshot ceph_ha_restart
|
|
|
|
"""
|
|
self.env.revert_snapshot("ceph_ha")
|
|
|
|
# Wait until MySQL Galera is UP on some controller
|
|
self.fuel_web.wait_mysql_galera_is_up(['slave-01'])
|
|
|
|
# Wait until Cinder services UP on a controller
|
|
self.fuel_web.wait_cinder_is_up(['slave-01'])
|
|
|
|
cluster_id = self.fuel_web.get_last_created_cluster()
|
|
|
|
self.fuel_web.check_ceph_status(cluster_id)
|
|
|
|
# Run ostf
|
|
self.fuel_web.run_ostf(cluster_id=cluster_id)
|
|
|
|
# Destroy osd-node
|
|
logger.info("Destory slave-06")
|
|
self.env.d_env.nodes().slaves[5].destroy()
|
|
|
|
wait(lambda: not self.fuel_web.get_nailgun_node_by_devops_node(
|
|
self.env.d_env.nodes().slaves[5])['online'], timeout=30 * 8)
|
|
offline_nodes = [self.fuel_web.get_nailgun_node_by_devops_node(
|
|
self.env.d_env.nodes().slaves[5])['id']]
|
|
self.fuel_web.run_ceph_task(cluster_id, offline_nodes)
|
|
self.fuel_web.check_ceph_status(cluster_id, offline_nodes)
|
|
self.fuel_web.run_ostf(cluster_id=cluster_id)
|
|
|
|
# Destroy compute node
|
|
logger.info("Destory slave-05")
|
|
self.env.d_env.nodes().slaves[4].destroy()
|
|
|
|
wait(lambda: not self.fuel_web.get_nailgun_node_by_devops_node(
|
|
self.env.d_env.nodes().slaves[4])['online'], timeout=30 * 8)
|
|
|
|
offline_nodes.append(self.fuel_web.get_nailgun_node_by_devops_node(
|
|
self.env.d_env.nodes().slaves[4])['id'])
|
|
self.fuel_web.run_ceph_task(cluster_id, offline_nodes)
|
|
self.fuel_web.check_ceph_status(cluster_id, offline_nodes)
|
|
|
|
self.fuel_web.run_ostf(cluster_id=cluster_id, should_fail=1)
|
|
|
|
# Cold restart
|
|
self.fuel_web.cold_restart_nodes(
|
|
self.env.d_env.nodes().slaves[:4])
|
|
|
|
# Wait for HA services ready
|
|
self.fuel_web.assert_ha_services_ready(cluster_id)
|
|
|
|
# Wait until OpenStack services are UP, should fail 2 services
|
|
# because slave-05 (compute+ceph-osd) destroyed. We ignore
|
|
# expect fail a test - 'Check openstack services are running'
|
|
self.fuel_web.assert_os_services_ready(cluster_id, should_fail=1)
|
|
|
|
self.fuel_web.run_ceph_task(cluster_id, offline_nodes)
|
|
self.fuel_web.check_ceph_status(cluster_id, offline_nodes)
|
|
|
|
# Wait until MySQL Galera is UP on some controller
|
|
self.fuel_web.wait_mysql_galera_is_up(['slave-01'])
|
|
|
|
# Wait until Cinder services UP on a controller
|
|
self.fuel_web.wait_cinder_is_up(['slave-01'])
|
|
|
|
try:
|
|
self.fuel_web.run_single_ostf_test(
|
|
cluster_id, test_sets=['smoke'],
|
|
test_name=map_ostf.OSTF_TEST_MAPPING.get(
|
|
'Create volume and attach it to instance'))
|
|
except AssertionError:
|
|
logger.debug("Test failed from first probe,"
|
|
" we sleep 60 second try one more time "
|
|
"and if it fails again - test will fails ")
|
|
time.sleep(180)
|
|
self.fuel_web.run_single_ostf_test(
|
|
cluster_id, test_sets=['smoke'],
|
|
test_name=map_ostf.OSTF_TEST_MAPPING.get(
|
|
'Create volume and attach it to instance'))
|
|
|
|
self.fuel_web.run_ostf(cluster_id=cluster_id, should_fail=1)
|
|
|
|
self.env.make_snapshot("ceph_ha_restart")
|
|
|
|
|
|
@test(groups=["thread_1"])
|
|
class HAOneControllerNeutronRestart(TestBasic):
|
|
|
|
@test(depends_on=[SetupEnvironment.prepare_slaves_3],
|
|
groups=["ha_one_controller_neutron_warm_restart"])
|
|
@log_snapshot_after_test
|
|
def ha_one_controller_neutron_warm_restart(self):
|
|
"""Cold restart for ha one controller environment
|
|
|
|
Scenario:
|
|
1. Create cluster
|
|
2. Add 1 node with controller role
|
|
3. Add 1 node with compute role
|
|
4. Deploy the cluster
|
|
5. Run network verification
|
|
6. Run OSTF
|
|
7. Warm restart
|
|
8. Wait for Galera is up
|
|
9. Run network verification
|
|
10. Run OSTF
|
|
|
|
Duration 30m
|
|
|
|
"""
|
|
self.env.revert_snapshot("ready_with_3_slaves")
|
|
|
|
cluster_id = self.fuel_web.create_cluster(
|
|
name=self.__class__.__name__,
|
|
mode=DEPLOYMENT_MODE,
|
|
settings={
|
|
"net_provider": 'neutron',
|
|
"net_segment_type": NEUTRON_SEGMENT_TYPE
|
|
}
|
|
)
|
|
self.fuel_web.update_nodes(
|
|
cluster_id,
|
|
{
|
|
'slave-01': ['controller'],
|
|
'slave-02': ['compute']
|
|
}
|
|
)
|
|
self.fuel_web.deploy_cluster_wait(cluster_id)
|
|
|
|
self.fuel_web.verify_network(cluster_id)
|
|
self.fuel_web.run_ostf(cluster_id=cluster_id)
|
|
|
|
# Warm restart
|
|
self.fuel_web.warm_restart_nodes(
|
|
self.env.d_env.nodes().slaves[:2])
|
|
|
|
# Wait for HA services ready
|
|
self.fuel_web.assert_ha_services_ready(cluster_id)
|
|
# Wait until OpenStack services are UP
|
|
self.fuel_web.assert_os_services_ready(cluster_id)
|
|
self.fuel_web.wait_mysql_galera_is_up(['slave-01'])
|
|
self.fuel_web.security.verify_firewall(cluster_id)
|
|
|
|
self.fuel_web.verify_network(cluster_id)
|
|
self.fuel_web.run_ostf(cluster_id=cluster_id)
|