Exemple #1
0
    def setUp(self):
        super(TestOutletTempControl, self).setUp()
        # fake metrics
        self.fake_metrics = faker_metrics_collector.FakerMetricsCollector()
        # fake cluster
        self.fake_cluster = faker_cluster_state.FakerModelCollector()

        p_model = mock.patch.object(strategies.OutletTempControl,
                                    "compute_model",
                                    new_callable=mock.PropertyMock)
        self.m_model = p_model.start()
        self.addCleanup(p_model.stop)

        p_ceilometer = mock.patch.object(strategies.OutletTempControl,
                                         "ceilometer",
                                         new_callable=mock.PropertyMock)
        self.m_ceilometer = p_ceilometer.start()
        self.addCleanup(p_ceilometer.stop)

        p_audit_scope = mock.patch.object(strategies.OutletTempControl,
                                          "audit_scope",
                                          new_callable=mock.PropertyMock)
        self.m_audit_scope = p_audit_scope.start()
        self.addCleanup(p_audit_scope.stop)

        self.m_audit_scope.return_value = mock.Mock()

        self.m_model.return_value = model_root.ModelRoot()
        self.m_ceilometer.return_value = mock.Mock(
            statistic_aggregation=self.fake_metrics.mock_get_statistics)
        self.strategy = strategies.OutletTempControl(config=mock.Mock())

        self.strategy.input_parameters = utils.Struct()
        self.strategy.input_parameters.update({'threshold': 34.3})
        self.strategy.threshold = 34.3
Exemple #2
0
 def test_group_hosts_by_outlet_temp(self):
     model = self.fake_cluster.generate_scenario_3_with_2_hypervisors()
     strategy = strategies.OutletTempControl()
     strategy.ceilometer = mock.MagicMock(
         statistic_aggregation=self.fake_metrics.mock_get_statistics)
     h1, h2 = strategy.group_hosts_by_outlet_temp(model)
     self.assertEqual('Node_1', h1[0]['hv'].uuid)
     self.assertEqual('Node_0', h2[0]['hv'].uuid)
Exemple #3
0
 def test_filter_dest_servers(self):
     model = self.fake_cluster.generate_scenario_3_with_2_hypervisors()
     strategy = strategies.OutletTempControl()
     strategy.ceilometer = mock.MagicMock(
         statistic_aggregation=self.fake_metrics.mock_get_statistics)
     h1, h2 = strategy.group_hosts_by_outlet_temp(model)
     vm_to_mig = strategy.choose_vm_to_migrate(model, h1)
     dest_hosts = strategy.filter_dest_servers(model, h2, vm_to_mig[1])
     self.assertEqual(1, len(dest_hosts))
     self.assertEqual('Node_0', dest_hosts[0]['hv'].uuid)
Exemple #4
0
 def test_choose_vm_to_migrate(self):
     model = self.fake_cluster.generate_scenario_3_with_2_hypervisors()
     strategy = strategies.OutletTempControl()
     strategy.ceilometer = mock.MagicMock(
         statistic_aggregation=self.fake_metrics.mock_get_statistics)
     h1, h2 = strategy.group_hosts_by_outlet_temp(model)
     vm_to_mig = strategy.choose_vm_to_migrate(model, h1)
     self.assertEqual('Node_1', vm_to_mig[0].uuid)
     self.assertEqual('a4cab39b-9828-413a-bf88-f76921bf1517',
                      vm_to_mig[1].uuid)
Exemple #5
0
    def test_calc_used_res(self):
        model = self.fake_cluster.generate_scenario_3_with_2_hypervisors()
        strategy = strategies.OutletTempControl()
        hypervisor = model.get_hypervisor_from_id('Node_0')
        cap_cores = model.get_resource_from_id(resource.ResourceType.cpu_cores)
        cap_mem = model.get_resource_from_id(resource.ResourceType.memory)
        cap_disk = model.get_resource_from_id(resource.ResourceType.disk)
        cores_used, mem_used, disk_used = strategy.calc_used_res(
            model, hypervisor, cap_cores, cap_mem, cap_disk)

        self.assertEqual((10, 2, 20), (cores_used, mem_used, disk_used))
Exemple #6
0
 def test_check_parameters(self):
     outlet = strategies.OutletTempControl()
     outlet.ceilometer = mock.MagicMock(
         statistic_aggregation=self.fake_metrics.mock_get_statistics)
     model = self.fake_cluster.generate_scenario_3_with_2_hypervisors()
     solution = outlet.execute(model)
     loader = default.DefaultActionLoader()
     for action in solution.actions:
         loaded_action = loader.load(action['action_type'])
         loaded_action.input_parameters = action['input_parameters']
         loaded_action.validate_parameters()
Exemple #7
0
    def test_execute(self):
        strategy = strategies.OutletTempControl()
        strategy.ceilometer = mock.MagicMock(
            statistic_aggregation=self.fake_metrics.mock_get_statistics)
        model = self.fake_cluster.generate_scenario_3_with_2_hypervisors()
        solution = strategy.execute(model)
        actions_counter = collections.Counter(
            [action.get('action_type') for action in solution.actions])

        num_migrations = actions_counter.get("migrate", 0)
        self.assertEqual(1, num_migrations)
Exemple #8
0
    def test_execute_no_workload(self):
        strategy = strategies.OutletTempControl()
        strategy.ceilometer = mock.MagicMock(
            statistic_aggregation=self.fake_metrics.mock_get_statistics)

        current_state_cluster = faker_cluster_state.FakerModelCollector()
        model = current_state_cluster. \
            generate_scenario_4_with_1_hypervisor_no_vm()

        solution = strategy.execute(model)
        self.assertEqual([], solution.actions)
Exemple #9
0
    def setUp(self):
        super(TestOutletTempControl, self).setUp()
        # fake metrics
        self.fake_metrics = self.fake_datasource_cls()

        p_datasource = mock.patch.object(
            strategies.OutletTempControl, 'datasource_backend',
            new_callable=mock.PropertyMock)
        self.m_datasource = p_datasource.start()
        self.addCleanup(p_datasource.stop)

        self.m_datasource.return_value = mock.Mock(
            statistic_aggregation=self.fake_metrics.mock_get_statistics,
            NAME=self.fake_metrics.NAME)
        self.strategy = strategies.OutletTempControl(
            config=mock.Mock(datasource=self.datasource))

        self.strategy.input_parameters = utils.Struct()
        self.strategy.input_parameters.update({'threshold': 34.3})
        self.strategy.threshold = 34.3
Exemple #10
0
 def test_execute_cluster_empty(self):
     strategy = strategies.OutletTempControl()
     strategy.ceilometer = mock.MagicMock(
         statistic_aggregation=self.fake_metrics.mock_get_statistics)
     model = model_root.ModelRoot()
     self.assertRaises(exception.ClusterEmpty, strategy.execute, model)
Exemple #11
0
 def test_exception_cluster_empty(self):
     strategy = strategies.OutletTempControl()
     model = model_root.ModelRoot()
     self.assertRaises(exception.ClusterEmpty, strategy.execute, model)
Exemple #12
0
 def test_exception_model(self):
     strategy = strategies.OutletTempControl()
     self.assertRaises(exception.ClusterStateNotDefined, strategy.execute,
                       None)