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

        p_osc = mock.patch.object(clients, "OpenStackClients")
        self.m_osc = p_osc.start()
        self.addCleanup(p_osc.stop)

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

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

        p_audit_scope = mock.patch.object(strategies.BasicConsolidation,
                                          "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.BasicConsolidation(config=mock.Mock())
예제 #2
0
 def build():
     metrics = fake.FakerMetricsCollector()
     current_state_cluster = faker_cluster_state.FakerModelCollector()
     sercon = strategies.BasicConsolidation(config=mock.Mock())
     sercon._compute_model = current_state_cluster.generate_scenario_1()
     sercon.ceilometer = mock.MagicMock(
         get_statistics=metrics.mock_get_statistics)
     return sercon.execute()
예제 #3
0
 def build():
     metrics = fake.FakerMetricsCollector()
     current_state_cluster = faker_cluster_state.FakerModelCollector()
     sercon = strategies.BasicConsolidation("basic",
                                            "Basic offline consolidation")
     sercon.ceilometer = mock.\
         MagicMock(get_statistics=metrics.mock_get_statistics)
     return sercon.execute(current_state_cluster.generate_scenario_1())
예제 #4
0
 def test_basic_consolidation_score_vm_disk(self):
     cluster = self.fake_cluster.generate_scenario_5_with_vm_disk_0()
     sercon = strategies.BasicConsolidation()
     sercon.ceilometer = mock.MagicMock(
         statistic_aggregation=self.fake_metrics.mock_get_statistics)
     vm_0 = cluster.get_vm_from_id("VM_0")
     vm_0_score = 0.023333333333333355
     self.assertEqual(sercon.calculate_score_vm(vm_0, cluster), vm_0_score)
예제 #5
0
    def test_calculate_score_vm_raise_cluster_state_not_found(self):
        metrics = faker_metrics_collector.FakerMetricsCollector()
        metrics.empty_one_metric("CPU_COMPUTE")
        sercon = strategies.BasicConsolidation()
        sercon.ceilometer = mock.MagicMock(
            statistic_aggregation=self.fake_metrics.mock_get_statistics)

        self.assertRaises(exception.ClusterStateNotDefined,
                          sercon.calculate_score_vm, "VM_1", None)
예제 #6
0
    def test_check_migration(self):
        sercon = strategies.BasicConsolidation()
        fake_cluster = faker_cluster_state.FakerModelCollector()
        model = fake_cluster.generate_scenario_3_with_2_hypervisors()

        all_vms = model.get_all_vms()
        all_hyps = model.get_all_hypervisors()
        vm0 = all_vms[list(all_vms.keys())[0]]
        hyp0 = all_hyps[list(all_hyps.keys())[0]]

        sercon.check_migration(model, hyp0, hyp0, vm0)
예제 #7
0
 def test_check_parameters(self):
     sercon = strategies.BasicConsolidation()
     sercon.ceilometer = mock.MagicMock(
         statistic_aggregation=self.fake_metrics.mock_get_statistics)
     solution = sercon.execute(
         self.fake_cluster.generate_scenario_3_with_2_hypervisors())
     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()
예제 #8
0
    def test_threshold(self):
        sercon = strategies.BasicConsolidation()
        fake_cluster = faker_cluster_state.FakerModelCollector()
        model = fake_cluster.generate_scenario_3_with_2_hypervisors()

        all_hyps = model.get_all_hypervisors()
        hyp0 = all_hyps[list(all_hyps.keys())[0]]

        sercon.check_threshold(model, hyp0, 1000, 1000, 1000)

        threshold_cores = sercon.get_threshold_cores()
        sercon.set_threshold_cores(threshold_cores + 1)
        self.assertEqual(sercon.get_threshold_cores(), threshold_cores + 1)
예제 #9
0
    def test_execute_no_workload(self):
        sercon = strategies.BasicConsolidation()
        sercon.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()

        with mock.patch.object(strategies.BasicConsolidation,
                               'calculate_weight') \
                as mock_score_call:
            mock_score_call.return_value = 0
            solution = sercon.execute(model)
            self.assertEqual(solution.efficacy, 100)
예제 #10
0
 def test_basic_consolidation_weight(self):
     cluster = self.fake_cluster.generate_scenario_1()
     sercon = strategies.BasicConsolidation()
     sercon.ceilometer = mock.MagicMock(
         statistic_aggregation=self.fake_metrics.mock_get_statistics)
     vm_0 = cluster.get_vm_from_id("VM_0")
     cores = 16
     # 80 Go
     disk = 80
     # mem 8 Go
     mem = 8
     vm_0_weight_assert = 3.1999999999999997
     self.assertEqual(
         sercon.calculate_weight(cluster, vm_0, cores, disk, mem),
         vm_0_weight_assert)
예제 #11
0
    def test_basic_consolidation_migration(self):
        sercon = strategies.BasicConsolidation()
        sercon.ceilometer = mock.MagicMock(
            statistic_aggregation=self.fake_metrics.mock_get_statistics)

        solution = sercon.execute(
            self.fake_cluster.generate_scenario_3_with_2_hypervisors())

        actions_counter = collections.Counter(
            [action.get('action_type') for action in solution.actions])

        expected_num_migrations = 1
        expected_power_state = 0

        num_migrations = actions_counter.get("migrate", 0)
        num_hypervisor_state_change = actions_counter.get(
            "change_hypervisor_state", 0)
        self.assertEqual(num_migrations, expected_num_migrations)
        self.assertEqual(num_hypervisor_state_change, expected_power_state)
예제 #12
0
    def setUp(self):
        super(TestBasicConsolidation, self).setUp()
        # fake metrics
        self.fake_metrics = self.fake_datasource_cls()

        p_osc = mock.patch.object(clients, "OpenStackClients")
        self.m_osc = p_osc.start()
        self.addCleanup(p_osc.stop)

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

        self.m_datasource.return_value = mock.Mock(
            get_host_cpu_usage=self.fake_metrics.get_usage_node_cpu,
            get_instance_cpu_usage=self.fake_metrics.
            get_average_usage_instance_cpu)
        self.strategy = strategies.BasicConsolidation(config=mock.Mock(
            datasource=self.datasource))
예제 #13
0
    def test_basic_consolidation_score_vm(self):
        cluster = self.fake_cluster.generate_scenario_1()
        sercon = strategies.BasicConsolidation()
        sercon.ceilometer = mock.MagicMock(
            statistic_aggregation=self.fake_metrics.mock_get_statistics)
        vm_0 = cluster.get_vm_from_id("VM_0")
        vm_0_score = 0.023333333333333317
        self.assertEqual(sercon.calculate_score_vm(vm_0, cluster), vm_0_score)

        vm_1 = cluster.get_vm_from_id("VM_1")
        vm_1_score = 0.023333333333333317
        self.assertEqual(sercon.calculate_score_vm(vm_1, cluster), vm_1_score)
        vm_2 = cluster.get_vm_from_id("VM_2")
        vm_2_score = 0.033333333333333326
        self.assertEqual(sercon.calculate_score_vm(vm_2, cluster), vm_2_score)
        vm_6 = cluster.get_vm_from_id("VM_6")
        vm_6_score = 0.02666666666666669
        self.assertEqual(sercon.calculate_score_vm(vm_6, cluster), vm_6_score)
        vm_7 = cluster.get_vm_from_id("VM_7")
        vm_7_score = 0.013333333333333345
        self.assertEqual(sercon.calculate_score_vm(vm_7, cluster), vm_7_score)
예제 #14
0
    def test_basic_consolidation_score_hypervisor(self):
        cluster = self.fake_cluster.generate_scenario_1()
        sercon = strategies.BasicConsolidation()
        sercon.ceilometer = mock.MagicMock(
            statistic_aggregation=self.fake_metrics.mock_get_statistics)

        node_1_score = 0.023333333333333317
        self.assertEqual(
            sercon.calculate_score_node(
                cluster.get_hypervisor_from_id("Node_1"), cluster),
            node_1_score)
        node_2_score = 0.26666666666666666
        self.assertEqual(
            sercon.calculate_score_node(
                cluster.get_hypervisor_from_id("Node_2"), cluster),
            node_2_score)
        node_0_score = 0.023333333333333317
        self.assertEqual(
            sercon.calculate_score_node(
                cluster.get_hypervisor_from_id("Node_0"), cluster),
            node_0_score)
예제 #15
0
    def setUp(self):
        super(TestBasicConsolidation, self).setUp()
        # fake metrics
        self.fake_metrics = self.fake_datasource_cls()
        # fake cluster
        self.fake_cluster = faker_cluster_state.FakerModelCollector()

        p_osc = mock.patch.object(clients, "OpenStackClients")
        self.m_osc = p_osc.start()
        self.addCleanup(p_osc.stop)

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

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

        p_audit_scope = mock.patch.object(strategies.BasicConsolidation,
                                          "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_datasource.return_value = mock.Mock(
            get_host_cpu_usage=self.fake_metrics.get_usage_node_cpu,
            get_instance_cpu_usage=self.fake_metrics.
            get_average_usage_instance_cpu)
        self.strategy = strategies.BasicConsolidation(config=mock.Mock(
            datasource=self.datasource))
예제 #16
0
 def test_exception_model(self):
     sercon = strategies.BasicConsolidation()
     self.assertRaises(exception.ClusterStateNotDefined, sercon.execute,
                       None)
예제 #17
0
 def test_number_of(self):
     sercon = strategies.BasicConsolidation()
     sercon.get_number_of_released_nodes()
     sercon.get_number_of_migrations()
예제 #18
0
 def test_exception_cluster_empty(self):
     sercon = strategies.BasicConsolidation()
     model = model_root.ModelRoot()
     self.assertRaises(exception.ClusterEmpty, sercon.execute, model)
예제 #19
0
 def test_calculate_migration_efficacy(self):
     sercon = strategies.BasicConsolidation()
     sercon.calculate_migration_efficacy()