Exemplo n.º 1
0
 def test_list_stacks(self, mock_clients):
     stacks_list = []
     mock_clients("heat").stacks.list.return_value = stacks_list
     scenario = utils.HeatScenario()
     return_stacks_list = scenario._list_stacks()
     self.assertEqual(stacks_list, return_stacks_list)
     self._test_atomic_action_timer(scenario.atomic_actions(),
                                    "heat.list_stacks")
Exemplo n.º 2
0
 def test_delete_stack(self):
     scenario = utils.HeatScenario()
     scenario._delete_stack(self.stack)
     self.stack.delete.assert_called_once_with()
     self.wait_for_delete.mock.assert_called_once_with(
         self.stack,
         update_resource=self.gfm(),
         check_interval=1,
         timeout=3600)
     self._test_atomic_action_timer(scenario.atomic_actions(),
                                    "heat.delete_stack")
Exemplo n.º 3
0
 def setup(self):
     template = self._prepare_stack_template(
         self.config["resources_per_stack"])
     for user, tenant_id in rutils.iterate_per_tenants(
             self.context["users"]):
         heat_scenario = heat_utils.HeatScenario(
             clients=osclients.Clients(user["endpoint"]))
         self.context["tenants"][tenant_id]["stacks"] = []
         for i in range(self.config["stacks_per_tenant"]):
             stack = heat_scenario._create_stack(template)
             self.context["tenants"][tenant_id]["stacks"].append(stack.id)
Exemplo n.º 4
0
 def test_check_stack(self, mock_clients):
     scenario = utils.HeatScenario()
     scenario._check_stack(self.stack)
     mock_clients("heat").actions.check.assert_called_once_with(
         self.stack.id)
     self.wait_for.mock.assert_called_once_with(
         self.stack,
         update_resource=self.gfm(),
         is_ready=self.res_is.mock(),
         check_interval=utils.CONF.benchmark.heat_stack_check_poll_interval,
         timeout=utils.CONF.benchmark.heat_stack_check_timeout)
     self.res_is.mock.assert_has_calls([mock.call("CHECK_COMPLETE")])
     self._test_atomic_action_timer(scenario.atomic_actions(),
                                    "heat.check_stack")
Exemplo n.º 5
0
 def setUp(self):
     super(HeatScenarioTestCase, self).setUp()
     self.stack = mock.Mock()
     self.res_is = mockpatch.Patch(BM_UTILS + ".resource_is")
     self.get_fm = mockpatch.Patch(BM_UTILS + ".get_from_manager")
     self.wait_for = mockpatch.Patch(HEAT_UTILS + ".bench_utils.wait_for")
     self.wait_for_delete = mockpatch.Patch(
         HEAT_UTILS + ".bench_utils.wait_for_delete")
     self.useFixture(self.wait_for)
     self.useFixture(self.wait_for_delete)
     self.useFixture(self.res_is)
     self.useFixture(self.get_fm)
     self.gfm = self.get_fm.mock
     self.useFixture(mockpatch.Patch("time.sleep"))
     self.scenario = utils.HeatScenario()
Exemplo n.º 6
0
    def test_update_stack(self, mock_bench, mock_clients):
        mock_clients("heat").stacks.update.return_value = None
        mock_bench.heat_stack_update_timeout = 1
        mock_bench.heat_stack_update_poll_interval = 1

        scenario = utils.HeatScenario()
        scenario._update_stack(self.stack, None)
        self.wait_for.mock.assert_called_once_with(self.stack,
                                                   update_resource=self.gfm(),
                                                   is_ready=self.res_is.mock(),
                                                   check_interval=1,
                                                   timeout=1)
        self.res_is.mock.assert_has_calls([mock.call("UPDATE_COMPLETE")])
        self._test_atomic_action_timer(scenario.atomic_actions(),
                                       "heat.update_stack")
Exemplo n.º 7
0
 def test_create_stack(self, mock_clients):
     mock_clients("heat").stacks.create.return_value = \
         {'stack': {'id': 'test_id'}}
     mock_clients("heat").stacks.get.return_value = self.stack
     scenario = utils.HeatScenario()
     return_stack = scenario._create_stack('stack_name')
     self.wait_for.mock.assert_called_once_with(self.stack,
                                                update_resource=self.gfm(),
                                                is_ready=self.res_is.mock(),
                                                check_interval=1,
                                                timeout=3600)
     self.res_is.mock.assert_has_calls(mock.call('CREATE_COMPLETE'))
     self.assertEqual(self.wait_for.mock(), return_stack)
     self._test_atomic_action_timer(scenario.atomic_actions(),
                                    'heat.create_stack')
Exemplo n.º 8
0
 def test_create_stack(self, mock_clients):
     mock_clients("heat").stacks.create.return_value = {
         "stack": {"id": "test_id"}
     }
     mock_clients("heat").stacks.get.return_value = self.stack
     scenario = utils.HeatScenario()
     return_stack = scenario._create_stack()
     self.wait_for.mock.assert_called_once_with(self.stack,
                                                update_resource=self.gfm(),
                                                is_ready=self.res_is.mock(),
                                                check_interval=1,
                                                timeout=3600)
     self.res_is.mock.assert_has_calls([mock.call("CREATE_COMPLETE")])
     self.assertEqual(self.wait_for.mock(), return_stack)
     self._test_atomic_action_timer(scenario.atomic_actions(),
                                    "heat.create_stack")
Exemplo n.º 9
0
    def test_resume_stack(self, mock_bench, mock_clients):
        mock_bench.heat_stack_resume_timeout = 1
        mock_bench.heat_stack_resume_poll_interval = 1

        scenario = utils.HeatScenario()
        scenario._resume_stack(self.stack)
        mock_clients("heat").actions.resume.assert_called_once_with(
            self.stack.id)
        self.wait_for.mock.assert_called_once_with(self.stack,
                                                   update_resource=self.gfm(),
                                                   is_ready=self.res_is.mock(),
                                                   check_interval=1,
                                                   timeout=1)
        self.res_is.mock.assert_has_calls([mock.call("RESUME_COMPLETE")])
        self._test_atomic_action_timer(scenario.atomic_actions(),
                                       "heat.resume_stack")
Exemplo n.º 10
0
    def test_failed_update_stack(self, mock_bench, mock_clients):
        mock_bench.heat_stack_update_prepoll_delay = 2
        mock_bench.heat_stack_update_timeout = 1
        mock_bench.benchmark.heat_stack_update_poll_interval = 1

        stack = mock.Mock()
        resource = mock.Mock()
        resource.stack_status = "UPDATE_FAILED"
        stack.manager.get.return_value = resource
        mock_clients("heat").stacks.get.return_value = stack
        scenario = utils.HeatScenario()
        try:
            ex = self.assertRaises(exceptions.GetResourceErrorStatus,
                                   scenario._update_stack, stack)
            self.assertIn("has UPDATE_FAILED status", str(ex))
        except exceptions.TimeoutException:
            raise self.fail("Unrecognized error status")
Exemplo n.º 11
0
    def test_failed_create_stack(self, mock_bench, mock_clients):
        mock_bench.heat_stack_create_prepoll_delay = 2
        mock_bench.heat_stack_create_timeout = 1
        mock_bench.benchmark.heat_stack_create_poll_interval = 1

        mock_clients("heat").stacks.create.return_value = {
            'stack': {
                'id': 'test_id'
            }
        }
        stack = mock.Mock()
        resource = mock.Mock()
        resource.stack_status = "CREATE_FAILED"
        stack.manager.get.return_value = resource
        mock_clients("heat").stacks.get.return_value = stack
        scenario = utils.HeatScenario()
        try:
            ex = self.assertRaises(exceptions.GetResourceErrorStatus,
                                   scenario._create_stack, 'stack_name')
            self.assertIn('has CREATE_FAILED status', str(ex))
        except exceptions.TimeoutException:
            raise self.fail('Unrecognized error status')