blob: 080f17f20c2c8c263290234ddfb40cbb5880eedc [file] [log] [blame]
Pavlo Shchelokovskyy9ede1852015-03-19 17:54:52 +00001#
2# Licensed under the Apache License, Version 2.0 (the "License"); you may
3# not use this file except in compliance with the License. You may obtain
4# a copy of the License at
5#
6# http://www.apache.org/licenses/LICENSE-2.0
7#
8# Unless required by applicable law or agreed to in writing, software
9# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
10# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
11# License for the specific language governing permissions and limitations
12# under the License.
13
14import time
15
16import requests
17
18from heat_integrationtests.common import test
19from heat_integrationtests.scenario import scenario_base
20
21
22class AutoscalingLoadBalancerTest(scenario_base.ScenarioTestsBase):
Mark Vanderwiel6d8e0862015-10-15 12:51:07 -050023 """The class is responsible for testing ASG + LBv1 scenario.
Pavlo Shchelokovskyy9ede1852015-03-19 17:54:52 +000024
25 The very common use case tested is an autoscaling group
26 of some web application servers behind a loadbalancer.
27 """
28
29 def setUp(self):
30 super(AutoscalingLoadBalancerTest, self).setUp()
31 self.template_name = 'test_autoscaling_lb_neutron.yaml'
32 self.app_server_template_name = 'app_server_neutron.yaml'
33 self.webapp_template_name = 'netcat-webapp.yaml'
Mark Vanderwiel6d8e0862015-10-15 12:51:07 -050034 if not self.is_network_extension_supported('lbaas'):
35 self.skipTest('LBaas v1 extension not available, skipping')
Pavlo Shchelokovskyy9ede1852015-03-19 17:54:52 +000036
37 def check_num_responses(self, url, expected_num, retries=10):
38 resp = set()
39 for count in range(retries):
40 time.sleep(1)
41 r = requests.get(url)
venkatamahesha9d3fdd2016-02-03 13:18:17 +053042 # skip unsuccessful requests
Pavlo Shchelokovskyy9ede1852015-03-19 17:54:52 +000043 if r.status_code == 200:
44 resp.add(r.text)
45 self.assertEqual(expected_num, len(resp))
46
47 def autoscale_complete(self, stack_id, expected_num):
48 res_list = self.client.resources.list(stack_id)
49 all_res_complete = all(res.resource_status in ('UPDATE_COMPLETE',
50 'CREATE_COMPLETE')
51 for res in res_list)
52 all_res = len(res_list) == expected_num
53 return all_res and all_res_complete
54
55 def test_autoscaling_loadbalancer_neutron(self):
Mark Vanderwiel6d8e0862015-10-15 12:51:07 -050056 """Check work of AutoScaing and Neutron LBaaS v1 resource in Heat.
Pavlo Shchelokovskyy9ede1852015-03-19 17:54:52 +000057
58 The scenario is the following:
59 1. Launch a stack with a load balancer and autoscaling group
60 of one server, wait until stack create is complete.
61 2. Check that there is only one distinctive response from
62 loadbalanced IP.
63 3. Signal the scale_up policy, wait until all resources in
64 autoscaling group are complete.
65 4. Check that now there are two distinctive responses from
66 loadbalanced IP.
67 """
68
69 parameters = {
70 'flavor': self.conf.minimal_instance_type,
71 'image': self.conf.minimal_image_ref,
72 'net': self.conf.fixed_network_name,
73 'subnet': self.conf.fixed_subnet_name,
74 'public_net': self.conf.floating_network_name,
75 'app_port': 8080,
76 'lb_port': 80,
77 'timeout': 600
78 }
79
80 app_server_template = self._load_template(
81 __file__, self.app_server_template_name, self.sub_dir
82 )
83 webapp_template = self._load_template(
84 __file__, self.webapp_template_name, self.sub_dir
85 )
86 files = {'appserver.yaml': app_server_template,
87 'webapp.yaml': webapp_template}
88 env = {'resource_registry':
89 {'OS::Test::NeutronAppServer': 'appserver.yaml',
90 'OS::Test::WebAppConfig': 'webapp.yaml'}}
91 # Launch stack
92 sid = self.launch_stack(
93 template_name=self.template_name,
94 parameters=parameters,
95 files=files,
96 environment=env
97 )
98 stack = self.client.stacks.get(sid)
99 lb_url = self._stack_output(stack, 'lburl')
100 # Check number of distinctive responces, must be 1
101 self.check_num_responses(lb_url, 1)
102
103 # Signal the scaling hook
104 self.client.resources.signal(sid, 'scale_up')
105
106 # Wait for AutoScalingGroup update to finish
107 asg = self.client.resources.get(sid, 'asg')
108 test.call_until_true(self.conf.build_timeout,
109 self.conf.build_interval,
110 self.autoscale_complete,
111 asg.physical_resource_id, 2)
112
113 # Check number of distinctive responses, must now be 2
114 self.check_num_responses(lb_url, 2)