020fe761b9
Removed unnecessary an all exception Previously test just print traceback and continues For now an inner timeout exception will pop up Closes-Bug: 1525988 Change-Id: I4acaa35d56558a75f7feea7f46301bedd7840fbc
434 lines
14 KiB
Python
434 lines
14 KiB
Python
# Copyright 2014 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.
|
|
|
|
from proboscis import asserts
|
|
from proboscis import test
|
|
from fuelweb_test.helpers.decorators import check_fuel_statistics
|
|
from fuelweb_test.helpers.decorators import log_snapshot_after_test
|
|
from fuelweb_test import settings as hlp_data
|
|
from fuelweb_test.tests import base_test_case
|
|
|
|
|
|
@test(groups=["cluster_actions"])
|
|
class EnvironmentAction(base_test_case.TestBasic):
|
|
"""EnvironmentAction.""" # TODO documentation
|
|
|
|
@test(depends_on=[base_test_case.SetupEnvironment.prepare_slaves_3],
|
|
groups=["smoke", "deploy_neutron_stop_reset_on_deploying",
|
|
"classic_provisioning"])
|
|
@log_snapshot_after_test
|
|
@check_fuel_statistics
|
|
def deploy_neutron_stop_on_deploying(self):
|
|
"""Stop reset cluster in HA mode with neutron
|
|
|
|
Scenario:
|
|
1. Create cluster in HA mode with 1 controller
|
|
2. Add 1 node with controller role
|
|
3. Add 1 node with compute role
|
|
4. Run provisioning task
|
|
5. Run deployment task
|
|
6. Stop deployment
|
|
7. Add 1 node with cinder role
|
|
8. Re-deploy cluster
|
|
9. Run OSTF
|
|
|
|
Duration 50m
|
|
Snapshot: deploy_neutron_stop_reset_on_deploying
|
|
|
|
"""
|
|
self.env.revert_snapshot("ready_with_3_slaves")
|
|
|
|
cluster_id = self.fuel_web.create_cluster(
|
|
name=self.__class__.__name__,
|
|
mode=hlp_data.DEPLOYMENT_MODE,
|
|
settings={
|
|
'tenant': 'stop_deploy',
|
|
'user': 'stop_deploy',
|
|
'password': 'stop_deploy',
|
|
}
|
|
)
|
|
self.fuel_web.update_nodes(
|
|
cluster_id,
|
|
{
|
|
'slave-01': ['controller'],
|
|
'slave-02': ['compute']
|
|
}
|
|
)
|
|
|
|
self.fuel_web.provisioning_cluster_wait(cluster_id)
|
|
self.fuel_web.deploy_task_wait(cluster_id=cluster_id, progress=10)
|
|
self.fuel_web.stop_deployment_wait(cluster_id)
|
|
self.fuel_web.wait_nodes_get_online_state(
|
|
self.env.d_env.nodes().slaves[:2], timeout=10 * 60)
|
|
|
|
self.fuel_web.update_nodes(
|
|
cluster_id,
|
|
{
|
|
'slave-03': ['cinder']
|
|
}
|
|
)
|
|
|
|
self.fuel_web.deploy_cluster_wait(cluster_id)
|
|
|
|
asserts.assert_equal(
|
|
3, len(self.fuel_web.client.list_cluster_nodes(cluster_id)))
|
|
|
|
self.fuel_web.run_ostf(
|
|
cluster_id=cluster_id)
|
|
|
|
self.env.make_snapshot("deploy_neutron_stop_reset_on_deploying")
|
|
|
|
@test(depends_on=[base_test_case.SetupEnvironment.prepare_slaves_3],
|
|
groups=["smoke", "deploy_neutron_stop_reset_on_provisioning"])
|
|
@log_snapshot_after_test
|
|
def deploy_neutron_stop_reset_on_provisioning(self):
|
|
"""Stop provisioning cluster in HA mode with neutron
|
|
|
|
Scenario:
|
|
1. Create cluster in HA mode with 1 controller
|
|
2. Add 1 node with controller role
|
|
3. Add 1 node with compute role
|
|
4. Run provisioning task
|
|
5. Stop provisioning
|
|
6. Reset settings
|
|
7. Add 1 node with cinder role
|
|
8. Re-deploy cluster
|
|
9. Run OSTF
|
|
|
|
Duration 40m
|
|
Snapshot: deploy_neutron_stop_reset_on_deploying
|
|
|
|
"""
|
|
self.env.revert_snapshot("ready_with_3_slaves")
|
|
|
|
cluster_id = self.fuel_web.create_cluster(
|
|
name=self.__class__.__name__,
|
|
mode=hlp_data.DEPLOYMENT_MODE,
|
|
)
|
|
self.fuel_web.update_nodes(
|
|
cluster_id,
|
|
{
|
|
'slave-01': ['controller'],
|
|
'slave-02': ['compute']
|
|
}
|
|
)
|
|
|
|
self.fuel_web.provisioning_cluster_wait(
|
|
cluster_id=cluster_id, progress=20)
|
|
|
|
self.fuel_web.stop_deployment_wait(cluster_id)
|
|
|
|
self.fuel_web.wait_nodes_get_online_state(
|
|
self.env.d_env.nodes().slaves[:2], timeout=10 * 60)
|
|
self.fuel_web.update_nodes(
|
|
cluster_id,
|
|
{
|
|
'slave-03': ['cinder']
|
|
}
|
|
)
|
|
|
|
self.fuel_web.deploy_cluster_wait(cluster_id)
|
|
|
|
asserts.assert_equal(
|
|
3, len(self.fuel_web.client.list_cluster_nodes(cluster_id)))
|
|
|
|
self.fuel_web.run_ostf(
|
|
cluster_id=cluster_id)
|
|
|
|
self.env.make_snapshot("deploy_neutron_stop_reset_on_provisioning")
|
|
|
|
@test(depends_on=[base_test_case.SetupEnvironment.prepare_slaves_3],
|
|
groups=["smoke", "deploy_reset_on_ready"])
|
|
@log_snapshot_after_test
|
|
@check_fuel_statistics
|
|
def deploy_reset_on_ready(self):
|
|
"""Stop reset cluster in HA mode with 1 controller
|
|
|
|
Scenario:
|
|
1. Create cluster in Ha mode with 1 controller
|
|
2. Add 1 node with controller role
|
|
3. Add 1 node with compute role
|
|
4. Deploy cluster
|
|
5. Reset settings
|
|
6. Update net
|
|
7. Re-deploy cluster
|
|
8. Verify network
|
|
9. Run OSTF
|
|
|
|
Duration 40m
|
|
Snapshot: deploy_reset_on_ready
|
|
|
|
"""
|
|
self.env.revert_snapshot("ready_with_3_slaves")
|
|
|
|
cluster_id = self.fuel_web.create_cluster(
|
|
name=self.__class__.__name__,
|
|
mode=hlp_data.DEPLOYMENT_MODE,
|
|
)
|
|
self.fuel_web.update_nodes(
|
|
cluster_id,
|
|
{
|
|
'slave-01': ['controller'],
|
|
'slave-02': ['compute']
|
|
}
|
|
)
|
|
|
|
self.fuel_web.deploy_cluster_wait(cluster_id)
|
|
|
|
self.fuel_web.stop_reset_env_wait(cluster_id)
|
|
self.fuel_web.wait_nodes_get_online_state(
|
|
self.env.d_env.nodes().slaves[:2], timeout=10 * 60)
|
|
|
|
self.fuel_web.deploy_cluster_wait(cluster_id)
|
|
|
|
self.fuel_web.verify_network(cluster_id)
|
|
|
|
self.fuel_web.run_ostf(
|
|
cluster_id=cluster_id)
|
|
|
|
self.env.make_snapshot("deploy_reset_on_ready")
|
|
|
|
|
|
@test(groups=["cluster_actions_ha"])
|
|
class EnvironmentActionOnHA(base_test_case.TestBasic):
|
|
"""EnvironmentActionOnHA.""" # TODO documentation
|
|
|
|
@test(depends_on=[base_test_case.SetupEnvironment.prepare_slaves_5],
|
|
groups=["smoke", "deploy_stop_reset_on_ha"])
|
|
@log_snapshot_after_test
|
|
def deploy_stop_reset_on_ha(self):
|
|
"""Stop reset cluster in ha mode
|
|
|
|
Scenario:
|
|
1. Create cluster
|
|
2. Add 3 node with controller role
|
|
3. Deploy cluster
|
|
4. Stop deployment
|
|
5. Reset settings
|
|
6. Add 2 nodes with compute role
|
|
7. Re-deploy cluster
|
|
8. Run OSTF
|
|
|
|
Duration 60m
|
|
Snapshot: deploy_stop_reset_on_ha
|
|
|
|
"""
|
|
self.env.revert_snapshot("ready_with_5_slaves")
|
|
|
|
cluster_id = self.fuel_web.create_cluster(
|
|
name=self.__class__.__name__,
|
|
mode=hlp_data.DEPLOYMENT_MODE_HA,
|
|
)
|
|
self.fuel_web.update_nodes(
|
|
cluster_id,
|
|
{
|
|
'slave-01': ['controller'],
|
|
'slave-02': ['controller'],
|
|
'slave-03': ['controller']
|
|
}
|
|
)
|
|
|
|
self.fuel_web.deploy_cluster_wait_progress(cluster_id, progress=10)
|
|
self.fuel_web.stop_deployment_wait(cluster_id)
|
|
self.fuel_web.wait_nodes_get_online_state(
|
|
self.env.d_env.nodes().slaves[:3], timeout=10 * 60)
|
|
self.fuel_web.update_nodes(
|
|
cluster_id,
|
|
{
|
|
'slave-04': ['compute'],
|
|
'slave-05': ['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,
|
|
test_sets=['ha', 'smoke', 'sanity'])
|
|
|
|
self.env.make_snapshot("deploy_stop_reset_on_ha")
|
|
|
|
|
|
@test(groups=["controller_replacement"])
|
|
class ControllerReplacement(base_test_case.TestBasic):
|
|
"""
|
|
Test class ControllerReplacement includes following cases:
|
|
- replace controller on ha cluster with neutron gre provider;
|
|
- replace controller on ha cluster with neutron vlan provider;
|
|
- replace controller on ha cluster with nova network provider;
|
|
"""
|
|
|
|
@test(depends_on=[base_test_case.SetupEnvironment.prepare_slaves_5],
|
|
groups=["deploy_ha_neutron_tun_ctrl_replacement"])
|
|
@log_snapshot_after_test
|
|
def deploy_ha_neutron_tun_ctrl_replacement(self):
|
|
"""Replace 1 controller and re-deploy on ha env with neutron vxlan
|
|
|
|
Scenario:
|
|
1. Create cluster with Neutron VXLAN
|
|
2. Add 3 node with controller role
|
|
3. Add 1 node with compute
|
|
4. Deploy cluster
|
|
5. Remove one controller add new controller
|
|
6. Deploy changes
|
|
7. Run OSTF
|
|
|
|
Duration 90m
|
|
Snapshot: deploy_ha_neutron_tun_ctrl_replacement
|
|
"""
|
|
|
|
self.env.revert_snapshot("ready_with_5_slaves")
|
|
|
|
data = {"net_provider": "neutron", "net_segment_type": 'tun'}
|
|
|
|
cluster_id = self.fuel_web.create_cluster(
|
|
name=self.__class__.__name__,
|
|
mode=hlp_data.DEPLOYMENT_MODE_HA,
|
|
settings=data
|
|
|
|
)
|
|
self.fuel_web.update_nodes(
|
|
cluster_id,
|
|
{
|
|
'slave-01': ['controller'],
|
|
'slave-02': ['controller'],
|
|
'slave-03': ['controller'],
|
|
'slave-04': ['compute']
|
|
}
|
|
)
|
|
|
|
self.fuel_web.deploy_cluster_wait(cluster_id)
|
|
self.fuel_web.update_nodes(
|
|
cluster_id, {'slave-05': ['controller']}, True, False)
|
|
self.fuel_web.update_nodes(
|
|
cluster_id, {'slave-01': ['controller']}, False, True)
|
|
|
|
# Disable check services here, according to nova-manage shows
|
|
# XXX for node that we remove
|
|
self.fuel_web.deploy_cluster_wait(cluster_id, check_services=False)
|
|
self.fuel_web.run_ostf(cluster_id,
|
|
test_sets=['ha', 'smoke', 'sanity'],
|
|
should_fail=1)
|
|
|
|
self.env.make_snapshot("deploy_ha_neutron_tun_ctrl_replacement")
|
|
|
|
@test(depends_on=[base_test_case.SetupEnvironment.prepare_slaves_5],
|
|
groups=["deploy_ha_neutron_vlan_ctrl_replacement"])
|
|
@log_snapshot_after_test
|
|
def deploy_ha_neutron_vlan_ctrl_replacement(self):
|
|
"""Replace 1 controller and re-deploy on ha env with neutron vlan
|
|
|
|
Scenario:
|
|
1. Create cluster with neutron vlan
|
|
2. Add 3 node with controller role
|
|
3. Add 1 node with compute
|
|
4. Deploy cluster
|
|
5. Remove one controller add new controller
|
|
6. Deploy changes
|
|
7. Run OSTF
|
|
|
|
Duration 90m
|
|
Snapshot: deploy_ha_neutron_vlan_ctrl_replacement
|
|
"""
|
|
|
|
self.env.revert_snapshot("ready_with_5_slaves")
|
|
|
|
data = {"net_provider": "neutron", "net_segment_type": 'vlan'}
|
|
|
|
cluster_id = self.fuel_web.create_cluster(
|
|
name=self.__class__.__name__,
|
|
mode=hlp_data.DEPLOYMENT_MODE_HA,
|
|
settings=data
|
|
|
|
)
|
|
self.fuel_web.update_nodes(
|
|
cluster_id,
|
|
{
|
|
'slave-01': ['controller'],
|
|
'slave-02': ['controller'],
|
|
'slave-03': ['controller'],
|
|
'slave-04': ['compute']
|
|
}
|
|
)
|
|
|
|
self.fuel_web.deploy_cluster_wait(cluster_id)
|
|
self.fuel_web.update_nodes(
|
|
cluster_id, {'slave-05': ['controller']}, True, False)
|
|
self.fuel_web.update_nodes(
|
|
cluster_id, {'slave-01': ['controller']}, False, True)
|
|
|
|
# Disable check services here, according to nova-manage shows
|
|
# XXX for node that we remove
|
|
self.fuel_web.deploy_cluster_wait(cluster_id, check_services=False)
|
|
self.fuel_web.run_ostf(cluster_id,
|
|
test_sets=['ha', 'smoke', 'sanity'],
|
|
should_fail=1)
|
|
|
|
self.env.make_snapshot("deploy_ha_neutron_vlan_ctrl_replacement")
|
|
|
|
@test(enabled=False,
|
|
depends_on=[base_test_case.SetupEnvironment.prepare_slaves_5],
|
|
groups=["deploy_ha_nova_ctrl_replacement"])
|
|
@log_snapshot_after_test
|
|
def deploy_ha_nova_ctrl_replacement(self):
|
|
# REMOVE THIS NOVA_NETWORK CASE WHEN NEUTRON BE DEFAULT
|
|
"""Replace 1 controller and re-deploy on ha env with nova
|
|
|
|
Scenario:
|
|
1. Create cluster with nova
|
|
2. Add 3 node with controller role
|
|
3. Add 1 node with compute
|
|
4. Deploy cluster
|
|
5. Remove one controller add new controller
|
|
6. Deploy changes
|
|
7. Run OSTF
|
|
|
|
Duration 90m
|
|
Snapshot: deploy_ha_nova_ctrl_replacement
|
|
"""
|
|
|
|
self.env.revert_snapshot("ready_with_5_slaves")
|
|
|
|
cluster_id = self.fuel_web.create_cluster(
|
|
name=self.__class__.__name__,
|
|
mode=hlp_data.DEPLOYMENT_MODE_HA,
|
|
|
|
)
|
|
self.fuel_web.update_nodes(
|
|
cluster_id,
|
|
{
|
|
'slave-01': ['controller'],
|
|
'slave-02': ['controller'],
|
|
'slave-03': ['controller'],
|
|
'slave-04': ['compute']
|
|
}
|
|
)
|
|
|
|
self.fuel_web.deploy_cluster_wait(cluster_id)
|
|
self.fuel_web.update_nodes(
|
|
cluster_id, {'slave-05': ['controller']}, True, False)
|
|
self.fuel_web.update_nodes(
|
|
cluster_id, {'slave-01': ['controller']}, False, True)
|
|
|
|
# Disable check services here, according to nova-manage shows
|
|
# XXX for node that we remove
|
|
self.fuel_web.deploy_cluster_wait(cluster_id, check_services=False)
|
|
self.fuel_web.run_ostf(cluster_id,
|
|
test_sets=['ha', 'smoke', 'sanity'],
|
|
should_fail=1)
|
|
|
|
self.env.make_snapshot("deploy_ha_nova_ctrl_replacement")
|