From 23cc15687b33d7924d64d6d4603cdee994c80a5d Mon Sep 17 00:00:00 2001 From: Zane Bitter Date: Sun, 1 May 2016 19:06:09 -0500 Subject: [PATCH] Unit tests: Don't use ResourceDefinition as cfn snippet Eliminate from the unit tests the deprecated use of a ResourceDefinition as if it were a snippet from a CloudFormation template, in preparation for this being removed in future. Change-Id: I0449d3bff19c1294a9d0a475a4a9b623c73e11db --- .../tests/test_docker_container.py | 79 +++---- .../tests/test_cloud_loadbalancer.py | 196 ++++++++++-------- .../autoscaling/test_heat_scaling_group.py | 7 +- heat/tests/autoscaling/test_scaling_group.py | 15 +- heat/tests/aws/test_instance.py | 80 ++++--- heat/tests/aws/test_instance_network.py | 8 +- heat/tests/aws/test_loadbalancer.py | 15 +- heat/tests/engine/tools.py | 4 +- heat/tests/openstack/barbican/test_order.py | 39 ++-- .../ceilometer/test_ceilometer_alarm.py | 9 +- .../ceilometer/test_gnocchi_alarm.py | 36 ++-- .../openstack/cinder/test_volume_type.py | 32 ++- heat/tests/openstack/glance/test_image.py | 42 +++- .../heat/test_instance_group_update_policy.py | 15 +- .../openstack/heat/test_resource_group.py | 41 ++-- .../tests/openstack/keystone/test_endpoint.py | 14 +- heat/tests/openstack/keystone/test_service.py | 16 +- .../openstack/manila/test_security_service.py | 2 +- .../openstack/manila/test_share_network.py | 29 +-- .../neutron/test_neutron_firewall.py | 32 +-- .../neutron/test_neutron_loadbalancer.py | 33 +-- .../openstack/neutron/test_neutron_router.py | 10 +- .../neutron/test_neutron_subnetpool.py | 2 +- .../neutron/test_neutron_vpnservice.py | 14 +- heat/tests/openstack/nova/test_server.py | 186 ++++++++++------- .../openstack/sahara/test_data_source.py | 10 +- heat/tests/openstack/sahara/test_image.py | 10 +- .../tests/openstack/sahara/test_job_binary.py | 13 +- heat/tests/openstack/sahara/test_templates.py | 17 +- heat/tests/openstack/trove/test_cluster.py | 13 +- heat/tests/test_hot.py | 24 ++- heat/tests/test_nokey.py | 4 +- heat/tests/test_server_tags.py | 13 +- heat/tests/test_stack_update.py | 16 +- 34 files changed, 624 insertions(+), 452 deletions(-) diff --git a/contrib/heat_docker/heat_docker/tests/test_docker_container.py b/contrib/heat_docker/heat_docker/tests/test_docker_container.py index d5fd4d5b72..136549a380 100644 --- a/contrib/heat_docker/heat_docker/tests/test_docker_container.py +++ b/contrib/heat_docker/heat_docker/tests/test_docker_container.py @@ -96,9 +96,10 @@ class DockerContainerTest(common.HeatTestCase): t = template_format.parse(template) self.stack = utils.parse_stack(t) definition = self.stack.t.resource_definitions(self.stack)['Blog'] - definition['Properties']['name'] = 'super-blog' + props = t['Resources']['Blog']['Properties'].copy() + props['name'] = 'super-blog' resource = docker_container.DockerContainer( - 'Blog', definition, self.stack) + 'Blog', definition.freeze(properties=props), self.stack) self.m.StubOutWithMock(resource, 'get_client') resource.get_client().MultipleTimes().AndReturn( docker.Client()) @@ -136,11 +137,11 @@ class DockerContainerTest(common.HeatTestCase): t = template_format.parse(template) self.stack = utils.parse_stack(t) definition = self.stack.t.resource_definitions(self.stack)['Blog'] - definition['Properties']['port_bindings'] = { - '80/tcp': [{'HostPort': '80'}]} - definition['Properties']['links'] = {'db': 'mysql'} + props = t['Resources']['Blog']['Properties'].copy() + props['port_bindings'] = {'80/tcp': [{'HostPort': '80'}]} + props['links'] = {'db': 'mysql'} resource = docker_container.DockerContainer( - 'Blog', definition, self.stack) + 'Blog', definition.freeze(properties=props), self.stack) self.m.StubOutWithMock(resource, 'get_client') resource.get_client().MultipleTimes().AndReturn( docker.Client()) @@ -228,10 +229,10 @@ class DockerContainerTest(common.HeatTestCase): t = template_format.parse(template) self.stack = utils.parse_stack(t) definition = self.stack.t.resource_definitions(self.stack)['Blog'] - definition['Properties']['restart_policy'] = { - 'Name': 'no', 'MaximumRetryCount': 0} + props = t['Resources']['Blog']['Properties'].copy() + props['restart_policy'] = {'Name': 'no', 'MaximumRetryCount': 0} resource = docker_container.DockerContainer( - 'Blog', definition, self.stack) + 'Blog', definition.freeze(properties=props), self.stack) get_client_mock = self.patchobject(resource, 'get_client') get_client_mock.return_value = docker.Client() self.assertIsNone(resource.validate()) @@ -247,10 +248,11 @@ class DockerContainerTest(common.HeatTestCase): t = template_format.parse(template) self.stack = utils.parse_stack(t) definition = self.stack.t.resource_definitions(self.stack)['Blog'] - definition['Properties']['restart_policy'] = { - 'Name': 'on-failure', 'MaximumRetryCount': 10} + props = t['Resources']['Blog']['Properties'].copy() + props['restart_policy'] = {'Name': 'on-failure', + 'MaximumRetryCount': 10} resource = docker_container.DockerContainer( - 'Blog', definition, self.stack) + 'Blog', definition.freeze(properties=props), self.stack) get_client_mock = self.patchobject(resource, 'get_client') get_client_mock.return_value = docker.Client() self.assertIsNone(resource.validate()) @@ -266,10 +268,10 @@ class DockerContainerTest(common.HeatTestCase): t = template_format.parse(template) self.stack = utils.parse_stack(t) definition = self.stack.t.resource_definitions(self.stack)['Blog'] - definition['Properties']['restart_policy'] = { - 'Name': 'always', 'MaximumRetryCount': 0} + props = t['Resources']['Blog']['Properties'].copy() + props['restart_policy'] = {'Name': 'always', 'MaximumRetryCount': 0} resource = docker_container.DockerContainer( - 'Blog', definition, self.stack) + 'Blog', definition.freeze(properties=props), self.stack) get_client_mock = self.patchobject(resource, 'get_client') get_client_mock.return_value = docker.Client() self.assertIsNone(resource.validate()) @@ -285,10 +287,11 @@ class DockerContainerTest(common.HeatTestCase): t = template_format.parse(template) self.stack = utils.parse_stack(t) definition = self.stack.t.resource_definitions(self.stack)['Blog'] - definition['Properties']['cap_add'] = ['NET_ADMIN'] - definition['Properties']['cap_drop'] = ['MKNOD'] + props = t['Resources']['Blog']['Properties'].copy() + props['cap_add'] = ['NET_ADMIN'] + props['cap_drop'] = ['MKNOD'] resource = docker_container.DockerContainer( - 'Blog', definition, self.stack) + 'Blog', definition.freeze(properties=props), self.stack) get_client_mock = self.patchobject(resource, 'get_client') get_client_mock.return_value = docker.Client() self.assertIsNone(resource.validate()) @@ -304,9 +307,10 @@ class DockerContainerTest(common.HeatTestCase): t = template_format.parse(template) self.stack = utils.parse_stack(t) definition = self.stack.t.resource_definitions(self.stack)['Blog'] - definition['Properties']['read_only'] = True + props = t['Resources']['Blog']['Properties'].copy() + props['read_only'] = True resource = docker_container.DockerContainer( - 'Blog', definition, self.stack) + 'Blog', definition.freeze(properties=props), self.stack) get_client_mock = self.patchobject(resource, 'get_client') get_client_mock.return_value = docker.Client() get_client_mock.return_value.set_api_version('1.17') @@ -322,9 +326,10 @@ class DockerContainerTest(common.HeatTestCase): t = template_format.parse(template) self.stack = utils.parse_stack(t) definition = self.stack.t.resource_definitions(self.stack)['Blog'] - definition['Properties'][arg] = value + props = t['Resources']['Blog']['Properties'].copy() + props[arg] = value my_resource = docker_container.DockerContainer( - 'Blog', definition, self.stack) + 'Blog', definition.freeze(properties=props), self.stack) get_client_mock = self.patchobject(my_resource, 'get_client') get_client_mock.return_value = docker.Client() get_client_mock.return_value.set_api_version(low_version) @@ -348,9 +353,10 @@ class DockerContainerTest(common.HeatTestCase): t = template_format.parse(template) self.stack = utils.parse_stack(t) definition = self.stack.t.resource_definitions(self.stack)['Blog'] - definition['Properties']['cpu_shares'] = 512 + props = t['Resources']['Blog']['Properties'].copy() + props['cpu_shares'] = 512 my_resource = docker_container.DockerContainer( - 'Blog', definition, self.stack) + 'Blog', definition.freeze(properties=props), self.stack) get_client_mock = self.patchobject(my_resource, 'get_client') get_client_mock.return_value = docker.Client() self.assertIsNone(my_resource.validate()) @@ -368,7 +374,8 @@ class DockerContainerTest(common.HeatTestCase): t = template_format.parse(template) self.stack = utils.parse_stack(t) definition = self.stack.t.resource_definitions(self.stack)['Blog'] - definition['Properties']['devices'] = ( + props = t['Resources']['Blog']['Properties'].copy() + props['devices'] = ( [{'path_on_host': '/dev/sda', 'path_in_container': '/dev/xvdc', 'permissions': 'r'}, @@ -376,7 +383,7 @@ class DockerContainerTest(common.HeatTestCase): 'path_in_container': '/dev/xvdd', 'permissions': 'rw'}]) my_resource = docker_container.DockerContainer( - 'Blog', definition, self.stack) + 'Blog', definition.freeze(properties=props), self.stack) get_client_mock = self.patchobject(my_resource, 'get_client') get_client_mock.return_value = docker.Client() self.assertIsNone(my_resource.validate()) @@ -393,13 +400,14 @@ class DockerContainerTest(common.HeatTestCase): t = template_format.parse(template) self.stack = utils.parse_stack(t) definition = self.stack.t.resource_definitions(self.stack)['Blog'] - definition['Properties']['devices'] = ( + props = t['Resources']['Blog']['Properties'].copy() + props['devices'] = ( [{'path_on_host': '/dev/sdb', 'path_in_container': '/dev/xvdc', 'permissions': 'r'}]) - definition['Properties']['privileged'] = True + props['privileged'] = True my_resource = docker_container.DockerContainer( - 'Blog', definition, self.stack) + 'Blog', definition.freeze(properties=props), self.stack) get_client_mock = self.patchobject(my_resource, 'get_client') get_client_mock.return_value = docker.Client() self.assertIsNone(my_resource.validate()) @@ -420,11 +428,11 @@ class DockerContainerTest(common.HeatTestCase): t = template_format.parse(template) self.stack = utils.parse_stack(t) definition = self.stack.t.resource_definitions(self.stack)['Blog'] - definition['Properties']['devices'] = ( - [{'path_on_host': '/dev/sda', - 'permissions': 'rwm'}]) + props = t['Resources']['Blog']['Properties'].copy() + props['devices'] = [{'path_on_host': '/dev/sda', + 'permissions': 'rwm'}] my_resource = docker_container.DockerContainer( - 'Blog', definition, self.stack) + 'Blog', definition.freeze(properties=props), self.stack) get_client_mock = self.patchobject(my_resource, 'get_client') get_client_mock.return_value = docker.Client() self.assertIsNone(my_resource.validate()) @@ -440,9 +448,10 @@ class DockerContainerTest(common.HeatTestCase): t = template_format.parse(template) self.stack = utils.parse_stack(t) definition = self.stack.t.resource_definitions(self.stack)['Blog'] - definition['Properties']['cpu_set'] = '0-8,16-24,28' + props = t['Resources']['Blog']['Properties'].copy() + props['cpu_set'] = '0-8,16-24,28' my_resource = docker_container.DockerContainer( - 'Blog', definition, self.stack) + 'Blog', definition.freeze(properties=props), self.stack) get_client_mock = self.patchobject(my_resource, 'get_client') get_client_mock.return_value = docker.Client() self.assertIsNone(my_resource.validate()) diff --git a/contrib/rackspace/rackspace/tests/test_cloud_loadbalancer.py b/contrib/rackspace/rackspace/tests/test_cloud_loadbalancer.py index f8cb8a6050..ee5cbff4c1 100644 --- a/contrib/rackspace/rackspace/tests/test_cloud_loadbalancer.py +++ b/contrib/rackspace/rackspace/tests/test_cloud_loadbalancer.py @@ -316,26 +316,28 @@ class LoadBalancerTest(common.HeatTestCase): def setUp(self): super(LoadBalancerTest, self).setUp() + self.lb_props = { + "name": "test-clb", + "nodes": [{"addresses": ["166.78.103.141"], + "port": 80, + "condition": "ENABLED"}], + "protocol": "HTTP", + "port": 80, + "virtualIps": [ + {"type": "PUBLIC", "ipVersion": "IPV6"}], + "algorithm": 'LEAST_CONNECTIONS', + "connectionThrottle": {'maxConnectionRate': 1000}, + 'timeout': 110, + 'contentCaching': 'DISABLED' + } + self.lb_template = { "AWSTemplateFormatVersion": "2010-09-09", "Description": "fawef", "Resources": { self._get_lb_resource_name(): { "Type": "Rackspace::Cloud::LoadBalancer", - "Properties": { - "name": "test-clb", - "nodes": [{"addresses": ["166.78.103.141"], - "port": 80, - "condition": "ENABLED"}], - "protocol": "HTTP", - "port": 80, - "virtualIps": [ - {"type": "PUBLIC", "ipVersion": "IPV6"}], - "algorithm": 'LEAST_CONNECTIONS', - "connectionThrottle": {'maxConnectionRate': 1000}, - 'timeout': 110, - 'contentCaching': 'DISABLED' - } + "Properties": self.lb_props, } } } @@ -812,9 +814,9 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) + props = copy.deepcopy(self.lb_props) expected_ip = '172.168.1.4' - update_template['Properties']['nodes'] = [ + props['nodes'] = [ {"addresses": ["166.78.103.141"], "port": 80, "condition": "ENABLED", @@ -825,6 +827,7 @@ class LoadBalancerTest(common.HeatTestCase): "condition": "ENABLED", "type": "PRIMARY", "weight": 1}] + update_template = rsrc.t.freeze(properties=props) self.m.UnsetStubs() self.m.StubOutWithMock(rsrc.clb, 'get') @@ -894,9 +897,9 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) + props = copy.deepcopy(self.lb_props) expected_ip = '4.4.4.4' - update_template['Properties']['nodes'] = [ + props['nodes'] = [ {"addresses": ["1.1.1.1"], "port": 80, "condition": "ENABLED", "type": "PRIMARY", "weight": 1}, {"addresses": ["2.2.2.2"], "port": 80, "condition": "DISABLED", @@ -904,6 +907,7 @@ class LoadBalancerTest(common.HeatTestCase): {"addresses": [expected_ip], "port": 80, "condition": "ENABLED", "type": "PRIMARY", "weight": 1} ] + update_template = rsrc.t.freeze(properties=props) self.m.UnsetStubs() self.m.StubOutWithMock(rsrc.clb, 'get') @@ -978,8 +982,9 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['name'] = "updated_name" + props = copy.deepcopy(self.lb_props) + props['name'] = "updated_name" + update_template = rsrc.t.freeze(properties=props) self.m.UnsetStubs() self.m.StubOutWithMock(rsrc.clb, 'get') @@ -1005,8 +1010,9 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['name'] = "updated_name" + props = copy.deepcopy(self.lb_props) + props['name'] = "updated_name" + update_template = rsrc.t.freeze(properties=props) self.m.UnsetStubs() self.m.StubOutWithMock(rsrc.clb, 'get') @@ -1060,8 +1066,9 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['name'] = "updated_name" + props = copy.deepcopy(self.lb_props) + props['name'] = "updated_name" + update_template = rsrc.t.freeze(properties=props) self.m.UnsetStubs() self.m.StubOutWithMock(rsrc.clb, 'get') @@ -1085,9 +1092,10 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['name'] = "updated_name" - update_template['Properties']['algorithm'] = "RANDOM" + props = copy.deepcopy(self.lb_props) + props['name'] = "updated_name" + props['algorithm'] = "RANDOM" + update_template = rsrc.t.freeze(properties=props) self.m.UnsetStubs() self.m.StubOutWithMock(rsrc.clb, 'get') @@ -1115,8 +1123,9 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['algorithm'] = "RANDOM" + props = copy.deepcopy(self.lb_props) + props['algorithm'] = "RANDOM" + update_template = rsrc.t.freeze(properties=props) self.m.UnsetStubs() self.m.StubOutWithMock(rsrc.clb, 'get') @@ -1143,8 +1152,9 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['protocol'] = "IMAPS" + props = copy.deepcopy(self.lb_props) + props['protocol'] = "IMAPS" + update_template = rsrc.t.freeze(properties=props) self.m.UnsetStubs() self.m.StubOutWithMock(rsrc.clb, 'get') @@ -1174,8 +1184,9 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['httpsRedirect'] = True + props = copy.deepcopy(template['Resources'][rsrc.name]['Properties']) + props['httpsRedirect'] = True + update_template = rsrc.t.freeze(properties=props) self.m.UnsetStubs() self.m.StubOutWithMock(rsrc.clb, 'get') @@ -1261,8 +1272,9 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['halfClosed'] = True + props = copy.deepcopy(self.lb_props) + props['halfClosed'] = True + update_template = rsrc.t.freeze(properties=props) self.m.UnsetStubs() self.m.StubOutWithMock(rsrc.clb, 'get') @@ -1286,8 +1298,9 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['port'] = 1234 + props = copy.deepcopy(self.lb_props) + props['port'] = 1234 + update_template = rsrc.t.freeze(properties=props) self.m.UnsetStubs() self.m.StubOutWithMock(rsrc.clb, 'get') @@ -1311,8 +1324,9 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['timeout'] = 120 + props = copy.deepcopy(self.lb_props) + props['timeout'] = 120 + update_template = rsrc.t.freeze(properties=props) self.m.UnsetStubs() self.m.StubOutWithMock(rsrc.clb, 'get') @@ -1336,12 +1350,13 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['healthMonitor'] = { + props = copy.deepcopy(self.lb_props) + props['healthMonitor'] = { 'type': "HTTP", 'delay': 10, 'timeout': 10, 'attemptsBeforeDeactivation': 4, 'path': "/", 'statusRegex': "^[234][0-9][0-9]$", 'bodyRegex': ".* testing .*", 'hostHeader': "example.com"} + update_template = rsrc.t.freeze(properties=props) self.m.StubOutWithMock(fake_lb, 'get_health_monitor') fake_lb.get_health_monitor().AndReturn({}) @@ -1379,8 +1394,7 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - del update_template['Properties']['healthMonitor'] + update_template = rsrc.t.freeze(properties=self.lb_props) self.m.StubOutWithMock(fake_lb, 'get_health_monitor') fake_lb.get_health_monitor().AndReturn( @@ -1406,8 +1420,9 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['sessionPersistence'] = 'SOURCE_IP' + props = copy.deepcopy(self.lb_props) + props['sessionPersistence'] = 'SOURCE_IP' + update_template = rsrc.t.freeze(properties=props) self.m.ReplayAll() @@ -1430,8 +1445,7 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - del update_template['Properties']['sessionPersistence'] + update_template = rsrc.t.freeze(properties=self.lb_props) self.m.ReplayAll() @@ -1447,10 +1461,15 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['sslTermination'] = { - 'securePort': 443, 'privatekey': private_key, 'certificate': cert, - 'secureTrafficOnly': False, 'intermediateCertificate': ''} + props = copy.deepcopy(self.lb_props) + props['sslTermination'] = { + 'securePort': 443, + 'privatekey': private_key, + 'certificate': cert, + 'secureTrafficOnly': False, + 'intermediateCertificate': '' + } + update_template = rsrc.t.freeze(properties=props) self.m.StubOutWithMock(fake_lb, 'get_ssl_termination') fake_lb.get_ssl_termination().AndReturn({}) @@ -1497,8 +1516,7 @@ class LoadBalancerTest(common.HeatTestCase): scheduler.TaskRunner(rsrc.create)() self.m.UnsetStubs() - update_template = copy.deepcopy(rsrc.t) - del update_template['Properties']['sslTermination'] + update_template = rsrc.t.freeze(properties=self.lb_props) self.m.StubOutWithMock(rsrc.clb, 'get') rsrc.clb.get(mox.IgnoreArg()).MultipleTimes().AndReturn( @@ -1527,8 +1545,9 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['metadata'] = {'a': 1, 'b': 2} + props = copy.deepcopy(self.lb_props) + props['metadata'] = {'a': 1, 'b': 2} + update_template = rsrc.t.freeze(properties=props) self.m.StubOutWithMock(fake_lb, 'get_metadata') fake_lb.get_metadata().AndReturn({}) @@ -1557,8 +1576,7 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - del update_template['Properties']['metadata'] + update_template = rsrc.t.freeze(properties=self.lb_props) self.m.StubOutWithMock(fake_lb, 'get_metadata') fake_lb.get_metadata().AndReturn({'a': 1, 'b': 2}) @@ -1584,8 +1602,9 @@ class LoadBalancerTest(common.HeatTestCase): 'Service Unavailable

' 'Service Unavailable

The service is unavailable') - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['errorPage'] = error_page + props = copy.deepcopy(self.lb_props) + props['errorPage'] = error_page + update_template = rsrc.t.freeze(properties=props) self.m.StubOutWithMock(fake_lb, 'get_error_page') fake_lb.get_error_page().AndReturn( @@ -1627,8 +1646,7 @@ class LoadBalancerTest(common.HeatTestCase): scheduler.TaskRunner(rsrc.create)() self.m.UnsetStubs() - update_template = copy.deepcopy(rsrc.t) - del update_template['Properties']['errorPage'] + update_template = rsrc.t.freeze(properties=self.lb_props) self.m.StubOutWithMock(rsrc.clb, 'get') rsrc.clb.get(mox.IgnoreArg()).MultipleTimes().AndReturn( @@ -1655,8 +1673,9 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['connectionLogging'] = True + props = copy.deepcopy(self.lb_props) + props['connectionLogging'] = True + update_template = rsrc.t.freeze(properties=props) self.m.ReplayAll() scheduler.TaskRunner(rsrc.update, update_template)() @@ -1688,8 +1707,7 @@ class LoadBalancerTest(common.HeatTestCase): fake_lb2.connection_logging = False rsrc.clb.get(mox.IgnoreArg()).AndReturn(fake_lb2) - update_template = copy.deepcopy(rsrc.t) - del update_template['Properties']['connectionLogging'] + update_template = rsrc.t.freeze(properties=self.lb_props) self.m.ReplayAll() @@ -1712,8 +1730,9 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['connectionLogging'] = False + props = copy.deepcopy(self.lb_props) + props['connectionLogging'] = False + update_template = rsrc.t.freeze(properties=props) self.m.ReplayAll() @@ -1729,9 +1748,9 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['connectionThrottle'] = { - 'maxConnections': 1000} + props = copy.deepcopy(self.lb_props) + props['connectionThrottle'] = {'maxConnections': 1000} + update_template = rsrc.t.freeze(properties=props) self.m.StubOutWithMock(fake_lb, 'add_connection_throttle') self.m.StubOutWithMock(fake_lb, 'get_connection_throttle') @@ -1768,8 +1787,9 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - del update_template['Properties']['connectionThrottle'] + props = copy.deepcopy(self.lb_props) + del props['connectionThrottle'] + update_template = rsrc.t.freeze(properties=props) self.m.StubOutWithMock(fake_lb, 'get_connection_throttle') fake_lb.get_connection_throttle().AndReturn({ @@ -1793,8 +1813,9 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['contentCaching'] = 'ENABLED' + props = copy.deepcopy(self.lb_props) + props['contentCaching'] = 'ENABLED' + update_template = rsrc.t.freeze(properties=props) self.m.UnsetStubs() self.m.StubOutWithMock(rsrc.clb, 'get') @@ -1823,8 +1844,9 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - del update_template['Properties']['contentCaching'] + props = copy.deepcopy(self.lb_props) + del props['contentCaching'] + update_template = rsrc.t.freeze(properties=props) self.m.UnsetStubs() self.m.StubOutWithMock(rsrc.clb, 'get') @@ -1854,8 +1876,9 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['contentCaching'] = 'DISABLED' + props = copy.deepcopy(self.lb_props) + props['contentCaching'] = 'DISABLED' + update_template = rsrc.t.freeze(properties=props) self.m.UnsetStubs() self.m.StubOutWithMock(rsrc.clb, 'get') @@ -2051,9 +2074,9 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) + props = copy.deepcopy(self.lb_props) expected_ip = '172.168.1.4' - update_template['Properties']['nodes'] = [ + props['nodes'] = [ {"addresses": ["166.78.103.141"], "port": 80, "condition": "DRAINING", @@ -2064,6 +2087,7 @@ class LoadBalancerTest(common.HeatTestCase): "condition": "DRAINING", "type": "PRIMARY", "weight": 1}] + update_template = rsrc.t.freeze(properties=props) self.m.UnsetStubs() self.m.StubOutWithMock(rsrc.clb, 'get') @@ -2100,8 +2124,8 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['nodes'] = [ + props = copy.deepcopy(self.lb_props) + props['nodes'] = [ {"addresses": ["166.78.103.141"], "port": 80, "condition": "ENABLED", @@ -2112,6 +2136,7 @@ class LoadBalancerTest(common.HeatTestCase): "condition": "ENABLED", "type": "PRIMARY", "weight": 1}] + update_template = rsrc.t.freeze(properties=props) self.m.UnsetStubs() self.m.StubOutWithMock(rsrc.clb, 'get') @@ -2160,10 +2185,9 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['nodes'] = [ - {"addresses": ["166.78.103.141"], - "port": 80}] + props = copy.deepcopy(self.lb_props) + props['nodes'] = [{"addresses": ["166.78.103.141"], "port": 80}] + update_template = rsrc.t.freeze(properties=props) self.m.UnsetStubs() self.m.StubOutWithMock(rsrc.clb, 'get') diff --git a/heat/tests/autoscaling/test_heat_scaling_group.py b/heat/tests/autoscaling/test_heat_scaling_group.py index 58b13f24b7..94e442547e 100644 --- a/heat/tests/autoscaling/test_heat_scaling_group.py +++ b/heat/tests/autoscaling/test_heat_scaling_group.py @@ -561,14 +561,9 @@ class RollingUpdatePolicyDiffTest(common.HeatTestCase): else None) self.assertTrue(tmpl_diff.properties_changed()) - # test application of the new update policy in handle_update - update_snippet = rsrc_defn.ResourceDefinition( - current_grp.name, - current_grp.type(), - properties=updated_grp.t['Properties']) current_grp._try_rolling_update = mock.MagicMock() current_grp.resize = mock.MagicMock() - current_grp.handle_update(update_snippet, tmpl_diff, None) + current_grp.handle_update(updated_grp_json, tmpl_diff, None) if updated_policy is None: self.assertIsNone( current_grp.properties.data.get('rolling_updates')) diff --git a/heat/tests/autoscaling/test_scaling_group.py b/heat/tests/autoscaling/test_scaling_group.py index 2b96603832..2722015471 100644 --- a/heat/tests/autoscaling/test_scaling_group.py +++ b/heat/tests/autoscaling/test_scaling_group.py @@ -705,23 +705,14 @@ class RollingUpdatePolicyDiffTest(common.HeatTestCase): # identify the template difference tmpl_diff = updated_grp.update_template_diff( updated_grp_json, current_grp_json) - updated_policy = (updated_grp.t['UpdatePolicy'] - if 'UpdatePolicy' in updated_grp.t else None) self.assertTrue(tmpl_diff.update_policy_changed()) # test application of the new update policy in handle_update - update_snippet = rsrc_defn.ResourceDefinition( - current_grp.name, - current_grp.type(), - properties=updated_grp.t['Properties'], - update_policy=updated_policy) current_grp._try_rolling_update = mock.MagicMock() current_grp.resize = mock.MagicMock() - current_grp.handle_update(update_snippet, tmpl_diff, None) - if updated_policy is None: - self.assertEqual({}, current_grp.update_policy.data) - else: - self.assertEqual(updated_policy, current_grp.update_policy.data) + current_grp.handle_update(updated_grp_json, tmpl_diff, None) + self.assertEqual(updated_grp_json._update_policy or {}, + current_grp.update_policy.data) def test_update_policy_added(self): self.validate_update_policy_diff(inline_templates.as_template, diff --git a/heat/tests/aws/test_instance.py b/heat/tests/aws/test_instance.py index b26afc2bb9..a7d717f1eb 100644 --- a/heat/tests/aws/test_instance.py +++ b/heat/tests/aws/test_instance.py @@ -124,6 +124,7 @@ class InstancesTest(common.HeatTestCase): stack_name = '%s_s' % name tmpl, self.stack = self._get_test_template(stack_name, image_id, volumes=volumes) + self.instance_props = tmpl.t['Resources']['WebServer']['Properties'] resource_defns = tmpl.resource_definitions(self.stack) instance = instances.Instance(name, resource_defns['WebServer'], self.stack) @@ -723,8 +724,9 @@ class InstancesTest(common.HeatTestCase): instance = self._create_test_instance(return_server, 'ud_type') - update_template = copy.deepcopy(instance.t) - update_template['Properties']['InstanceType'] = 'm1.small' + update_props = self.instance_props.copy() + update_props['InstanceType'] = 'm1.small' + update_template = instance.t.freeze(properties=update_props) def side_effect(*args): return 2 if args[0] == 'm1.small' else 1 @@ -786,8 +788,9 @@ class InstancesTest(common.HeatTestCase): self.patchobject(glance.GlanceClientPlugin, 'find_image_by_name_or_id', return_value=1) - update_template = copy.deepcopy(instance.t) - update_template['Properties']['InstanceType'] = 'm1.small' + update_props = self.instance_props.copy() + update_props['InstanceType'] = 'm1.small' + update_template = instance.t.freeze(properties=update_props) self.m.StubOutWithMock(self.fc.servers, 'get') @@ -850,9 +853,13 @@ class InstancesTest(common.HeatTestCase): {'NetworkInterfaceId': '34b752ec-14de-416a-8722-9531015e04a5', 'DeviceIndex': '3'}] - instance.t['Properties']['NetworkInterfaces'] = old_interfaces - update_template = copy.deepcopy(instance.t) - update_template['Properties']['NetworkInterfaces'] = new_interfaces + before_props = self.instance_props.copy() + before_props['NetworkInterfaces'] = old_interfaces + update_props = self.instance_props.copy() + update_props['NetworkInterfaces'] = new_interfaces + update_template = instance.t.freeze(properties=update_props) + instance.t = instance.t.freeze(properties=before_props) + instance.reparse() self.m.StubOutWithMock(self.fc.servers, 'get') self.fc.servers.get('1234').MultipleTimes().AndReturn(return_server) @@ -889,9 +896,13 @@ class InstancesTest(common.HeatTestCase): {'NetworkInterfaceId': 'ea29f957-cd35-4364-98fb-57ce9732c10d', 'DeviceIndex': '2'}] - instance.t['Properties']['NetworkInterfaces'] = old_interfaces - update_template = copy.deepcopy(instance.t) - update_template['Properties']['NetworkInterfaces'] = new_interfaces + before_props = self.instance_props.copy() + before_props['NetworkInterfaces'] = old_interfaces + update_props = self.instance_props.copy() + update_props['NetworkInterfaces'] = new_interfaces + update_template = instance.t.freeze(properties=update_props) + instance.t = instance.t.freeze(properties=before_props) + instance.reparse() self.m.StubOutWithMock(self.fc.servers, 'get') self.fc.servers.get('1234').MultipleTimes().AndReturn(return_server) @@ -925,9 +936,13 @@ class InstancesTest(common.HeatTestCase): {'NetworkInterfaceId': 'd1e9c73c-04fe-4e9e-983c-d5ef94cd1a46', 'DeviceIndex': '1'}] - instance.t['Properties']['NetworkInterfaces'] = old_interfaces - update_template = copy.deepcopy(instance.t) - update_template['Properties']['NetworkInterfaces'] = new_interfaces + before_props = self.instance_props.copy() + before_props['NetworkInterfaces'] = old_interfaces + update_props = self.instance_props.copy() + update_props['NetworkInterfaces'] = new_interfaces + update_template = instance.t.freeze(properties=update_props) + instance.t = instance.t.freeze(properties=before_props) + instance.reparse() self.m.StubOutWithMock(self.fc.servers, 'get') self.fc.servers.get('1234').MultipleTimes().AndReturn(return_server) @@ -961,9 +976,13 @@ class InstancesTest(common.HeatTestCase): {'NetworkInterfaceId': 'd1e9c73c-04fe-4e9e-983c-d5ef94cd1a46', 'DeviceIndex': '1'}] - instance.t['Properties']['NetworkInterfaces'] = old_interfaces - update_template = copy.deepcopy(instance.t) - update_template['Properties']['NetworkInterfaces'] = new_interfaces + before_props = self.instance_props.copy() + before_props['NetworkInterfaces'] = old_interfaces + update_props = self.instance_props.copy() + update_props['NetworkInterfaces'] = new_interfaces + update_template = instance.t.freeze(properties=update_props) + instance.t = instance.t.freeze(properties=before_props) + instance.reparse() self.m.StubOutWithMock(self.fc.servers, 'get') self.fc.servers.get('1234').MultipleTimes().AndReturn(return_server) @@ -1001,8 +1020,9 @@ class InstancesTest(common.HeatTestCase): 'c4485ba1-283a-4f5f-8868-0cd46cdda52f', '10.0.0.4') - update_template = copy.deepcopy(instance.t) - update_template['Properties']['NetworkInterfaces'] = new_interfaces + update_props = self.instance_props.copy() + update_props['NetworkInterfaces'] = new_interfaces + update_template = instance.t.freeze(properties=update_props) self.m.StubOutWithMock(self.fc.servers, 'get') self.fc.servers.get('1234').MultipleTimes().AndReturn(return_server) @@ -1037,8 +1057,9 @@ class InstancesTest(common.HeatTestCase): 'c4485ba1-283a-4f5f-8868-0cd46cdda52f', '10.0.0.4') - update_template = copy.deepcopy(instance.t) - update_template['Properties']['NetworkInterfaces'] = [] + update_props = self.instance_props.copy() + update_props['NetworkInterfaces'] = [] + update_template = instance.t.freeze(properties=update_props) self.m.StubOutWithMock(self.fc.servers, 'get') self.fc.servers.get('1234').MultipleTimes().AndReturn(return_server) @@ -1069,12 +1090,18 @@ class InstancesTest(common.HeatTestCase): '10.0.0.4') subnet_id = '8c1aaddf-e49e-4f28-93ea-ca9f0b3c6240' nics = [{'port-id': 'ea29f957-cd35-4364-98fb-57ce9732c10d'}] + + before_props = self.instance_props.copy() if old_interfaces is not None: - instance.t['Properties']['NetworkInterfaces'] = old_interfaces - update_template = copy.deepcopy(instance.t) + before_props['NetworkInterfaces'] = old_interfaces + update_props = self.instance_props.copy() if new_interfaces is not None: - update_template['Properties']['NetworkInterfaces'] = new_interfaces - update_template['Properties']['SubnetId'] = subnet_id + update_props['NetworkInterfaces'] = new_interfaces + update_props['SubnetId'] = subnet_id + + update_template = instance.t.freeze(properties=update_props) + instance.t = instance.t.freeze(properties=before_props) + instance.reparse() self.m.StubOutWithMock(self.fc.servers, 'get') @@ -1133,8 +1160,9 @@ class InstancesTest(common.HeatTestCase): self.stub_ImageConstraint_validate() self.m.ReplayAll() - update_template = copy.deepcopy(instance.t) - update_template['Properties']['ImageId'] = 'mustreplace' + update_props = self.instance_props.copy() + update_props['ImageId'] = 'mustreplace' + update_template = instance.t.freeze(properties=update_props) updater = scheduler.TaskRunner(instance.update, update_template) self.assertRaises(exception.UpdateReplace, updater) diff --git a/heat/tests/aws/test_instance_network.py b/heat/tests/aws/test_instance_network.py index d71b198351..f0750747ed 100644 --- a/heat/tests/aws/test_instance_network.py +++ b/heat/tests/aws/test_instance_network.py @@ -228,12 +228,12 @@ class instancesTest(common.HeatTestCase): # need to resolve the template functions server_userdata = instance.client_plugin().build_userdata( metadata, - instance.t['Properties']['UserData'], + instance.properties['UserData'], 'ec2-user') self.m.StubOutWithMock(nova.NovaClientPlugin, 'build_userdata') nova.NovaClientPlugin.build_userdata( metadata, - instance.t['Properties']['UserData'], + instance.properties['UserData'], 'ec2-user').AndReturn(server_userdata) self.m.StubOutWithMock(self.fc.servers, 'create') @@ -288,12 +288,12 @@ class instancesTest(common.HeatTestCase): # need to resolve the template functions server_userdata = instance.client_plugin().build_userdata( metadata, - instance.t['Properties']['UserData'], + instance.properties['UserData'], 'ec2-user') self.m.StubOutWithMock(nova.NovaClientPlugin, 'build_userdata') nova.NovaClientPlugin.build_userdata( metadata, - instance.t['Properties']['UserData'], + instance.properties['UserData'], 'ec2-user').AndReturn(server_userdata) self.m.StubOutWithMock(self.fc.servers, 'create') diff --git a/heat/tests/aws/test_loadbalancer.py b/heat/tests/aws/test_loadbalancer.py index 7150d12d0c..0b53a5ea66 100644 --- a/heat/tests/aws/test_loadbalancer.py +++ b/heat/tests/aws/test_loadbalancer.py @@ -128,27 +128,25 @@ class LoadBalancerTest(common.HeatTestCase): md.metadata_set.assert_called_once_with(expected_md) def test_loadbalancer_validate_hchk_good(self): - rsrc = self.setup_loadbalancer() - rsrc._parse_nested_stack = mock.Mock() hc = { 'Target': 'HTTP:80/', 'HealthyThreshold': '3', 'UnhealthyThreshold': '5', 'Interval': '30', 'Timeout': '5'} - rsrc.t['Properties']['HealthCheck'] = hc + rsrc = self.setup_loadbalancer(hc=hc) + rsrc._parse_nested_stack = mock.Mock() self.assertIsNone(rsrc.validate()) def test_loadbalancer_validate_hchk_int_gt_tmo(self): - rsrc = self.setup_loadbalancer() - rsrc._parse_nested_stack = mock.Mock() hc = { 'Target': 'HTTP:80/', 'HealthyThreshold': '3', 'UnhealthyThreshold': '5', 'Interval': '30', 'Timeout': '35'} - rsrc.t['Properties']['HealthCheck'] = hc + rsrc = self.setup_loadbalancer(hc=hc) + rsrc._parse_nested_stack = mock.Mock() self.assertEqual( {'Error': 'Interval must be larger than Timeout'}, rsrc.validate()) @@ -159,12 +157,15 @@ class LoadBalancerTest(common.HeatTestCase): rsrc = self.setup_loadbalancer() self.assertRaises(exception.StackValidationFailed, rsrc.validate) - def setup_loadbalancer(self, include_magic=True, cache_data=None): + def setup_loadbalancer(self, include_magic=True, cache_data=None, hc=None): template = template_format.parse(lb_template) if not include_magic: del template['Parameters']['KeyName'] del template['Parameters']['LbFlavor'] del template['Parameters']['LbImageId'] + if hc is not None: + props = template['Resources']['LoadBalancer']['Properties'] + props['HealthCheck'] = hc self.stack = utils.parse_stack(template, cache_data=cache_data) resource_name = 'LoadBalancer' diff --git a/heat/tests/engine/tools.py b/heat/tests/engine/tools.py index a92d7f94b4..9f3474d1b8 100644 --- a/heat/tests/engine/tools.py +++ b/heat/tests/engine/tools.py @@ -192,7 +192,7 @@ def setup_mocks(mocks, stack, mock_image_constraint=True, metadata = instance.metadata_get() if mock_image_constraint: setup_mock_for_image_constraint(mocks, - instance.t['Properties']['ImageId']) + instance.properties['ImageId']) if mock_keystone: setup_keystone_mocks(mocks, stack) @@ -203,7 +203,7 @@ def setup_mocks(mocks, stack, mock_image_constraint=True, mocks.StubOutWithMock(nova.NovaClientPlugin, 'build_userdata') nova.NovaClientPlugin.build_userdata( metadata, - instance.t['Properties']['UserData'], + user_data, 'ec2-user').AndReturn(server_userdata) mocks.StubOutWithMock(fc.servers, 'create') diff --git a/heat/tests/openstack/barbican/test_order.py b/heat/tests/openstack/barbican/test_order.py index f646e0ff10..840bd31102 100644 --- a/heat/tests/openstack/barbican/test_order.py +++ b/heat/tests/openstack/barbican/test_order.py @@ -11,8 +11,6 @@ # License for the specific language governing permissions and limitations # under the License. -import copy - import mock import six @@ -87,8 +85,10 @@ class TestOrder(common.HeatTestCase): self.assertEqual(256, args['bit_length']) def test_create_order_without_type_fail(self): - snippet = copy.deepcopy(self.res_template) - del snippet['Properties']['type'] + props = self.props.copy() + del props['type'] + snippet = self.res_template.freeze(properties=props) + self.assertRaisesRegexp(exception.ResourceFailure, 'Property type not assigned', self._create_resource, @@ -96,9 +96,10 @@ class TestOrder(common.HeatTestCase): snippet, self.stack) def test_validate_non_certificate_order(self): - snippet = copy.deepcopy(self.res_template) - del snippet['Properties']['bit_length'] - del snippet['Properties']['algorithm'] + props = self.props.copy() + del props['bit_length'] + del props['algorithm'] + snippet = self.res_template.freeze(properties=props) res = self._create_resource('test', snippet, self.stack) msg = ("Properties algorithm and bit_length are required for " "key type of order.") @@ -107,9 +108,10 @@ class TestOrder(common.HeatTestCase): res.validate) def test_validate_certificate_with_profile_without_ca_id(self): - snippet = copy.deepcopy(self.res_template) - snippet['Properties']['profile'] = 'cert' - snippet['Properties']['type'] = 'certificate' + props = self.props.copy() + props['profile'] = 'cert' + props['type'] = 'certificate' + snippet = self.res_template.freeze(properties=props) res = self._create_resource('test', snippet, self.stack) msg = ("profile cannot be specified without ca_id.") self.assertRaisesRegexp(exception.ResourcePropertyDependency, @@ -117,8 +119,9 @@ class TestOrder(common.HeatTestCase): res.validate) def test_key_order_validation_fail(self): - snippet = copy.deepcopy(self.res_template) - snippet['Properties']['pass_phrase'] = "something" + props = self.props.copy() + props['pass_phrase'] = "something" + snippet = self.res_template.freeze(properties=props) res = self._create_resource('test', snippet, self.stack) msg = ("Unexpected properties: pass_phrase. Only these properties " "are allowed for key type of order: algorithm, " @@ -128,8 +131,9 @@ class TestOrder(common.HeatTestCase): res.validate) def test_certificate_validation_fail(self): - snippet = copy.deepcopy(self.res_template) - snippet['Properties']['type'] = 'certificate' + props = self.props.copy() + props['type'] = 'certificate' + snippet = self.res_template.freeze(properties=props) res = self._create_resource('test', snippet, self.stack) msg = ("Unexpected properties: algorithm, bit_length, mode. Only " "these properties are allowed for certificate type of order: " @@ -140,9 +144,10 @@ class TestOrder(common.HeatTestCase): res.validate) def test_asymmetric_order_validation_fail(self): - snippet = copy.deepcopy(self.res_template) - snippet['Properties']['type'] = 'asymmetric' - snippet['Properties']['subject_dn'] = 'asymmetric' + props = self.props.copy() + props['type'] = 'asymmetric' + props['subject_dn'] = 'asymmetric' + snippet = self.res_template.freeze(properties=props) res = self._create_resource('test', snippet, self.stack) msg = ("Unexpected properties: subject_dn. Only these properties are " "allowed for asymmetric type of order: algorithm, bit_length, " diff --git a/heat/tests/openstack/ceilometer/test_ceilometer_alarm.py b/heat/tests/openstack/ceilometer/test_ceilometer_alarm.py index ba4e67d303..98dd7c91f5 100644 --- a/heat/tests/openstack/ceilometer/test_ceilometer_alarm.py +++ b/heat/tests/openstack/ceilometer/test_ceilometer_alarm.py @@ -668,8 +668,8 @@ class CombinationAlarmTest(common.HeatTestCase): time_constraints=[], severity='low' ).AndReturn(FakeCeilometerAlarm()) - snippet = template_format.parse(combination_alarm_template) - self.stack = utils.parse_stack(snippet) + self.tmpl = template_format.parse(combination_alarm_template) + self.stack = utils.parse_stack(self.tmpl) resource_defns = self.stack.t.resource_definitions(self.stack) return alarm.CombinationAlarm( 'CombinAlarm', resource_defns['CombinAlarm'], self.stack) @@ -707,8 +707,9 @@ class CombinationAlarmTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['alarm_ids'] = ['alarm1', 'alarm3'] + props = self.tmpl['Resources']['CombinAlarm']['Properties'].copy() + props['alarm_ids'] = ['alarm1', 'alarm3'] + update_template = rsrc.t.freeze(properties=props) scheduler.TaskRunner(rsrc.update, update_template)() self.assertEqual((rsrc.UPDATE, rsrc.COMPLETE), rsrc.state) diff --git a/heat/tests/openstack/ceilometer/test_gnocchi_alarm.py b/heat/tests/openstack/ceilometer/test_gnocchi_alarm.py index 77976ffbcc..011dbb3c86 100644 --- a/heat/tests/openstack/ceilometer/test_gnocchi_alarm.py +++ b/heat/tests/openstack/ceilometer/test_gnocchi_alarm.py @@ -11,8 +11,6 @@ # License for the specific language governing permissions and limitations # under the License. -import copy - import mock import mox @@ -121,8 +119,8 @@ class GnocchiResourcesAlarmTest(common.HeatTestCase): time_constraints=[], severity='low', ).AndReturn(FakeCeilometerAlarm()) - snippet = template_format.parse(gnocchi_resources_alarm_template) - self.stack = utils.parse_stack(snippet) + self.tmpl = template_format.parse(gnocchi_resources_alarm_template) + self.stack = utils.parse_stack(self.tmpl) resource_defns = self.stack.t.resource_definitions(self.stack) return gnocchi.CeilometerGnocchiResourcesAlarm( 'GnoResAlarm', resource_defns['GnoResAlarm'], self.stack) @@ -138,9 +136,9 @@ class GnocchiResourcesAlarmTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['resource_id'] = ( - 'd3d6c642-921e-4fc2-9c5f-15d9a5afb598') + props = self.tmpl['resources']['GnoResAlarm']['properties'] + props['resource_id'] = 'd3d6c642-921e-4fc2-9c5f-15d9a5afb598' + update_template = rsrc.t.freeze(properties=props) scheduler.TaskRunner(rsrc.update, update_template)() self.assertEqual((rsrc.UPDATE, rsrc.COMPLETE), rsrc.state) @@ -242,9 +240,9 @@ class GnocchiAggregationByMetricsAlarmTest(GnocchiResourcesAlarmTest): time_constraints=[], severity='low', ).AndReturn(FakeCeilometerAlarm()) - snippet = template_format.parse( + self.tmpl = template_format.parse( gnocchi_aggregation_by_metrics_alarm_template) - self.stack = utils.parse_stack(snippet) + self.stack = utils.parse_stack(self.tmpl) resource_defns = self.stack.t.resource_definitions(self.stack) return gnocchi.CeilometerGnocchiAggregationByMetricsAlarm( 'GnoAggregationByMetricsAlarm', @@ -262,10 +260,11 @@ class GnocchiAggregationByMetricsAlarmTest(GnocchiResourcesAlarmTest): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['metrics'] = [ - 'd3d6c642-921e-4fc2-9c5f-15d9a5afb598', - 'bc60f822-18a0-4a0c-94e7-94c554b00901'] + snippet = self.tmpl['resources']['GnoAggregationByMetricsAlarm'] + props = snippet['properties'].copy() + props['metrics'] = ['d3d6c642-921e-4fc2-9c5f-15d9a5afb598', + 'bc60f822-18a0-4a0c-94e7-94c554b00901'] + update_template = rsrc.t.freeze(properties=props) scheduler.TaskRunner(rsrc.update, update_template)() self.assertEqual((rsrc.UPDATE, rsrc.COMPLETE), rsrc.state) @@ -319,9 +318,9 @@ class GnocchiAggregationByResourcesAlarmTest(GnocchiResourcesAlarmTest): time_constraints=[], severity='low', ).AndReturn(FakeCeilometerAlarm()) - snippet = template_format.parse( + self.tmpl = template_format.parse( gnocchi_aggregation_by_resources_alarm_template) - self.stack = utils.parse_stack(snippet) + self.stack = utils.parse_stack(self.tmpl) resource_defns = self.stack.t.resource_definitions(self.stack) return gnocchi.CeilometerGnocchiAggregationByResourcesAlarm( 'GnoAggregationByResourcesAlarm', @@ -338,9 +337,10 @@ class GnocchiAggregationByResourcesAlarmTest(GnocchiResourcesAlarmTest): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['query'] = ( - '{"=": {"server_group": "my_new_group"}}') + snippet = self.tmpl['resources']['GnoAggregationByResourcesAlarm'] + props = snippet['properties'].copy() + props['query'] = '{"=": {"server_group": "my_new_group"}}' + update_template = rsrc.t.freeze(properties=props) scheduler.TaskRunner(rsrc.update, update_template)() self.assertEqual((rsrc.UPDATE, rsrc.COMPLETE), rsrc.state) diff --git a/heat/tests/openstack/cinder/test_volume_type.py b/heat/tests/openstack/cinder/test_volume_type.py index 8e0ea9f51d..24276e8ccd 100644 --- a/heat/tests/openstack/cinder/test_volume_type.py +++ b/heat/tests/openstack/cinder/test_volume_type.py @@ -61,12 +61,16 @@ class CinderVolumeTypeTest(common.HeatTestCase): volume_type_id = '927202df-1afb-497f-8368-9c2d2f26e5db' value.id = volume_type_id self.volume_types.create.return_value = value - self.my_volume_type.t['Properties']['is_public'] = is_public + tmpl = self.stack.t.t + props = tmpl['resources']['my_volume_type']['properties'].copy() + props['is_public'] = is_public if projects: - self.my_volume_type.t['Properties']['projects'] = projects + props['projects'] = projects project = collections.namedtuple('Project', ['id']) stub_projects = [project(p) for p in projects] self.project_list.side_effect = [p for p in stub_projects] + self.my_volume_type.t = self.my_volume_type.t.freeze(properties=props) + self.my_volume_type.reparse() self.my_volume_type.handle_create() self.volume_types.create.assert_called_once_with( name='volumeBackend', is_public=is_public, description=None) @@ -166,8 +170,12 @@ class CinderVolumeTypeTest(common.HeatTestCase): self.my_volume_type.resource_id, 'id3') def test_validate_projects_in_v1(self): - self.my_volume_type.t['Properties']['is_public'] = False - self.my_volume_type.t['Properties']['projects'] = ['id1'] + tmpl = self.stack.t.t + props = tmpl['resources']['my_volume_type']['properties'].copy() + props['is_public'] = False + props['projects'] = ['id1'] + self.my_volume_type.t = self.my_volume_type.t.freeze(properties=props) + self.my_volume_type.reparse() self.cinderclient.volume_api_version = 1 self.stub_KeystoneProjectConstraint() ex = self.assertRaises(exception.NotSupported, @@ -176,8 +184,12 @@ class CinderVolumeTypeTest(common.HeatTestCase): self.assertEqual(expected, six.text_type(ex)) def test_validate_projects_when_public(self): - self.my_volume_type.t['Properties']['projects'] = ['id1'] - self.my_volume_type.t['Properties']['is_public'] = True + tmpl = self.stack.t.t + props = tmpl['resources']['my_volume_type']['properties'].copy() + props['is_public'] = True + props['projects'] = ['id1'] + self.my_volume_type.t = self.my_volume_type.t.freeze(properties=props) + self.my_volume_type.reparse() self.cinderclient.volume_api_version = 2 self.stub_KeystoneProjectConstraint() ex = self.assertRaises(exception.StackValidationFailed, @@ -187,8 +199,12 @@ class CinderVolumeTypeTest(common.HeatTestCase): self.assertEqual(expected, six.text_type(ex)) def test_validate_projects_when_private(self): - self.my_volume_type.t['Properties']['projects'] = ['id1'] - self.my_volume_type.t['Properties']['is_public'] = False + tmpl = self.stack.t.t + props = tmpl['resources']['my_volume_type']['properties'].copy() + props['is_public'] = False + props['projects'] = ['id1'] + self.my_volume_type.t = self.my_volume_type.t.freeze(properties=props) + self.my_volume_type.reparse() self.cinderclient.volume_api_version = 2 self.stub_KeystoneProjectConstraint() self.assertIsNone(self.my_volume_type.validate()) diff --git a/heat/tests/openstack/glance/test_image.py b/heat/tests/openstack/glance/test_image.py index a3987424e1..fdbd56ca4f 100644 --- a/heat/tests/openstack/glance/test_image.py +++ b/heat/tests/openstack/glance/test_image.py @@ -86,7 +86,10 @@ class GlanceImageTest(common.HeatTestCase): template.Template(tpl) ) image = stack['image'] - image.t['Properties']['min_disk'] = -1 + props = stack.t.t['resources']['image']['properties'].copy() + props['min_disk'] = -1 + image.t = image.t.freeze(properties=props) + image.reparse() error_msg = ('Property error: resources.image.properties.min_disk: ' '-1 is out of range (min: 0, max: None)') self._test_validate(image, error_msg) @@ -99,7 +102,10 @@ class GlanceImageTest(common.HeatTestCase): template.Template(tpl) ) image = stack['image'] - image.t['Properties']['min_ram'] = -1 + props = stack.t.t['resources']['image']['properties'].copy() + props['min_ram'] = -1 + image.t = image.t.freeze(properties=props) + image.reparse() error_msg = ('Property error: resources.image.properties.min_ram: ' '-1 is out of range (min: 0, max: None)') self._test_validate(image, error_msg) @@ -112,7 +118,10 @@ class GlanceImageTest(common.HeatTestCase): template.Template(tpl) ) image = stack['image'] - image.t['Properties'].pop('disk_format') + props = stack.t.t['resources']['image']['properties'].copy() + del props['disk_format'] + image.t = image.t.freeze(properties=props) + image.reparse() error_msg = 'Property disk_format not assigned' self._test_validate(image, error_msg) @@ -124,7 +133,10 @@ class GlanceImageTest(common.HeatTestCase): template.Template(tpl) ) image = stack['image'] - image.t['Properties']['disk_format'] = 'incorrect_format' + props = stack.t.t['resources']['image']['properties'].copy() + props['disk_format'] = 'incorrect_format' + image.t = image.t.freeze(properties=props) + image.reparse() error_msg = ('Property error: ' 'resources.image.properties.disk_format: ' '"incorrect_format" is not an allowed value ' @@ -139,7 +151,10 @@ class GlanceImageTest(common.HeatTestCase): template.Template(tpl) ) image = stack['image'] - image.t['Properties'].pop('container_format') + props = stack.t.t['resources']['image']['properties'].copy() + del props['container_format'] + image.t = image.t.freeze(properties=props) + image.reparse() error_msg = 'Property container_format not assigned' self._test_validate(image, error_msg) @@ -151,7 +166,10 @@ class GlanceImageTest(common.HeatTestCase): template.Template(tpl) ) image = stack['image'] - image.t['Properties']['container_format'] = 'incorrect_format' + props = stack.t.t['resources']['image']['properties'].copy() + props['container_format'] = 'incorrect_format' + image.t = image.t.freeze(properties=props) + image.reparse() error_msg = ('Property error: ' 'resources.image.properties.container_format: ' '"incorrect_format" is not an allowed value ' @@ -166,7 +184,10 @@ class GlanceImageTest(common.HeatTestCase): template.Template(tpl) ) image = stack['image'] - image.t['Properties'].pop('location') + props = stack.t.t['resources']['image']['properties'].copy() + del props['location'] + image.t = image.t.freeze(properties=props) + image.reparse() error_msg = 'Property location not assigned' self._test_validate(image, error_msg) @@ -177,8 +198,11 @@ class GlanceImageTest(common.HeatTestCase): template.Template(tpl) ) image = stack['image'] - image.t['Properties']['disk_format'] = 'raw' - image.t['Properties']['container_format'] = 'ari' + props = stack.t.t['resources']['image']['properties'].copy() + props['disk_format'] = 'raw' + props['container_format'] = 'ari' + image.t = image.t.freeze(properties=props) + image.reparse() error_msg = ("Invalid mix of disk and container formats. When " "setting a disk or container format to one of 'aki', " "'ari', or 'ami', the container and disk formats must " diff --git a/heat/tests/openstack/heat/test_instance_group_update_policy.py b/heat/tests/openstack/heat/test_instance_group_update_policy.py index e5fe7f57ed..9add242492 100644 --- a/heat/tests/openstack/heat/test_instance_group_update_policy.py +++ b/heat/tests/openstack/heat/test_instance_group_update_policy.py @@ -245,23 +245,14 @@ class InstanceGroupTest(common.HeatTestCase): # identify the template difference tmpl_diff = updated_grp.update_template_diff( updated_grp_json, current_grp_json) - updated_policy = (updated_grp.t['UpdatePolicy'] - if 'UpdatePolicy' in updated_grp.t else None) self.assertTrue(tmpl_diff.update_policy_changed()) # test application of the new update policy in handle_update - update_snippet = rsrc_defn.ResourceDefinition( - current_grp.name, - current_grp.type(), - properties=updated_grp.t['Properties'], - update_policy=updated_policy) current_grp._try_rolling_update = mock.MagicMock() current_grp.resize = mock.MagicMock() - current_grp.handle_update(update_snippet, tmpl_diff, None) - if updated_policy is None: - self.assertEqual({}, current_grp.update_policy.data) - else: - self.assertEqual(updated_policy, current_grp.update_policy.data) + current_grp.handle_update(updated_grp_json, tmpl_diff, None) + self.assertEqual(updated_grp_json._update_policy or {}, + current_grp.update_policy.data) def test_update_policy_added(self): self.validate_update_policy_diff(ig_tmpl_without_updt_policy, diff --git a/heat/tests/openstack/heat/test_resource_group.py b/heat/tests/openstack/heat/test_resource_group.py index f9e294ee4f..24a1ebc1fa 100644 --- a/heat/tests/openstack/heat/test_resource_group.py +++ b/heat/tests/openstack/heat/test_resource_group.py @@ -407,11 +407,15 @@ class ResourceGroupTest(common.HeatTestCase): res_prop['listprop'] = list(res_prop['listprop']) self.assertEqual(expect, nested) - res_def = snip['Properties']['resource_def'] + props = copy.deepcopy(templ['resources']['group1']['properties']) + res_def = props['resource_def'] res_def['properties']['Foo'] = "Bar___foo__" - res_def['properties']['listprop'] = ["__foo___0", "__foo___1", + res_def['properties']['listprop'] = ["__foo___0", + "__foo___1", "__foo___2"] res_def['type'] = "ResourceWithListProp__foo__" + snip = snip.freeze(properties=props) + resg = resource_group.ResourceGroup('test', snip, stack) expect = { "heat_template_version": "2015-04-30", @@ -517,9 +521,11 @@ class ResourceGroupTest(common.HeatTestCase): def test_handle_create_with_batching(self): stack = utils.parse_stack(tmpl_with_default_updt_policy()) - snip = stack.t.resource_definitions(stack)['group1'] - snip['UpdatePolicy']['batch_create'] = {'max_batch_size': 3} - snip['Properties']['count'] = 10 + defn = stack.t.resource_definitions(stack)['group1'] + props = stack.t.t['resources']['group1']['properties'].copy() + props['count'] = 10 + update_policy = {'batch_create': {'max_batch_size': 3}} + snip = defn.freeze(properties=props, update_policy=update_policy) resgrp = resource_group.ResourceGroup('test', snip, stack) self.patchobject(scheduler.TaskRunner, 'start') checkers = resgrp.handle_create() @@ -1019,25 +1025,15 @@ class RollingUpdatePolicyDiffTest(common.HeatTestCase): # identify the template difference tmpl_diff = updated_grp.update_template_diff( updated_grp_json, current_grp_json) - updated_policy = (updated_grp_json['UpdatePolicy'] - if 'UpdatePolicy' in updated_grp_json else None) self.assertTrue(tmpl_diff.update_policy_changed()) # test application of the new update policy in handle_update - update_snippet = rsrc_defn.ResourceDefinition( - current_grp.name, - current_grp.type(), - properties=updated_grp_json['Properties'], - update_policy=updated_policy) - current_grp._try_rolling_update = mock.Mock() current_grp._assemble_nested_for_size = mock.Mock() self.patchobject(scheduler.TaskRunner, 'start') - current_grp.handle_update(update_snippet, tmpl_diff, None) - if updated_policy is None: - self.assertEqual({}, current_grp.update_policy.data) - else: - self.assertEqual(updated_policy, current_grp.update_policy.data) + current_grp.handle_update(updated_grp_json, tmpl_diff, None) + self.assertEqual(updated_grp_json._update_policy or {}, + current_grp.update_policy.data) def test_update_policy_added(self): self.validate_update_policy_diff(template, @@ -1084,17 +1080,10 @@ class RollingUpdateTest(common.HeatTestCase): tmpl_diff = updated_grp.update_template_diff( updated_grp_json, current_grp_json) - updated_policy = updated_grp_json[ - 'UpdatePolicy']if 'UpdatePolicy' in updated_grp_json else None - update_snippet = rsrc_defn.ResourceDefinition( - self.current_grp.name, - self.current_grp.type(), - properties=updated_grp_json['Properties'], - update_policy=updated_policy) self.current_grp._replace = mock.Mock(return_value=[]) self.current_grp._assemble_nested = mock.Mock() self.patchobject(scheduler.TaskRunner, 'start') - self.current_grp.handle_update(update_snippet, tmpl_diff, prop_diff) + self.current_grp.handle_update(updated_grp_json, tmpl_diff, prop_diff) def test_update_without_policy_prop_diff(self): self.check_with_update(with_diff=True) diff --git a/heat/tests/openstack/keystone/test_endpoint.py b/heat/tests/openstack/keystone/test_endpoint.py index f25ff2d31c..1f928b917f 100644 --- a/heat/tests/openstack/keystone/test_endpoint.py +++ b/heat/tests/openstack/keystone/test_endpoint.py @@ -11,6 +11,8 @@ # License for the specific language governing permissions and limitations # under the License. +import copy + import mock from heat.engine import constraints @@ -61,9 +63,15 @@ class KeystoneEndpointTest(common.HeatTestCase): return value def _setup_endpoint_resource(self, stack_name, use_default=False): + tmpl_data = copy.deepcopy(keystone_endpoint_template) + if use_default: + props = tmpl_data['resources']['test_endpoint']['properties'] + del props['name'] + del props['enabled'] + test_stack = stack.Stack( self.ctx, stack_name, - template.Template(keystone_endpoint_template) + template.Template(tmpl_data) ) r_endpoint = test_stack['test_endpoint'] @@ -72,10 +80,6 @@ class KeystoneEndpointTest(common.HeatTestCase): r_endpoint.client_plugin = mock.MagicMock() r_endpoint.client_plugin.return_value = self.keystone_client_plugin - if use_default: - del r_endpoint.t['Properties']['name'] - del r_endpoint.t['Properties']['enabled'] - return r_endpoint def test_endpoint_handle_create(self): diff --git a/heat/tests/openstack/keystone/test_service.py b/heat/tests/openstack/keystone/test_service.py index 51cd8c5e17..0e35bed0bd 100644 --- a/heat/tests/openstack/keystone/test_service.py +++ b/heat/tests/openstack/keystone/test_service.py @@ -11,6 +11,8 @@ # License for the specific language governing permissions and limitations # under the License. +import copy + import mock from heat.engine import properties @@ -52,9 +54,16 @@ class KeystoneServiceTest(common.HeatTestCase): self.keystone_client_plugin = mock.MagicMock() def _setup_service_resource(self, stack_name, use_default=False): + tmpl_data = copy.deepcopy(keystone_service_template) + if use_default: + props = tmpl_data['resources']['test_service']['properties'] + del props['name'] + del props['enabled'] + del props['description'] + test_stack = stack.Stack( self.ctx, stack_name, - template.Template(keystone_service_template) + template.Template(tmpl_data) ) r_service = test_stack['test_service'] r_service.client = mock.MagicMock() @@ -62,11 +71,6 @@ class KeystoneServiceTest(common.HeatTestCase): r_service.client_plugin = mock.MagicMock() r_service.client_plugin.return_value = self.keystone_client_plugin - if use_default: - del r_service.t['Properties']['name'] - del r_service.t['Properties']['enabled'] - del r_service.t['Properties']['description'] - return r_service def _get_mock_service(self): diff --git a/heat/tests/openstack/manila/test_security_service.py b/heat/tests/openstack/manila/test_security_service.py index dd01b22b8e..dc5c02085d 100644 --- a/heat/tests/openstack/manila/test_security_service.py +++ b/heat/tests/openstack/manila/test_security_service.py @@ -94,7 +94,7 @@ class ManilaSecurityServiceTest(common.HeatTestCase): self.client.security_services.get.return_value = value scheduler.TaskRunner(ss.create)() args = self.client.security_services.create.call_args[1] - self.assertEqual(self.rsrc_defn['Properties'], args) + self.assertEqual(self.rsrc_defn._properties, args) self.assertEqual('12345', ss.resource_id) return ss diff --git a/heat/tests/openstack/manila/test_share_network.py b/heat/tests/openstack/manila/test_share_network.py index bb0d4cb0e5..50a53d3203 100644 --- a/heat/tests/openstack/manila/test_share_network.py +++ b/heat/tests/openstack/manila/test_share_network.py @@ -11,8 +11,6 @@ # License for the specific language governing permissions and limitations # under the License. -import copy - import mock from heat.common import exception @@ -59,8 +57,8 @@ class ManilaShareNetworkTest(common.HeatTestCase): utils.setup_dummy_db() self.ctx = utils.dummy_context() - t = template_format.parse(stack_template) - self.stack = utils.parse_stack(t) + self.tmpl = template_format.parse(stack_template) + self.stack = utils.parse_stack(self.tmpl) resource_defns = self.stack.t.resource_definitions(self.stack) self.rsrc_defn = resource_defns['share_network'] @@ -150,12 +148,13 @@ class ManilaShareNetworkTest(common.HeatTestCase): def test_update(self): net = self._create_network('share_network', self.rsrc_defn, self.stack) - update_template = copy.deepcopy(net.t) - update_template['Properties']['name'] = 'a' - update_template['Properties']['description'] = 'b' - update_template['Properties']['neutron_network'] = 'c' - update_template['Properties']['neutron_subnet'] = 'd' - update_template['Properties']['security_services'] = ['7', '8'] + props = self.tmpl['resources']['share_network']['properties'].copy() + props['name'] = 'a' + props['description'] = 'b' + props['neutron_network'] = 'c' + props['neutron_subnet'] = 'd' + props['security_services'] = ['7', '8'] + update_template = net.t.freeze(properties=props) scheduler.TaskRunner(net.update, update_template)() self.assertEqual((net.UPDATE, net.COMPLETE), net.state) @@ -174,8 +173,9 @@ class ManilaShareNetworkTest(common.HeatTestCase): def test_update_security_services(self): net = self._create_network('share_network', self.rsrc_defn, self.stack) - update_template = copy.deepcopy(net.t) - update_template['Properties']['security_services'] = ['7', '8'] + props = self.tmpl['resources']['share_network']['properties'].copy() + props['security_services'] = ['7', '8'] + update_template = net.t.freeze(properties=props) scheduler.TaskRunner(net.update, update_template)() self.assertEqual((net.UPDATE, net.COMPLETE), net.state) called = net.client().share_networks.update.called @@ -189,8 +189,9 @@ class ManilaShareNetworkTest(common.HeatTestCase): net = self._create_network('share_network', self.rsrc_defn, self.stack) self.client.share_networks.remove_security_service.side_effect = ( Exception()) - update_template = copy.deepcopy(net.t) - update_template['Properties']['security_services'] = [] + props = self.tmpl['resources']['share_network']['properties'].copy() + props['security_services'] = [] + update_template = net.t.freeze(properties=props) run = scheduler.TaskRunner(net.update, update_template) self.assertRaises(exception.ResourceFailure, run) diff --git a/heat/tests/openstack/neutron/test_neutron_firewall.py b/heat/tests/openstack/neutron/test_neutron_firewall.py index bd1e78c504..53abea2430 100644 --- a/heat/tests/openstack/neutron/test_neutron_firewall.py +++ b/heat/tests/openstack/neutron/test_neutron_firewall.py @@ -11,8 +11,6 @@ # License for the specific language governing permissions and limitations # under the License. -import copy - from neutronclient.common import exceptions from neutronclient.v2_0 import client as neutronclient import six @@ -105,6 +103,7 @@ class FirewallTest(common.HeatTestCase): self.stack = utils.parse_stack(snippet) resource_defns = self.stack.t.resource_definitions(self.stack) + self.fw_props = snippet['resources']['firewall']['properties'] return firewall.Firewall( 'firewall', resource_defns['firewall'], self.stack) @@ -211,8 +210,9 @@ class FirewallTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['admin_state_up'] = False + props = self.fw_props.copy() + props['admin_state_up'] = False + update_template = rsrc.t.freeze(properties=props) scheduler.TaskRunner(rsrc.update, update_template)() self.m.VerifyAll() @@ -256,6 +256,7 @@ class FirewallPolicyTest(common.HeatTestCase): snippet = template_format.parse(firewall_policy_template) self.stack = utils.parse_stack(snippet) + self.tmpl = snippet resource_defns = self.stack.t.resource_definitions(self.stack) return firewall.FirewallPolicy( 'firewall_policy', resource_defns['firewall_policy'], self.stack) @@ -358,8 +359,9 @@ class FirewallPolicyTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['firewall_rules'] = ['3', '4'] + props = self.tmpl['resources']['firewall_policy']['properties'].copy() + props['firewall_rules'] = ['3', '4'] + update_template = rsrc.t.freeze(properties=props) scheduler.TaskRunner(rsrc.update, update_template)() self.m.VerifyAll() @@ -386,6 +388,7 @@ class FirewallRuleTest(common.HeatTestCase): snippet = template_format.parse(firewall_rule_template) self.stack = utils.parse_stack(snippet) + self.tmpl = snippet resource_defns = self.stack.t.resource_definitions(self.stack) return firewall.FirewallRule( 'firewall_rule', resource_defns['firewall_rule'], self.stack) @@ -401,7 +404,10 @@ class FirewallRuleTest(common.HeatTestCase): snippet = template_format.parse(firewall_rule_template) stack = utils.parse_stack(snippet) rsrc = stack['firewall_rule'] - rsrc.t['Properties']['protocol'] = 'None' + props = dict(rsrc.properties) + props['protocol'] = 'None' + rsrc.t = rsrc.t.freeze(properties=props) + rsrc.reparse() self.assertRaises(exception.StackValidationFailed, rsrc.validate) def test_create_with_protocol_any(self): @@ -414,9 +420,9 @@ class FirewallRuleTest(common.HeatTestCase): self.m.ReplayAll() snippet = template_format.parse(firewall_rule_template) + snippet['resources']['firewall_rule']['properties']['protocol'] = 'any' stack = utils.parse_stack(snippet) rsrc = stack['firewall_rule'] - rsrc.t['Properties']['protocol'] = 'any' scheduler.TaskRunner(rsrc.create)() self.assertEqual((rsrc.CREATE, rsrc.COMPLETE), rsrc.state) @@ -514,8 +520,9 @@ class FirewallRuleTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['protocol'] = 'icmp' + props = self.tmpl['resources']['firewall_rule']['properties'].copy() + props['protocol'] = 'icmp' + update_template = rsrc.t.freeze(properties=props) scheduler.TaskRunner(rsrc.update, update_template)() self.m.VerifyAll() @@ -527,7 +534,8 @@ class FirewallRuleTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() # update to 'any' protocol - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['protocol'] = 'any' + props = self.tmpl['resources']['firewall_rule']['properties'].copy() + props['protocol'] = 'any' + update_template = rsrc.t.freeze(properties=props) scheduler.TaskRunner(rsrc.update, update_template)() self.m.VerifyAll() diff --git a/heat/tests/openstack/neutron/test_neutron_loadbalancer.py b/heat/tests/openstack/neutron/test_neutron_loadbalancer.py index f4daf5283b..1d94f4605a 100644 --- a/heat/tests/openstack/neutron/test_neutron_loadbalancer.py +++ b/heat/tests/openstack/neutron/test_neutron_loadbalancer.py @@ -190,6 +190,7 @@ class HealthMonitorTest(common.HeatTestCase): snippet = template_format.parse(health_monitor_template) self.stack = utils.parse_stack(snippet) + self.tmpl = snippet resource_defns = self.stack.t.resource_definitions(self.stack) return loadbalancer.HealthMonitor( 'monitor', resource_defns['monitor'], self.stack) @@ -291,8 +292,9 @@ class HealthMonitorTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['delay'] = 10 + props = self.tmpl['resources']['monitor']['properties'].copy() + props['delay'] = 10 + update_template = rsrc.t.freeze(properties=props) scheduler.TaskRunner(rsrc.update, update_template)() self.m.VerifyAll() @@ -326,6 +328,7 @@ class PoolTest(common.HeatTestCase): else: snippet = template_format.parse(pool_template_deprecated) self.stack = utils.parse_stack(snippet) + self.tmpl = snippet neutronclient.Client.create_pool({ 'pool': { 'subnet_id': 'sub123', 'protocol': u'HTTP', @@ -799,8 +802,9 @@ class PoolTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['admin_state_up'] = False + props = self.tmpl['resources']['pool']['properties'].copy() + props['admin_state_up'] = False + update_template = rsrc.t.freeze(properties=props) scheduler.TaskRunner(rsrc.update, update_template)() self.m.VerifyAll() @@ -847,8 +851,9 @@ class PoolTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['monitors'] = ['mon123', 'mon789'] + props = snippet['resources']['pool']['properties'].copy() + props['monitors'] = ['mon123', 'mon789'] + update_template = rsrc.t.freeze(properties=props) scheduler.TaskRunner(rsrc.update, update_template)() self.m.VerifyAll() @@ -874,6 +879,7 @@ class PoolMemberTest(common.HeatTestCase): ).AndReturn({'member': {'id': 'member5678'}}) snippet = template_format.parse(member_template) self.stack = utils.parse_stack(snippet) + self.tmpl = snippet resource_defns = self.stack.t.resource_definitions(self.stack) return loadbalancer.PoolMember( 'member', resource_defns['member'], self.stack) @@ -927,8 +933,9 @@ class PoolMemberTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['pool_id'] = 'pool456' + props = self.tmpl['resources']['member']['properties'].copy() + props['pool_id'] = 'pool456' + update_template = rsrc.t.freeze(properties=props) scheduler.TaskRunner(rsrc.update, update_template)() self.m.VerifyAll() @@ -1001,8 +1008,9 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['members'] = ['5678'] + props = dict(rsrc.properties) + props['members'] = ['5678'] + update_template = rsrc.t.freeze(properties=props) scheduler.TaskRunner(rsrc.update, update_template)() self.m.VerifyAll() @@ -1015,8 +1023,9 @@ class LoadBalancerTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['members'] = [] + props = dict(rsrc.properties) + props['members'] = [] + update_template = rsrc.t.freeze(properties=props) scheduler.TaskRunner(rsrc.update, update_template)() self.assertEqual((rsrc.UPDATE, rsrc.COMPLETE), rsrc.state) diff --git a/heat/tests/openstack/neutron/test_neutron_router.py b/heat/tests/openstack/neutron/test_neutron_router.py index 1638e7b616..d976102ec5 100644 --- a/heat/tests/openstack/neutron/test_neutron_router.py +++ b/heat/tests/openstack/neutron/test_neutron_router.py @@ -224,7 +224,10 @@ class NeutronRouterTest(common.HeatTestCase): props['distributed'] = True stack = utils.parse_stack(t) rsrc = stack['router'] - rsrc.t['Properties'].pop('l3_agent_ids') + update_props = props.copy() + del update_props['l3_agent_ids'] + rsrc.t = rsrc.t.freeze(properties=update_props) + rsrc.reparse() exc = self.assertRaises(exception.ResourcePropertyConflict, rsrc.validate) self.assertIn('distributed, ha', six.text_type(exc)) @@ -942,11 +945,12 @@ class NeutronRouterTest(common.HeatTestCase): stack = utils.parse_stack(t) rsrc = self.create_router(t, stack, 'router') - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['external_gateway_info'] = { + props = t['resources']['router']['properties'].copy() + props['external_gateway_info'] = { "network": "other_public", "enable_snat": False } + update_template = rsrc.t.freeze(properties=props) scheduler.TaskRunner(rsrc.update, update_template)() self.assertEqual((rsrc.UPDATE, rsrc.COMPLETE), rsrc.state) diff --git a/heat/tests/openstack/neutron/test_neutron_subnetpool.py b/heat/tests/openstack/neutron/test_neutron_subnetpool.py index 460b376350..1398c9096a 100644 --- a/heat/tests/openstack/neutron/test_neutron_subnetpool.py +++ b/heat/tests/openstack/neutron/test_neutron_subnetpool.py @@ -185,7 +185,7 @@ class NeutronSubnetPoolTest(common.HeatTestCase): ref_id = rsrc.FnGetRefId() self.assertEqual('fc68ea2c-b60b-4b4f-bd82-94ec81110766', ref_id) update_snippet = rsrc_defn.ResourceDefinition(rsrc.name, rsrc.type(), - rsrc.t) + rsrc.t._properties) self.assertIsNone(rsrc.handle_update(update_snippet, {}, {})) update_subnetpool.assert_not_called() diff --git a/heat/tests/openstack/neutron/test_neutron_vpnservice.py b/heat/tests/openstack/neutron/test_neutron_vpnservice.py index 2159d61338..3b66f866f2 100644 --- a/heat/tests/openstack/neutron/test_neutron_vpnservice.py +++ b/heat/tests/openstack/neutron/test_neutron_vpnservice.py @@ -454,8 +454,9 @@ class IPsecSiteConnectionTest(common.HeatTestCase): 'con123', {'ipsec_site_connection': {'admin_state_up': False}}) self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['admin_state_up'] = False + props = dict(rsrc.properties) + props['admin_state_up'] = False + update_template = rsrc.t.freeze(properties=props) scheduler.TaskRunner(rsrc.update, update_template)() self.m.VerifyAll() @@ -598,8 +599,9 @@ class IKEPolicyTest(common.HeatTestCase): 'name': 'New IKEPolicy'}}) self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() - update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['name'] = 'New IKEPolicy' + props = dict(rsrc.properties) + props['name'] = 'New IKEPolicy' + update_template = rsrc.t.freeze(properties=props) scheduler.TaskRunner(rsrc.update, update_template)() self.m.VerifyAll() @@ -743,6 +745,8 @@ class IPsecPolicyTest(common.HeatTestCase): self.m.ReplayAll() scheduler.TaskRunner(rsrc.create)() update_template = copy.deepcopy(rsrc.t) - update_template['Properties']['name'] = 'New IPsecPolicy' + props = dict(rsrc.properties) + props['name'] = 'New IPsecPolicy' + update_template = rsrc.t.freeze(properties=props) scheduler.TaskRunner(rsrc.update, update_template)() self.m.VerifyAll() diff --git a/heat/tests/openstack/nova/test_server.py b/heat/tests/openstack/nova/test_server.py index 79cdcf113c..df9d63302f 100644 --- a/heat/tests/openstack/nova/test_server.py +++ b/heat/tests/openstack/nova/test_server.py @@ -252,6 +252,7 @@ class ServersTest(common.HeatTestCase): server_name = str(name) if override_name else None tmpl, self.stack = self._get_test_template(stack_name, server_name, image_id) + self.server_props = tmpl.t['Resources']['WebServer']['Properties'] resource_defns = tmpl.resource_definitions(self.stack) server = servers.Server(str(name), resource_defns['WebServer'], self.stack) @@ -563,8 +564,8 @@ class ServersTest(common.HeatTestCase): return_server = self.fc.servers.list()[1] (tmpl, stack) = self._setup_test_stack(stack_name) self.stack = stack - tmpl['Resources']['WebServer']['Properties'][ - 'user_data_format'] = 'SOFTWARE_CONFIG' + self.server_props = tmpl['Resources']['WebServer']['Properties'] + self.server_props['user_data_format'] = 'SOFTWARE_CONFIG' if md is not None: tmpl['Resources']['WebServer']['Metadata'] = md @@ -644,6 +645,7 @@ class ServersTest(common.HeatTestCase): props['software_config_transport'] = 'POLL_SERVER_HEAT' if md is not None: tmpl.t['Resources']['WebServer']['Metadata'] = md + self.server_props = props resource_defns = tmpl.resource_definitions(stack) server = servers.Server('WebServer', @@ -710,6 +712,7 @@ class ServersTest(common.HeatTestCase): props['software_config_transport'] = 'POLL_TEMP_URL' if md is not None: tmpl.t['Resources']['WebServer']['Metadata'] = md + self.server_props = props resource_defns = tmpl.resource_definitions(stack) server = servers.Server('WebServer', @@ -790,6 +793,7 @@ class ServersTest(common.HeatTestCase): props['software_config_transport'] = 'ZAQAR_MESSAGE' if md is not None: tmpl.t['Resources']['WebServer']['Metadata'] = md + self.server_props = props resource_defns = tmpl.resource_definitions(stack) server = servers.Server('WebServer', @@ -1448,9 +1452,9 @@ class ServersTest(common.HeatTestCase): sc.url = 'http://192.0.2.2' self.patchobject(swift.SwiftClientPlugin, '_create', return_value=sc) - update_template = copy.deepcopy(server.t) - update_template['Properties'][ - 'software_config_transport'] = 'POLL_TEMP_URL' + update_props = self.server_props.copy() + update_props['software_config_transport'] = 'POLL_TEMP_URL' + update_template = server.t.freeze(properties=update_props) self.rpc_client = mock.MagicMock() server._rpc_client = self.rpc_client @@ -1491,8 +1495,9 @@ class ServersTest(common.HeatTestCase): self.patchobject(self.fc.servers, 'get', return_value=return_server) set_meta_mock = self.patchobject(self.fc.servers, 'set_meta') - update_template = copy.deepcopy(server.t) - update_template['Properties']['metadata'] = new_meta + update_props = self.server_props.copy() + update_props['metadata'] = new_meta + update_template = server.t.freeze(properties=update_props) scheduler.TaskRunner(server.update, update_template)() self.assertEqual((server.UPDATE, server.COMPLETE), server.state) set_meta_mock.assert_called_with( @@ -1514,8 +1519,9 @@ class ServersTest(common.HeatTestCase): # If we're going to call set_meta() directly we # need to handle the serialization ourselves. - update_template = copy.deepcopy(server.t) - update_template['Properties']['metadata'] = new_meta + update_props = self.server_props.copy() + update_props['metadata'] = new_meta + update_template = server.t.freeze(properties=update_props) scheduler.TaskRunner(server.update, update_template)() self.assertEqual((server.UPDATE, server.COMPLETE), server.state) set_meta_mock.assert_called_with( @@ -1531,8 +1537,9 @@ class ServersTest(common.HeatTestCase): self.patchobject(self.fc.servers, 'get', return_value=return_server) set_meta_mock = self.patchobject(self.fc.servers, 'set_meta') - update_template = copy.deepcopy(server.t) - update_template['Properties']['metadata'] = new_meta + update_props = self.server_props.copy() + update_props['metadata'] = new_meta + update_template = server.t.freeze(properties=update_props) scheduler.TaskRunner(server.update, update_template)() self.assertEqual((server.UPDATE, server.COMPLETE), server.state) set_meta_mock.assert_called_with( @@ -1547,8 +1554,9 @@ class ServersTest(common.HeatTestCase): self.patchobject(self.fc.servers, 'get', return_value=new_return_server) del_meta_mock = self.patchobject(self.fc.servers, 'delete_meta') - update_template = copy.deepcopy(server.t) - update_template['Properties']['metadata'] = new_meta + update_props = self.server_props.copy() + update_props['metadata'] = new_meta + update_template = server.t.freeze(properties=update_props) scheduler.TaskRunner(server.update, update_template)() self.assertEqual((server.UPDATE, server.COMPLETE), server.state) @@ -1564,8 +1572,9 @@ class ServersTest(common.HeatTestCase): server = self._create_test_server(return_server, 'srv_update') new_name = 'new_name' - update_template = copy.deepcopy(server.t) - update_template['Properties']['name'] = new_name + update_props = self.server_props.copy() + update_props['name'] = new_name + update_template = server.t.freeze(properties=update_props) self.patchobject(self.fc.servers, 'get', return_value=return_server) @@ -1581,8 +1590,9 @@ class ServersTest(common.HeatTestCase): server = self._create_test_server(return_server, 'change_password') new_password = 'new_password' - update_template = copy.deepcopy(server.t) - update_template['Properties']['admin_pass'] = new_password + update_props = self.server_props.copy() + update_props['admin_pass'] = new_password + update_template = server.t.freeze(properties=update_props) self.patchobject(self.fc.servers, 'get', return_value=return_server) self.patchobject(return_server, 'change_password') @@ -1602,8 +1612,9 @@ class ServersTest(common.HeatTestCase): return_server.id = '1234' server = self._create_test_server(return_server, 'srv_update') - update_template = copy.deepcopy(server.t) - update_template['Properties']['flavor'] = 'm1.small' + update_props = self.server_props.copy() + update_props['flavor'] = 'm1.small' + update_template = server.t.freeze(properties=update_props) def set_status(status): return_server.status = status @@ -1633,8 +1644,9 @@ class ServersTest(common.HeatTestCase): return_server.id = '1234' server = self._create_test_server(return_server, 'srv_update2') - update_template = copy.deepcopy(server.t) - update_template['Properties']['flavor'] = 'm1.small' + update_props = self.server_props.copy() + update_props['flavor'] = 'm1.small' + update_template = server.t.freeze(properties=update_props) def set_status(status): return_server.status = status @@ -1668,8 +1680,9 @@ class ServersTest(common.HeatTestCase): server_resource = self._create_test_server(server, 'resize_server') # prepare template with resized server - update_template = copy.deepcopy(server_resource.t) - update_template['Properties']['flavor'] = 'm1.small' + update_props = self.server_props.copy() + update_props['flavor'] = 'm1.small' + update_template = server_resource.t.freeze(properties=update_props) # define status transition when server resize # ACTIVE(initial) -> ACTIVE -> RESIZE -> VERIFY_RESIZE @@ -1700,13 +1713,14 @@ class ServersTest(common.HeatTestCase): def test_server_update_server_flavor_replace(self, mock_replace): stack_name = 'update_flvrep' (tmpl, stack) = self._setup_test_stack(stack_name) - tmpl['Resources']['WebServer']['Properties'][ - 'flavor_update_policy'] = 'REPLACE' + server_props = tmpl['Resources']['WebServer']['Properties'] + server_props['flavor_update_policy'] = 'REPLACE' resource_defns = tmpl.resource_definitions(stack) server = servers.Server('server_server_update_flavor_replace', resource_defns['WebServer'], stack) - update_template = copy.deepcopy(server.t) - update_template['Properties']['flavor'] = 'm1.small' + update_props = server_props.copy() + update_props['flavor'] = 'm1.small' + update_template = server.t.freeze(properties=update_props) updater = scheduler.TaskRunner(server.update, update_template) self.assertRaises(exception.UpdateReplace, updater) @@ -1718,12 +1732,13 @@ class ServersTest(common.HeatTestCase): server = servers.Server('server_server_update_flavor_replace', resource_defns['WebServer'], stack) - update_template = copy.deepcopy(server.t) + update_props = tmpl.t['Resources']['WebServer']['Properties'].copy() # confirm that when flavor_update_policy is changed during # the update then the updated policy is followed for a flavor # update - update_template['Properties']['flavor_update_policy'] = 'REPLACE' - update_template['Properties']['flavor'] = 'm1.small' + update_props['flavor_update_policy'] = 'REPLACE' + update_props['flavor'] = 'm1.small' + update_template = server.t.freeze(properties=update_props) updater = scheduler.TaskRunner(server.update, update_template) self.assertRaises(exception.UpdateReplace, updater) @@ -1737,8 +1752,9 @@ class ServersTest(common.HeatTestCase): server = servers.Server('server_update_userdata_replace', resource_defns['WebServer'], stack) - update_template = copy.deepcopy(server.t) - update_template['Properties']['user_data'] = 'changed' + update_props = tmpl.t['Resources']['WebServer']['Properties'].copy() + update_props['user_data'] = 'changed' + update_template = server.t.freeze(properties=update_props) server.action = server.CREATE updater = scheduler.TaskRunner(server.update, update_template) self.assertRaises(exception.UpdateReplace, updater) @@ -1756,9 +1772,10 @@ class ServersTest(common.HeatTestCase): server = servers.Server('server_update_userdata_ignore', resource_defns['WebServer'], stack) - update_template = copy.deepcopy(server.t) - update_template['Properties']['user_data'] = 'changed' - update_template['Properties']['user_data_update_policy'] = 'IGNORE' + update_props = tmpl.t['Resources']['WebServer']['Properties'].copy() + update_props['user_data'] = 'changed' + update_props['user_data_update_policy'] = 'IGNORE' + update_template = server.t.freeze(properties=update_props) server.action = server.CREATE scheduler.TaskRunner(server.update, update_template)() self.assertEqual((server.UPDATE, server.COMPLETE), server.state) @@ -1774,8 +1791,9 @@ class ServersTest(common.HeatTestCase): server = servers.Server('server_update_image_replace', resource_defns['WebServer'], stack) image_id = self.getUniqueString() - update_template = copy.deepcopy(server.t) - update_template['Properties']['image'] = image_id + update_props = tmpl.t['Resources']['WebServer']['Properties'].copy() + update_props['image'] = image_id + update_template = server.t.freeze(properties=update_props) updater = scheduler.TaskRunner(server.update, update_template) self.assertRaises(exception.UpdateReplace, updater) @@ -1791,12 +1809,16 @@ class ServersTest(common.HeatTestCase): new_image = 'F17-x86_64-gold' # current test demonstrate updating when image_update_policy was not # changed, so image_update_policy will be used from self.properties - server.t['Properties']['image_update_policy'] = policy + before_props = self.server_props.copy() + before_props['image_update_policy'] = policy + server.t = server.t.freeze(properties=before_props) + server.reparse() - update_template = copy.deepcopy(server.t) - update_template['Properties']['image'] = new_image + update_props = before_props.copy() + update_props['image'] = new_image if password: - update_template['Properties']['admin_pass'] = password + update_props['admin_pass'] = password + update_template = server.t.freeze(properties=update_props) mock_rebuild = self.patchobject(self.fc.servers, 'rebuild') @@ -1857,9 +1879,13 @@ class ServersTest(common.HeatTestCase): new_image = 'F17-x86_64-gold' # current test demonstrate updating when image_update_policy was not # changed, so image_update_policy will be used from self.properties - server.t['Properties']['image_update_policy'] = 'REBUILD' - update_template = copy.deepcopy(server.t) - update_template['Properties']['image'] = new_image + before_props = self.server_props.copy() + before_props['image_update_policy'] = 'REBUILD' + update_props = before_props.copy() + update_props['image'] = new_image + update_template = server.t.freeze(properties=update_props) + server.t = server.t.freeze(properties=before_props) + server.reparse() mock_rebuild = self.patchobject(self.fc.servers, 'rebuild') def set_status(status): @@ -1883,9 +1909,10 @@ class ServersTest(common.HeatTestCase): return_server = self.fc.servers.list()[1] server = self._create_test_server(return_server, 'update_prop') - update_template = copy.deepcopy(server.t) - update_template['Properties']['image'] = 'F17-x86_64-gold' - update_template['Properties']['image_update_policy'] = 'REPLACE' + update_props = self.server_props.copy() + update_props['image'] = 'F17-x86_64-gold' + update_props['image_update_policy'] = 'REPLACE' + update_template = server.t.freeze(properties=update_props) updater = scheduler.TaskRunner(server.update, update_template) self.assertRaises(exception.UpdateReplace, updater) @@ -2964,12 +2991,11 @@ class ServersTest(common.HeatTestCase): server = self._create_test_server(return_server, 'networks_update') new_networks = [{'port': '2a60cbaa-3d33-4af6-a9ce-83594ac546fc'}] - update_template = copy.deepcopy(server.t) - update_template['Properties']['networks'] = new_networks + update_props = self.server_props.copy() + update_props['networks'] = new_networks + update_template = server.t.freeze(properties=update_props) self.patchobject(self.fc.servers, 'get', return_value=return_server) - # to make sure, that old_networks will be None - self.assertFalse(hasattr(server.t['Properties'], 'networks')) iface = self.create_fake_iface('aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa', '450abbc9-9b6d-4d6f-8c3a-c47ac34100ef', @@ -2994,14 +3020,12 @@ class ServersTest(common.HeatTestCase): new_networks = [{'network': 'aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa', 'fixed_ip': '1.2.3.4'}] - update_template = copy.deepcopy(server.t) - update_template['Properties']['networks'] = new_networks + update_props = self.server_props.copy() + update_props['networks'] = new_networks + update_template = server.t.freeze(properties=update_props) self.patchobject(self.fc.servers, 'get', return_value=return_server) - # to make sure, that old_networks will be None - self.assertFalse(hasattr(server.t['Properties'], 'networks')) - iface = self.create_fake_iface('aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa', '450abbc9-9b6d-4d6f-8c3a-c47ac34100ef', '1.2.3.4') @@ -3022,14 +3046,12 @@ class ServersTest(common.HeatTestCase): new_networks = [{'network': 'aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa', 'fixed_ip': '1.2.3.4', 'port': '2a60cbaa-3d33-4af6-a9ce-83594ac546fc'}] - update_template = copy.deepcopy(server.t) - update_template['Properties']['networks'] = new_networks + update_props = self.server_props.copy() + update_props['networks'] = new_networks + update_template = server.t.freeze(properties=update_props) self.patchobject(self.fc.servers, 'get', return_value=return_server) - # to make sure, that old_networks will be None - self.assertFalse(hasattr(server.t['Properties'], 'networks')) - iface = self.create_fake_iface('aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa', '450abbc9-9b6d-4d6f-8c3a-c47ac34100ef', '1.2.3.4') @@ -3059,9 +3081,13 @@ class ServersTest(common.HeatTestCase): 'fixed_ip': '1.2.3.4'}, {'port': '2a60cbaa-3d33-4af6-a9ce-83594ac546fc'}] - server.t['Properties']['networks'] = old_networks - update_template = copy.deepcopy(server.t) - update_template['Properties']['networks'] = new_networks + before_props = self.server_props.copy() + before_props['networks'] = old_networks + update_props = self.server_props.copy() + update_props['networks'] = new_networks + update_template = server.t.freeze(properties=update_props) + server.t = server.t.freeze(properties=before_props) + # server.reparse() self.patchobject(self.fc.servers, 'get', return_value=return_server) @@ -3100,9 +3126,13 @@ class ServersTest(common.HeatTestCase): {'network': 'aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa', 'fixed_ip': '31.32.33.34'}] - server.t['Properties']['networks'] = old_networks - update_template = copy.deepcopy(server.t) - update_template['Properties']['networks'] = None + before_props = self.server_props.copy() + before_props['networks'] = old_networks + update_props = self.server_props.copy() + update_props['networks'] = None + update_template = server.t.freeze(properties=update_props) + server.t = server.t.freeze(properties=before_props) + # server.reparse() self.patchobject(self.fc.servers, 'get', return_value=return_server) poor_interfaces = [ @@ -3137,9 +3167,13 @@ class ServersTest(common.HeatTestCase): {'network': 'aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa', 'fixed_ip': '31.32.33.34'}] - server.t['Properties']['networks'] = old_networks - update_template = copy.deepcopy(server.t) - update_template['Properties']['networks'] = [] + before_props = self.server_props.copy() + before_props['networks'] = old_networks + update_props = self.server_props.copy() + update_props['networks'] = [] + update_template = server.t.freeze(properties=update_props) + server.t = server.t.freeze(properties=before_props) + # server.reparse() self.patchobject(self.fc.servers, 'get', return_value=return_server) poor_interfaces = [ @@ -3172,9 +3206,10 @@ class ServersTest(common.HeatTestCase): server = self._create_test_server(return_server, 'my_server') - update_template = copy.deepcopy(server.t) - update_template['Properties']['image'] = 'F17-x86_64-gold' - update_template['Properties']['image_update_policy'] = 'REPLACE' + update_props = self.server_props.copy() + update_props['image'] = 'F17-x86_64-gold' + update_props['image_update_policy'] = 'REPLACE' + update_template = server.t.freeze(properties=update_props) updater = scheduler.TaskRunner(server.update, update_template) self.assertRaises(exception.UpdateReplace, updater) @@ -3190,8 +3225,9 @@ class ServersTest(common.HeatTestCase): self.patchobject(glance.GlanceClientPlugin, 'find_image_by_name_or_id', side_effect=[1, ex]) - update_template = copy.deepcopy(server.t) - update_template['Properties']['image'] = 'Update Image' + update_props = self.server_props.copy() + update_props['image'] = 'Update Image' + update_template = server.t.freeze(properties=update_props) # update updater = scheduler.TaskRunner(server.update, update_template) diff --git a/heat/tests/openstack/sahara/test_data_source.py b/heat/tests/openstack/sahara/test_data_source.py index 7ef335ff08..4da071b421 100644 --- a/heat/tests/openstack/sahara/test_data_source.py +++ b/heat/tests/openstack/sahara/test_data_source.py @@ -75,8 +75,10 @@ class SaharaDataSourceTest(common.HeatTestCase): def test_update(self): ds = self._create_resource('data-source', self.rsrc_defn, self.stack) - self.rsrc_defn['Properties']['type'] = 'hdfs' - self.rsrc_defn['Properties']['url'] = 'my/path' + props = self.stack.t.t['resources']['data-source']['properties'].copy() + props['type'] = 'hdfs' + props['url'] = 'my/path' + self.rsrc_defn = self.rsrc_defn.freeze(properties=props) scheduler.TaskRunner(ds.update, self.rsrc_defn)() data = { 'name': 'my-ds', @@ -100,7 +102,9 @@ class SaharaDataSourceTest(common.HeatTestCase): self.assertEqual({'ds': 'info'}, ds.FnGetAtt('show')) def test_validate_password_without_user(self): - self.rsrc_defn['Properties']['credentials'].pop('user') + props = self.stack.t.t['resources']['data-source']['properties'].copy() + del props['credentials']['user'] + self.rsrc_defn = self.rsrc_defn.freeze(properties=props) ds = data_source.DataSource('data-source', self.rsrc_defn, self.stack) ex = self.assertRaises(exception.StackValidationFailed, ds.validate) error_msg = ('Property error: resources.data-source.properties.' diff --git a/heat/tests/openstack/sahara/test_image.py b/heat/tests/openstack/sahara/test_image.py index 367f15ab63..5da7a17ebc 100644 --- a/heat/tests/openstack/sahara/test_image.py +++ b/heat/tests/openstack/sahara/test_image.py @@ -40,8 +40,8 @@ resources: class SaharaImageTest(common.HeatTestCase): def setUp(self): super(SaharaImageTest, self).setUp() - t = template_format.parse(sahara_image_template) - self.stack = utils.parse_stack(t) + self.tmpl = template_format.parse(sahara_image_template) + self.stack = utils.parse_stack(self.tmpl) resource_defns = self.stack.t.resource_definitions(self.stack) self.rsrc_defn = resource_defns['sahara-image'] self.client = mock.Mock() @@ -68,8 +68,10 @@ class SaharaImageTest(common.HeatTestCase): def test_update(self): img = self._create_resource('sahara-image', self.rsrc_defn, self.stack) - self.rsrc_defn['Properties']['tags'] = [] - self.rsrc_defn['Properties']['description'] = 'test image' + props = self.tmpl['resources']['sahara-image']['properties'].copy() + props['tags'] = [] + props['description'] = 'test image' + self.rsrc_defn = self.rsrc_defn.freeze(properties=props) scheduler.TaskRunner(img.update, self.rsrc_defn)() tags_update_calls = [ mock.call('12345', ['vanilla', '1.2.1']), diff --git a/heat/tests/openstack/sahara/test_job_binary.py b/heat/tests/openstack/sahara/test_job_binary.py index 62a7ca542e..97fa903bd5 100644 --- a/heat/tests/openstack/sahara/test_job_binary.py +++ b/heat/tests/openstack/sahara/test_job_binary.py @@ -74,8 +74,9 @@ class SaharaJobBinaryTest(common.HeatTestCase): def test_update(self): jb = self._create_resource('job-binary', self.rsrc_defn, self.stack) - self.rsrc_defn['Properties']['url'] = ( - 'internal-db://94b8821d-1ce7-4131-8364-a6c6d85ad57b') + props = self.stack.t.t['resources']['job-binary']['properties'].copy() + props['url'] = 'internal-db://94b8821d-1ce7-4131-8364-a6c6d85ad57b' + self.rsrc_defn = self.rsrc_defn.freeze(properties=props) scheduler.TaskRunner(jb.update, self.rsrc_defn)() data = { 'name': 'my-jb', @@ -114,7 +115,9 @@ class SaharaJobBinaryTest(common.HeatTestCase): self.assertEqual({'jb': 'info'}, jb.FnGetAtt('show')) def test_validate_invalid_url(self): - self.rsrc_defn['Properties']['url'] = 'internal-db://38273f82' + props = self.stack.t.t['resources']['job-binary']['properties'].copy() + props['url'] = 'internal-db://38273f82' + self.rsrc_defn = self.rsrc_defn.freeze(properties=props) jb = job_binary.JobBinary('job-binary', self.rsrc_defn, self.stack) ex = self.assertRaises(exception.StackValidationFailed, jb.validate) error_msg = ('resources.job-binary.properties: internal-db://38273f82 ' @@ -122,7 +125,9 @@ class SaharaJobBinaryTest(common.HeatTestCase): self.assertEqual(error_msg, six.text_type(ex)) def test_validate_password_without_user(self): - self.rsrc_defn['Properties']['credentials'].pop('user') + props = self.stack.t.t['resources']['job-binary']['properties'].copy() + props['credentials'].pop('user') + self.rsrc_defn = self.rsrc_defn.freeze(properties=props) jb = job_binary.JobBinary('job-binary', self.rsrc_defn, self.stack) ex = self.assertRaises(exception.StackValidationFailed, jb.validate) error_msg = ('Property error: resources.job-binary.properties.' diff --git a/heat/tests/openstack/sahara/test_templates.py b/heat/tests/openstack/sahara/test_templates.py index feaf5fc935..dcab5e985d 100644 --- a/heat/tests/openstack/sahara/test_templates.py +++ b/heat/tests/openstack/sahara/test_templates.py @@ -127,6 +127,7 @@ class SaharaNodeGroupTemplateTest(common.HeatTestCase): self.fake_ngt = FakeNodeGroupTemplate() self.t = template_format.parse(node_group_template) + self.ngt_props = self.t['resources']['node-group']['properties'] def _init_ngt(self, template): self.stack = utils.parse_stack(template) @@ -249,10 +250,10 @@ class SaharaNodeGroupTemplateTest(common.HeatTestCase): def test_update(self): ngt = self._create_ngt(self.t) - rsrc_defn = self.stack.t.resource_definitions(self.stack)['node-group'] - rsrc_defn['Properties']['node_processes'] = [ - 'tasktracker', 'datanode'] - rsrc_defn['Properties']['name'] = 'new-ng-template' + props = self.ngt_props.copy() + props['node_processes'] = ['tasktracker', 'datanode'] + props['name'] = 'new-ng-template' + rsrc_defn = ngt.t.freeze(properties=props) scheduler.TaskRunner(ngt.update, rsrc_defn)() args = {'node_processes': ['tasktracker', 'datanode'], 'name': 'new-ng-template'} @@ -341,9 +342,11 @@ class SaharaClusterTemplateTest(common.HeatTestCase): ct = self._create_ct(self.t) rsrc_defn = self.stack.t.resource_definitions(self.stack)[ 'cluster-template'] - rsrc_defn['Properties']['plugin_name'] = 'hdp' - rsrc_defn['Properties']['hadoop_version'] = '1.3.2' - rsrc_defn['Properties']['name'] = 'new-cluster-template' + props = self.t['resources']['cluster-template']['properties'].copy() + props['plugin_name'] = 'hdp' + props['hadoop_version'] = '1.3.2' + props['name'] = 'new-cluster-template' + rsrc_defn = rsrc_defn.freeze(properties=props) scheduler.TaskRunner(ct.update, rsrc_defn)() args = { 'plugin_name': 'hdp', diff --git a/heat/tests/openstack/trove/test_cluster.py b/heat/tests/openstack/trove/test_cluster.py index 37a79c5593..7cb947d938 100644 --- a/heat/tests/openstack/trove/test_cluster.py +++ b/heat/tests/openstack/trove/test_cluster.py @@ -11,6 +11,7 @@ # License for the specific language governing permissions and limitations # under the License. +import copy import mock import six from troveclient.openstack.common.apiclient import exceptions as troveexc @@ -76,8 +77,8 @@ class TroveClusterTest(common.HeatTestCase): utils.setup_dummy_db() self.ctx = utils.dummy_context() - t = template_format.parse(stack_template) - self.stack = utils.parse_stack(t) + self.tmpl = template_format.parse(stack_template) + self.stack = utils.parse_stack(self.tmpl) resource_defns = self.stack.t.resource_definitions(self.stack) self.rsrc_defn = resource_defns['cluster'] @@ -144,7 +145,9 @@ class TroveClusterTest(common.HeatTestCase): self.assertIsNone(tc.validate()) def test_validate_invalid_dsversion(self): - self.rsrc_defn['Properties']['datastore_version'] = '2.6.2' + props = self.tmpl['resources']['cluster']['properties'].copy() + props['datastore_version'] = '2.6.2' + self.rsrc_defn = self.rsrc_defn.freeze(properties=props) tc = cluster.TroveCluster('cluster', self.rsrc_defn, self.stack) ex = self.assertRaises(exception.StackValidationFailed, tc.validate) error_msg = ('Datastore version 2.6.2 for datastore type mongodb is ' @@ -154,7 +157,9 @@ class TroveClusterTest(common.HeatTestCase): def test_validate_invalid_flavor(self): self.troveclient.flavors.get.side_effect = troveexc.NotFound() self.troveclient.flavors.find.side_effect = troveexc.NotFound() - self.rsrc_defn['Properties']['instances'][0]['flavor'] = 'm1.small' + props = copy.deepcopy(self.tmpl['resources']['cluster']['properties']) + props['instances'][0]['flavor'] = 'm1.small' + self.rsrc_defn = self.rsrc_defn.freeze(properties=props) tc = cluster.TroveCluster('cluster', self.rsrc_defn, self.stack) ex = self.assertRaises(exception.StackValidationFailed, tc.validate) error_msg = ("Property error: " diff --git a/heat/tests/test_hot.py b/heat/tests/test_hot.py index 06b3bc370e..c3ad073c97 100644 --- a/heat/tests/test_hot.py +++ b/heat/tests/test_hot.py @@ -1391,11 +1391,13 @@ class HotStackTest(common.HeatTestCase): self.assertEqual('abc', self.stack['AResource'].properties['Foo']) generic_rsrc.ResourceWithProps.update_template_diff( - {'Type': 'ResourceWithPropsType', - 'Properties': {'Foo': 'xyz'}}, - {'Type': 'ResourceWithPropsType', - 'Properties': {'Foo': 'abc'}} - ).WithSideEffects(check_props).AndRaise(exception.UpdateReplace) + rsrc_defn.ResourceDefinition('AResource', + 'ResourceWithPropsType', + properties={'Foo': 'xyz'}), + rsrc_defn.ResourceDefinition('AResource', + 'ResourceWithPropsType', + properties={'Foo': 'abc'}) + ).WithSideEffects(check_props).AndRaise(exception.UpdateReplace) self.m.ReplayAll() self.stack.update(updated_stack) @@ -1435,11 +1437,13 @@ class HotStackTest(common.HeatTestCase): self.assertEqual('abc', self.stack['AResource'].properties['Foo']) generic_rsrc.ResourceWithProps.update_template_diff( - {'Type': 'ResourceWithPropsType', - 'Properties': {'Foo': 'xyz'}}, - {'Type': 'ResourceWithPropsType', - 'Properties': {'Foo': 'abc'}} - ).WithSideEffects(check_props).AndRaise(exception.UpdateReplace) + rsrc_defn.ResourceDefinition('AResource', + 'ResourceWithPropsType', + properties={'Foo': 'xyz'}), + rsrc_defn.ResourceDefinition('AResource', + 'ResourceWithPropsType', + properties={'Foo': 'abc'}) + ).WithSideEffects(check_props).AndRaise(exception.UpdateReplace) self.m.ReplayAll() self.stack.update(updated_stack) diff --git a/heat/tests/test_nokey.py b/heat/tests/test_nokey.py index 5402947150..6c588735c5 100644 --- a/heat/tests/test_nokey.py +++ b/heat/tests/test_nokey.py @@ -69,12 +69,12 @@ class nokeyTest(common.HeatTestCase): metadata = instance.metadata_get() server_userdata = instance.client_plugin().build_userdata( metadata, - instance.t['Properties']['UserData'], + instance.properties['UserData'], 'ec2-user') self.m.StubOutWithMock(nova.NovaClientPlugin, 'build_userdata') nova.NovaClientPlugin.build_userdata( metadata, - instance.t['Properties']['UserData'], + instance.properties['UserData'], 'ec2-user').AndReturn(server_userdata) self.m.StubOutWithMock(self.fc.servers, 'create') diff --git a/heat/tests/test_server_tags.py b/heat/tests/test_server_tags.py index 5d22f343c3..bba06a7f0e 100644 --- a/heat/tests/test_server_tags.py +++ b/heat/tests/test_server_tags.py @@ -11,7 +11,6 @@ # License for the specific language governing permissions and limitations # under the License. -import copy import uuid from heat.common import template_format @@ -74,7 +73,7 @@ class ServerTagsTest(common.HeatTestCase): t['Resources']['WebServer']['Properties']['Tags'] = intags resource_defns = template.resource_definitions(self.stack) - instance = instances.Instance(stack_name, + instance = instances.Instance('WebServer', resource_defns['WebServer'], self.stack) self.m.StubOutWithMock(nova.NovaClientPlugin, '_create') @@ -84,12 +83,12 @@ class ServerTagsTest(common.HeatTestCase): metadata = instance.metadata_get() server_userdata = instance.client_plugin().build_userdata( metadata, - instance.t['Properties']['UserData'], + instance.properties['UserData'], 'ec2-user') self.m.StubOutWithMock(nova.NovaClientPlugin, 'build_userdata') nova.NovaClientPlugin.build_userdata( metadata, - instance.t['Properties']['UserData'], + instance.properties['UserData'], 'ec2-user').AndReturn(server_userdata) self.m.StubOutWithMock(self.fc.servers, 'create') @@ -138,8 +137,10 @@ class ServerTagsTest(common.HeatTestCase): self.stub_KeypairConstraint_validate() self.stub_FlavorConstraint_validate() self.m.ReplayAll() - update_template = copy.deepcopy(instance.t) - update_template['Properties']['Tags'] = new_tags + snippet = instance.stack.t.t['Resources'][instance.name] + props = snippet['Properties'].copy() + props['Tags'] = new_tags + update_template = instance.t.freeze(properties=props) scheduler.TaskRunner(instance.update, update_template)() self.assertEqual((instance.UPDATE, instance.COMPLETE), instance.state) self.m.VerifyAll() diff --git a/heat/tests/test_stack_update.py b/heat/tests/test_stack_update.py index bed46fae5c..f6d5cfbdec 100644 --- a/heat/tests/test_stack_update.py +++ b/heat/tests/test_stack_update.py @@ -20,6 +20,7 @@ from heat.common import template_format from heat.db.sqlalchemy import api as db_api from heat.engine import environment from heat.engine import resource +from heat.engine import rsrc_defn from heat.engine import scheduler from heat.engine import service from heat.engine import stack @@ -405,11 +406,13 @@ class StackUpdateTest(common.HeatTestCase): self.assertEqual((stack.Stack.UPDATE, stack.Stack.COMPLETE), self.stack.state) self.assertEqual('xyz', self.stack['AResource'].properties['Foo']) - mock_upd.assert_called_once_with( - {'Type': 'ResourceWithPropsType', - 'Properties': {'Foo': 'xyz'}}, - {'Type': 'ResourceWithPropsType', - 'Properties': {'Foo': 'abc'}}) + after = rsrc_defn.ResourceDefinition('AResource', + 'ResourceWithPropsType', + properties={'Foo': 'xyz'}) + before = rsrc_defn.ResourceDefinition('AResource', + 'ResourceWithPropsType', + properties={'Foo': 'abc'}) + mock_upd.assert_called_once_with(after, before) def test_update_replace_create_hook(self): tmpl = { @@ -549,7 +552,8 @@ class StackUpdateTest(common.HeatTestCase): self.assertEqual((stack.Stack.UPDATE, stack.Stack.FAILED), self.stack.state) mock_upd.assert_called_once_with( - tmpl2['Resources']['AResource'], + rsrc_defn.ResourceDefinition('AResource', 'ResourceWithPropsType', + properties={'Foo': 'xyz'}), mock.ANY, {'Foo': 'xyz'})