Merge "Fix [H405] pep rule in heat_integrationtests"
This commit is contained in:
commit
34f32eef0e
@ -23,7 +23,8 @@ import swiftclient
|
|||||||
|
|
||||||
|
|
||||||
class ClientManager(object):
|
class ClientManager(object):
|
||||||
"""
|
"""Provides access to the official python clients for calling various APIs.
|
||||||
|
|
||||||
Manager that provides access to the official python clients for
|
Manager that provides access to the official python clients for
|
||||||
calling various OpenStack APIs.
|
calling various OpenStack APIs.
|
||||||
"""
|
"""
|
||||||
|
@ -12,8 +12,7 @@
|
|||||||
|
|
||||||
|
|
||||||
class IntegrationException(Exception):
|
class IntegrationException(Exception):
|
||||||
"""
|
"""Base Tempest Exception.
|
||||||
Base Tempest Exception
|
|
||||||
|
|
||||||
To correctly use this class, inherit from it and define
|
To correctly use this class, inherit from it and define
|
||||||
a 'message' property. That message will get printf'd
|
a 'message' property. That message will get printf'd
|
||||||
|
@ -88,8 +88,7 @@ class Client(object):
|
|||||||
return (time.time() - self.timeout) > start_time
|
return (time.time() - self.timeout) > start_time
|
||||||
|
|
||||||
def exec_command(self, cmd):
|
def exec_command(self, cmd):
|
||||||
"""
|
"""Execute the specified command on the server.
|
||||||
Execute the specified command on the server.
|
|
||||||
|
|
||||||
Note that this method is reading whole command outputs to memory, thus
|
Note that this method is reading whole command outputs to memory, thus
|
||||||
shouldn't be used for large outputs.
|
shouldn't be used for large outputs.
|
||||||
@ -170,8 +169,9 @@ class RemoteClient(object):
|
|||||||
return self.ssh_client.exec_command(cmd)
|
return self.ssh_client.exec_command(cmd)
|
||||||
|
|
||||||
def validate_authentication(self):
|
def validate_authentication(self):
|
||||||
"""Validate ssh connection and authentication
|
"""Validate ssh connection and authentication.
|
||||||
This method raises an Exception when the validation fails.
|
|
||||||
|
This method raises an Exception when the validation fails.
|
||||||
"""
|
"""
|
||||||
self.ssh_client.test_connection_auth()
|
self.ssh_client.test_connection_auth()
|
||||||
|
|
||||||
|
@ -35,7 +35,8 @@ _LOG_FORMAT = "%(levelname)8s [%(name)s] %(message)s"
|
|||||||
|
|
||||||
|
|
||||||
def call_until_true(duration, sleep_for, func, *args, **kwargs):
|
def call_until_true(duration, sleep_for, func, *args, **kwargs):
|
||||||
"""
|
"""Call the function until it returns True or the duration elapsed.
|
||||||
|
|
||||||
Call the given function until it returns True (and return True) or
|
Call the given function until it returns True (and return True) or
|
||||||
until the specified duration (in seconds) elapses (and return
|
until the specified duration (in seconds) elapses (and return
|
||||||
False).
|
False).
|
||||||
@ -281,8 +282,7 @@ class HeatIntegrationTest(testscenarios.WithScenarios,
|
|||||||
def _wait_for_stack_status(self, stack_identifier, status,
|
def _wait_for_stack_status(self, stack_identifier, status,
|
||||||
failure_pattern=None,
|
failure_pattern=None,
|
||||||
success_on_not_found=False):
|
success_on_not_found=False):
|
||||||
"""
|
"""Waits for a Stack to reach a given status.
|
||||||
Waits for a Stack to reach a given status.
|
|
||||||
|
|
||||||
Note this compares the full $action_$status, e.g
|
Note this compares the full $action_$status, e.g
|
||||||
CREATE_COMPLETE, not just COMPLETE which is exposed
|
CREATE_COMPLETE, not just COMPLETE which is exposed
|
||||||
|
@ -189,7 +189,9 @@ class AutoscalingGroupBasicTest(AutoscalingGroupTest):
|
|||||||
self.assert_instance_count(stack, 5)
|
self.assert_instance_count(stack, 5)
|
||||||
|
|
||||||
def test_update_group_replace(self):
|
def test_update_group_replace(self):
|
||||||
"""Make sure that during a group update the non updatable
|
"""Test case for ensuring non-updatable props case a replacement.
|
||||||
|
|
||||||
|
Make sure that during a group update the non-updatable
|
||||||
properties cause a replacement.
|
properties cause a replacement.
|
||||||
"""
|
"""
|
||||||
files = {'provider.yaml': self.instance_template}
|
files = {'provider.yaml': self.instance_template}
|
||||||
@ -219,7 +221,9 @@ class AutoscalingGroupBasicTest(AutoscalingGroupTest):
|
|||||||
self.assertNotEqual(orig_asg_id, rsrc.physical_resource_id)
|
self.assertNotEqual(orig_asg_id, rsrc.physical_resource_id)
|
||||||
|
|
||||||
def test_create_instance_error_causes_group_error(self):
|
def test_create_instance_error_causes_group_error(self):
|
||||||
"""If a resource in an instance group fails to be created, the instance
|
"""Test create failing a resource in the instance group.
|
||||||
|
|
||||||
|
If a resource in an instance group fails to be created, the instance
|
||||||
group itself will fail and the broken inner resource will remain.
|
group itself will fail and the broken inner resource will remain.
|
||||||
"""
|
"""
|
||||||
stack_name = self._stack_rand_name()
|
stack_name = self._stack_rand_name()
|
||||||
@ -252,7 +256,9 @@ class AutoscalingGroupBasicTest(AutoscalingGroupTest):
|
|||||||
self._assert_instance_state(nested_ident, 0, 2)
|
self._assert_instance_state(nested_ident, 0, 2)
|
||||||
|
|
||||||
def test_update_instance_error_causes_group_error(self):
|
def test_update_instance_error_causes_group_error(self):
|
||||||
"""If a resource in an instance group fails to be created during an
|
"""Test update failing a resource in the instance group.
|
||||||
|
|
||||||
|
If a resource in an instance group fails to be created during an
|
||||||
update, the instance group itself will fail and the broken inner
|
update, the instance group itself will fail and the broken inner
|
||||||
resource will remain.
|
resource will remain.
|
||||||
"""
|
"""
|
||||||
@ -408,9 +414,10 @@ class AutoscalingGroupUpdatePolicyTest(AutoscalingGroupTest):
|
|||||||
self.assertNotIn(deletes_expected, updt_names)
|
self.assertNotIn(deletes_expected, updt_names)
|
||||||
|
|
||||||
def test_instance_group_update_replace(self):
|
def test_instance_group_update_replace(self):
|
||||||
"""
|
"""Test simple update replace.
|
||||||
Test simple update replace with no conflict in batch size and
|
|
||||||
minimum instances in service.
|
Test update replace with no conflict in batch size and minimum
|
||||||
|
instances in service.
|
||||||
"""
|
"""
|
||||||
updt_template = self.ig_tmpl_with_updt_policy()
|
updt_template = self.ig_tmpl_with_updt_policy()
|
||||||
grp = updt_template['Resources']['JobServerGroup']
|
grp = updt_template['Resources']['JobServerGroup']
|
||||||
@ -427,9 +434,10 @@ class AutoscalingGroupUpdatePolicyTest(AutoscalingGroupTest):
|
|||||||
update_replace=True)
|
update_replace=True)
|
||||||
|
|
||||||
def test_instance_group_update_replace_with_adjusted_capacity(self):
|
def test_instance_group_update_replace_with_adjusted_capacity(self):
|
||||||
"""
|
"""Test update replace with capacity adjustment.
|
||||||
Test update replace with capacity adjustment due to conflict in
|
|
||||||
batch size and minimum instances in service.
|
Test update replace with capacity adjustment due to conflict in batch
|
||||||
|
size and minimum instances in service.
|
||||||
"""
|
"""
|
||||||
updt_template = self.ig_tmpl_with_updt_policy()
|
updt_template = self.ig_tmpl_with_updt_policy()
|
||||||
grp = updt_template['Resources']['JobServerGroup']
|
grp = updt_template['Resources']['JobServerGroup']
|
||||||
@ -446,9 +454,7 @@ class AutoscalingGroupUpdatePolicyTest(AutoscalingGroupTest):
|
|||||||
update_replace=True)
|
update_replace=True)
|
||||||
|
|
||||||
def test_instance_group_update_replace_huge_batch_size(self):
|
def test_instance_group_update_replace_huge_batch_size(self):
|
||||||
"""
|
"""Test update replace with a huge batch size."""
|
||||||
Test update replace with a huge batch size.
|
|
||||||
"""
|
|
||||||
updt_template = self.ig_tmpl_with_updt_policy()
|
updt_template = self.ig_tmpl_with_updt_policy()
|
||||||
group = updt_template['Resources']['JobServerGroup']
|
group = updt_template['Resources']['JobServerGroup']
|
||||||
policy = group['UpdatePolicy']['AutoScalingRollingUpdate']
|
policy = group['UpdatePolicy']['AutoScalingRollingUpdate']
|
||||||
@ -464,9 +470,7 @@ class AutoscalingGroupUpdatePolicyTest(AutoscalingGroupTest):
|
|||||||
update_replace=True)
|
update_replace=True)
|
||||||
|
|
||||||
def test_instance_group_update_replace_huge_min_in_service(self):
|
def test_instance_group_update_replace_huge_min_in_service(self):
|
||||||
"""
|
"""Update replace with huge number of minimum instances in service."""
|
||||||
Test update replace with a huge number of minimum instances in service.
|
|
||||||
"""
|
|
||||||
updt_template = self.ig_tmpl_with_updt_policy()
|
updt_template = self.ig_tmpl_with_updt_policy()
|
||||||
group = updt_template['Resources']['JobServerGroup']
|
group = updt_template['Resources']['JobServerGroup']
|
||||||
policy = group['UpdatePolicy']['AutoScalingRollingUpdate']
|
policy = group['UpdatePolicy']['AutoScalingRollingUpdate']
|
||||||
@ -483,7 +487,8 @@ class AutoscalingGroupUpdatePolicyTest(AutoscalingGroupTest):
|
|||||||
update_replace=True)
|
update_replace=True)
|
||||||
|
|
||||||
def test_instance_group_update_no_replace(self):
|
def test_instance_group_update_no_replace(self):
|
||||||
"""
|
"""Test simple update only and no replace.
|
||||||
|
|
||||||
Test simple update only and no replace (i.e. updated instance flavor
|
Test simple update only and no replace (i.e. updated instance flavor
|
||||||
in Launch Configuration) with no conflict in batch size and
|
in Launch Configuration) with no conflict in batch size and
|
||||||
minimum instances in service.
|
minimum instances in service.
|
||||||
@ -504,7 +509,8 @@ class AutoscalingGroupUpdatePolicyTest(AutoscalingGroupTest):
|
|||||||
update_replace=False)
|
update_replace=False)
|
||||||
|
|
||||||
def test_instance_group_update_no_replace_with_adjusted_capacity(self):
|
def test_instance_group_update_no_replace_with_adjusted_capacity(self):
|
||||||
"""
|
"""Test update only and no replace with capacity adjustment.
|
||||||
|
|
||||||
Test update only and no replace (i.e. updated instance flavor in
|
Test update only and no replace (i.e. updated instance flavor in
|
||||||
Launch Configuration) with capacity adjustment due to conflict in
|
Launch Configuration) with capacity adjustment due to conflict in
|
||||||
batch size and minimum instances in service.
|
batch size and minimum instances in service.
|
||||||
|
@ -82,7 +82,7 @@ resources:
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
def test_non_admin_forbidden_create_flavors(self):
|
def test_non_admin_forbidden_create_flavors(self):
|
||||||
"""Fail to create Flavor resource w/o admin role
|
"""Fail to create Flavor resource w/o admin role.
|
||||||
|
|
||||||
Integration tests job runs as normal OpenStack user,
|
Integration tests job runs as normal OpenStack user,
|
||||||
and OS::Nova:Flavor is configured to require
|
and OS::Nova:Flavor is configured to require
|
||||||
|
@ -332,7 +332,8 @@ resources:
|
|||||||
self.list_resources(nested_identifier))
|
self.list_resources(nested_identifier))
|
||||||
|
|
||||||
def test_stack_update_provider_group(self):
|
def test_stack_update_provider_group(self):
|
||||||
'''Test two-level nested update.'''
|
"""Test two-level nested update."""
|
||||||
|
|
||||||
# Create a ResourceGroup (which creates a nested stack),
|
# Create a ResourceGroup (which creates a nested stack),
|
||||||
# containing provider resources (which create a nested
|
# containing provider resources (which create a nested
|
||||||
# stack), thus exercising an update which traverses
|
# stack), thus exercising an update which traverses
|
||||||
@ -403,10 +404,12 @@ resources:
|
|||||||
self.list_resources(provider_identifier))
|
self.list_resources(provider_identifier))
|
||||||
|
|
||||||
def test_stack_update_with_replacing_userdata(self):
|
def test_stack_update_with_replacing_userdata(self):
|
||||||
"""Confirm that we can update userdata of instance during updating
|
"""Test case for updating userdata of instance.
|
||||||
stack by the user of member role.
|
|
||||||
|
|
||||||
Make sure that a resource that inherites from StackUser can be deleted
|
Confirm that we can update userdata of instance during updating stack
|
||||||
|
by the user of member role.
|
||||||
|
|
||||||
|
Make sure that a resource that inherits from StackUser can be deleted
|
||||||
during updating stack.
|
during updating stack.
|
||||||
"""
|
"""
|
||||||
if not self.conf.minimal_image_ref:
|
if not self.conf.minimal_image_ref:
|
||||||
|
@ -131,6 +131,7 @@ class InstanceGroupBasicTest(InstanceGroupTest):
|
|||||||
|
|
||||||
def test_basic_create_works(self):
|
def test_basic_create_works(self):
|
||||||
"""Make sure the working case is good.
|
"""Make sure the working case is good.
|
||||||
|
|
||||||
Note this combines test_override_aws_ec2_instance into this test as
|
Note this combines test_override_aws_ec2_instance into this test as
|
||||||
well, which is:
|
well, which is:
|
||||||
If AWS::EC2::Instance is overridden, InstanceGroup will automatically
|
If AWS::EC2::Instance is overridden, InstanceGroup will automatically
|
||||||
@ -177,8 +178,10 @@ class InstanceGroupBasicTest(InstanceGroupTest):
|
|||||||
self.assert_instance_count(stack, 5)
|
self.assert_instance_count(stack, 5)
|
||||||
|
|
||||||
def test_update_group_replace(self):
|
def test_update_group_replace(self):
|
||||||
"""Make sure that during a group update the non updatable
|
"""Test case for ensuring non-updatable props case a replacement.
|
||||||
properties cause a replacement.
|
|
||||||
|
Make sure that during a group update the non-updatable properties cause
|
||||||
|
a replacement.
|
||||||
"""
|
"""
|
||||||
files = {'provider.yaml': self.instance_template}
|
files = {'provider.yaml': self.instance_template}
|
||||||
env = {'resource_registry':
|
env = {'resource_registry':
|
||||||
@ -207,7 +210,9 @@ class InstanceGroupBasicTest(InstanceGroupTest):
|
|||||||
self.assertNotEqual(orig_asg_id, rsrc.physical_resource_id)
|
self.assertNotEqual(orig_asg_id, rsrc.physical_resource_id)
|
||||||
|
|
||||||
def test_create_instance_error_causes_group_error(self):
|
def test_create_instance_error_causes_group_error(self):
|
||||||
"""If a resource in an instance group fails to be created, the instance
|
"""Test create failing a resource in the instance group.
|
||||||
|
|
||||||
|
If a resource in an instance group fails to be created, the instance
|
||||||
group itself will fail and the broken inner resource will remain.
|
group itself will fail and the broken inner resource will remain.
|
||||||
"""
|
"""
|
||||||
stack_name = self._stack_rand_name()
|
stack_name = self._stack_rand_name()
|
||||||
@ -240,7 +245,9 @@ class InstanceGroupBasicTest(InstanceGroupTest):
|
|||||||
self._assert_instance_state(nested_ident, 0, 2)
|
self._assert_instance_state(nested_ident, 0, 2)
|
||||||
|
|
||||||
def test_update_instance_error_causes_group_error(self):
|
def test_update_instance_error_causes_group_error(self):
|
||||||
"""If a resource in an instance group fails to be created during an
|
"""Test update failing a resource in the instance group.
|
||||||
|
|
||||||
|
If a resource in an instance group fails to be created during an
|
||||||
update, the instance group itself will fail and the broken inner
|
update, the instance group itself will fail and the broken inner
|
||||||
resource will remain.
|
resource will remain.
|
||||||
"""
|
"""
|
||||||
@ -376,7 +383,8 @@ class InstanceGroupUpdatePolicyTest(InstanceGroupTest):
|
|||||||
self.assertNotIn(deletes_expected, updt_names)
|
self.assertNotIn(deletes_expected, updt_names)
|
||||||
|
|
||||||
def test_instance_group_update_replace(self):
|
def test_instance_group_update_replace(self):
|
||||||
"""
|
"""Test simple update replace with no conflict.
|
||||||
|
|
||||||
Test simple update replace with no conflict in batch size and
|
Test simple update replace with no conflict in batch size and
|
||||||
minimum instances in service.
|
minimum instances in service.
|
||||||
"""
|
"""
|
||||||
@ -395,7 +403,8 @@ class InstanceGroupUpdatePolicyTest(InstanceGroupTest):
|
|||||||
update_replace=True)
|
update_replace=True)
|
||||||
|
|
||||||
def test_instance_group_update_replace_with_adjusted_capacity(self):
|
def test_instance_group_update_replace_with_adjusted_capacity(self):
|
||||||
"""
|
"""Test update replace with capacity adjustment.
|
||||||
|
|
||||||
Test update replace with capacity adjustment due to conflict in
|
Test update replace with capacity adjustment due to conflict in
|
||||||
batch size and minimum instances in service.
|
batch size and minimum instances in service.
|
||||||
"""
|
"""
|
||||||
@ -414,9 +423,7 @@ class InstanceGroupUpdatePolicyTest(InstanceGroupTest):
|
|||||||
update_replace=True)
|
update_replace=True)
|
||||||
|
|
||||||
def test_instance_group_update_replace_huge_batch_size(self):
|
def test_instance_group_update_replace_huge_batch_size(self):
|
||||||
"""
|
"""Test update replace with a huge batch size."""
|
||||||
Test update replace with a huge batch size.
|
|
||||||
"""
|
|
||||||
updt_template = self.ig_tmpl_with_updt_policy()
|
updt_template = self.ig_tmpl_with_updt_policy()
|
||||||
group = updt_template['Resources']['JobServerGroup']
|
group = updt_template['Resources']['JobServerGroup']
|
||||||
policy = group['UpdatePolicy']['RollingUpdate']
|
policy = group['UpdatePolicy']['RollingUpdate']
|
||||||
@ -432,9 +439,7 @@ class InstanceGroupUpdatePolicyTest(InstanceGroupTest):
|
|||||||
update_replace=True)
|
update_replace=True)
|
||||||
|
|
||||||
def test_instance_group_update_replace_huge_min_in_service(self):
|
def test_instance_group_update_replace_huge_min_in_service(self):
|
||||||
"""
|
"""Update replace with huge number of minimum instances in service."""
|
||||||
Test update replace with a huge number of minimum instances in service.
|
|
||||||
"""
|
|
||||||
updt_template = self.ig_tmpl_with_updt_policy()
|
updt_template = self.ig_tmpl_with_updt_policy()
|
||||||
group = updt_template['Resources']['JobServerGroup']
|
group = updt_template['Resources']['JobServerGroup']
|
||||||
policy = group['UpdatePolicy']['RollingUpdate']
|
policy = group['UpdatePolicy']['RollingUpdate']
|
||||||
@ -451,7 +456,8 @@ class InstanceGroupUpdatePolicyTest(InstanceGroupTest):
|
|||||||
update_replace=True)
|
update_replace=True)
|
||||||
|
|
||||||
def test_instance_group_update_no_replace(self):
|
def test_instance_group_update_no_replace(self):
|
||||||
"""
|
"""Test simple update only and no replace with no conflict.
|
||||||
|
|
||||||
Test simple update only and no replace (i.e. updated instance flavor
|
Test simple update only and no replace (i.e. updated instance flavor
|
||||||
in Launch Configuration) with no conflict in batch size and
|
in Launch Configuration) with no conflict in batch size and
|
||||||
minimum instances in service.
|
minimum instances in service.
|
||||||
@ -472,7 +478,8 @@ class InstanceGroupUpdatePolicyTest(InstanceGroupTest):
|
|||||||
update_replace=False)
|
update_replace=False)
|
||||||
|
|
||||||
def test_instance_group_update_no_replace_with_adjusted_capacity(self):
|
def test_instance_group_update_no_replace_with_adjusted_capacity(self):
|
||||||
"""
|
"""Test update only and no replace with capacity adjustment.
|
||||||
|
|
||||||
Test update only and no replace (i.e. updated instance flavor in
|
Test update only and no replace (i.e. updated instance flavor in
|
||||||
Launch Configuration) with capacity adjustment due to conflict in
|
Launch Configuration) with capacity adjustment due to conflict in
|
||||||
batch size and minimum instances in service.
|
batch size and minimum instances in service.
|
||||||
|
@ -267,11 +267,13 @@ resources:
|
|||||||
self.assertEqual(initial_rand, updated_rand)
|
self.assertEqual(initial_rand, updated_rand)
|
||||||
|
|
||||||
def test_update_nochange_resource_needs_update(self):
|
def test_update_nochange_resource_needs_update(self):
|
||||||
"""Test update when the resource definition has changed."""
|
"""Test update when the resource definition has changed.
|
||||||
# Test the scenario when the ResourceGroup update happens without
|
|
||||||
# any changed properties, this can happen if the definition of
|
Test the scenario when the ResourceGroup update happens without
|
||||||
# a contained provider resource changes (files map changes), then
|
any changed properties, this can happen if the definition of
|
||||||
# the group and underlying nested stack should end up updated.
|
a contained provider resource changes (files map changes), then
|
||||||
|
the group and underlying nested stack should end up updated.
|
||||||
|
"""
|
||||||
|
|
||||||
random_templ1 = '''
|
random_templ1 = '''
|
||||||
heat_template_version: 2013-05-23
|
heat_template_version: 2013-05-23
|
||||||
|
@ -195,9 +195,12 @@ outputs:
|
|||||||
self.assertIn('arn:openstack:heat:', test_ref)
|
self.assertIn('arn:openstack:heat:', test_ref)
|
||||||
|
|
||||||
def test_transparent_ref(self):
|
def test_transparent_ref(self):
|
||||||
"""With the addition of OS::stack_id we can now use the nested resource
|
"""Test using nested resource more transparently.
|
||||||
|
|
||||||
|
With the addition of OS::stack_id we can now use the nested resource
|
||||||
more transparently.
|
more transparently.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
nested_templ = '''
|
nested_templ = '''
|
||||||
heat_template_version: 2014-10-16
|
heat_template_version: 2014-10-16
|
||||||
resources:
|
resources:
|
||||||
@ -520,6 +523,7 @@ Outputs:
|
|||||||
|
|
||||||
class TemplateResourceUpdateFailedTest(functional_base.FunctionalTestsBase):
|
class TemplateResourceUpdateFailedTest(functional_base.FunctionalTestsBase):
|
||||||
"""Prove that we can do updates on a nested stack to fix a stack."""
|
"""Prove that we can do updates on a nested stack to fix a stack."""
|
||||||
|
|
||||||
main_template = '''
|
main_template = '''
|
||||||
HeatTemplateFormatVersion: '2012-12-12'
|
HeatTemplateFormatVersion: '2012-12-12'
|
||||||
Resources:
|
Resources:
|
||||||
@ -688,6 +692,7 @@ Outputs:
|
|||||||
|
|
||||||
class TemplateResourceErrorMessageTest(functional_base.FunctionalTestsBase):
|
class TemplateResourceErrorMessageTest(functional_base.FunctionalTestsBase):
|
||||||
"""Prove that nested stack errors don't suck."""
|
"""Prove that nested stack errors don't suck."""
|
||||||
|
|
||||||
template = '''
|
template = '''
|
||||||
HeatTemplateFormatVersion: '2012-12-12'
|
HeatTemplateFormatVersion: '2012-12-12'
|
||||||
Resources:
|
Resources:
|
||||||
@ -743,7 +748,7 @@ resources:
|
|||||||
super(TemplateResourceSuspendResumeTest, self).setUp()
|
super(TemplateResourceSuspendResumeTest, self).setUp()
|
||||||
|
|
||||||
def test_suspend_resume(self):
|
def test_suspend_resume(self):
|
||||||
"""Basic test for template resource suspend resume"""
|
"""Basic test for template resource suspend resume."""
|
||||||
stack_identifier = self.stack_create(
|
stack_identifier = self.stack_create(
|
||||||
template=self.main_template,
|
template=self.main_template,
|
||||||
files={'the.yaml': self.nested_templ}
|
files={'the.yaml': self.nested_templ}
|
||||||
@ -755,6 +760,7 @@ resources:
|
|||||||
|
|
||||||
class ValidateFacadeTest(test.HeatIntegrationTest):
|
class ValidateFacadeTest(test.HeatIntegrationTest):
|
||||||
"""Prove that nested stack errors don't suck."""
|
"""Prove that nested stack errors don't suck."""
|
||||||
|
|
||||||
template = '''
|
template = '''
|
||||||
heat_template_version: 2015-10-15
|
heat_template_version: 2015-10-15
|
||||||
resources:
|
resources:
|
||||||
|
@ -14,7 +14,7 @@ from heat_integrationtests.common import test
|
|||||||
|
|
||||||
|
|
||||||
class ScenarioTestsBase(test.HeatIntegrationTest):
|
class ScenarioTestsBase(test.HeatIntegrationTest):
|
||||||
"This class define common parameters for scenario tests"
|
"""This class defines common parameters for scenario tests."""
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(ScenarioTestsBase, self).setUp()
|
super(ScenarioTestsBase, self).setUp()
|
||||||
|
@ -20,8 +20,7 @@ from heat_integrationtests.scenario import scenario_base
|
|||||||
|
|
||||||
|
|
||||||
class AutoscalingLoadBalancerTest(scenario_base.ScenarioTestsBase):
|
class AutoscalingLoadBalancerTest(scenario_base.ScenarioTestsBase):
|
||||||
"""
|
"""The class is responsible for testing ASG + LB scenario.
|
||||||
The class is responsible for testing ASG + LB scenario.
|
|
||||||
|
|
||||||
The very common use case tested is an autoscaling group
|
The very common use case tested is an autoscaling group
|
||||||
of some web application servers behind a loadbalancer.
|
of some web application servers behind a loadbalancer.
|
||||||
@ -52,8 +51,7 @@ class AutoscalingLoadBalancerTest(scenario_base.ScenarioTestsBase):
|
|||||||
return all_res and all_res_complete
|
return all_res and all_res_complete
|
||||||
|
|
||||||
def test_autoscaling_loadbalancer_neutron(self):
|
def test_autoscaling_loadbalancer_neutron(self):
|
||||||
"""
|
"""Check work of AutoScaing and Neutron LBaaS resource in Heat.
|
||||||
Check work of AutoScaing and Neutron LBaaS resource in Heat.
|
|
||||||
|
|
||||||
The scenario is the following:
|
The scenario is the following:
|
||||||
1. Launch a stack with a load balancer and autoscaling group
|
1. Launch a stack with a load balancer and autoscaling group
|
||||||
|
@ -17,9 +17,7 @@ from heat_integrationtests.scenario import scenario_base
|
|||||||
|
|
||||||
|
|
||||||
class CfnInitIntegrationTest(scenario_base.ScenarioTestsBase):
|
class CfnInitIntegrationTest(scenario_base.ScenarioTestsBase):
|
||||||
"""
|
"""Testing cfn-init and cfn-signal workability."""
|
||||||
The class is responsible for testing cfn-init and cfn-signal workability
|
|
||||||
"""
|
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(CfnInitIntegrationTest, self).setUp()
|
super(CfnInitIntegrationTest, self).setUp()
|
||||||
@ -94,8 +92,7 @@ class CfnInitIntegrationTest(scenario_base.ScenarioTestsBase):
|
|||||||
raise e
|
raise e
|
||||||
|
|
||||||
def test_server_cfn_init(self):
|
def test_server_cfn_init(self):
|
||||||
"""
|
"""Check cfn-init and cfn-signal availability on the created server.
|
||||||
Check cfn-init and cfn-signal availability on the created server.
|
|
||||||
|
|
||||||
The alternative scenario is the following:
|
The alternative scenario is the following:
|
||||||
1. Create a stack with a server and configured security group.
|
1. Create a stack with a server and configured security group.
|
||||||
|
@ -133,8 +133,7 @@ class SoftwareConfigIntegrationTest(scenario_base.ScenarioTestsBase):
|
|||||||
dep1_dep.creation_time)
|
dep1_dep.creation_time)
|
||||||
|
|
||||||
def test_server_software_config(self):
|
def test_server_software_config(self):
|
||||||
"""
|
"""Check that passed files with scripts are executed on created server.
|
||||||
Check that passed files with scripts are executed on created server.
|
|
||||||
|
|
||||||
The alternative scenario is the following:
|
The alternative scenario is the following:
|
||||||
1. Create a stack and pass files with scripts.
|
1. Create a stack and pass files with scripts.
|
||||||
|
@ -22,9 +22,7 @@ LOG = logging.getLogger(__name__)
|
|||||||
|
|
||||||
|
|
||||||
class VolumeBackupRestoreIntegrationTest(scenario_base.ScenarioTestsBase):
|
class VolumeBackupRestoreIntegrationTest(scenario_base.ScenarioTestsBase):
|
||||||
"""
|
"""Class is responsible for testing of volume backup."""
|
||||||
Class is responsible for testing of volume backup.
|
|
||||||
"""
|
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(VolumeBackupRestoreIntegrationTest, self).setUp()
|
super(VolumeBackupRestoreIntegrationTest, self).setUp()
|
||||||
@ -101,8 +99,7 @@ class VolumeBackupRestoreIntegrationTest(scenario_base.ScenarioTestsBase):
|
|||||||
volume_id2)
|
volume_id2)
|
||||||
|
|
||||||
def test_cinder_volume_create_backup_restore(self):
|
def test_cinder_volume_create_backup_restore(self):
|
||||||
"""
|
"""Ensure the 'Snapshot' deletion policy works.
|
||||||
Ensure the 'Snapshot' deletion policy works.
|
|
||||||
|
|
||||||
This requires a more complex test, but it tests several aspects
|
This requires a more complex test, but it tests several aspects
|
||||||
of the heat cinder resources:
|
of the heat cinder resources:
|
||||||
|
Loading…
Reference in New Issue
Block a user