Skip to content

Commit

Permalink
Dev: unittest: Adjust unit test based on previous changes
Browse files Browse the repository at this point in the history
  • Loading branch information
liangxin1300 committed Sep 26, 2022
1 parent 74c8553 commit 672e905
Show file tree
Hide file tree
Showing 4 changed files with 71 additions and 15 deletions.
70 changes: 67 additions & 3 deletions test/unittests/test_bootstrap.py
Original file line number Diff line number Diff line change
Expand Up @@ -798,11 +798,13 @@ def test_init_qdevice_already_configured(self, mock_status, mock_ssh, mock_qdevi
mock_confirm.assert_called_once_with("Qdevice is already configured - overwrite?")
self.qdevice_with_ip.start_qdevice_service.assert_called_once_with()

@mock.patch('crmsh.bootstrap.adjust_priority_fencing_delay')
@mock.patch('crmsh.bootstrap.adjust_priority_in_rsc_defaults')
@mock.patch('crmsh.utils.list_cluster_nodes')
@mock.patch('crmsh.utils.is_qdevice_configured')
@mock.patch('crmsh.utils.check_ssh_passwd_need')
@mock.patch('logging.Logger.info')
def test_init_qdevice(self, mock_info, mock_ssh, mock_qdevice_configured, mock_list_nodes):
def test_init_qdevice(self, mock_info, mock_ssh, mock_qdevice_configured, mock_list_nodes, mock_adjust_priority, mock_adjust_fence_delay):
bootstrap._context = mock.Mock(qdevice_inst=self.qdevice_with_ip)
mock_list_nodes.return_value = []
mock_ssh.return_value = False
Expand Down Expand Up @@ -905,6 +907,8 @@ def test_remove_qdevice_not_confirmed(self, mock_qdevice_configured, mock_confir
mock_qdevice_configured.assert_called_once_with()
mock_confirm.assert_called_once_with("Removing QDevice service and configuration from cluster: Are you sure?")

@mock.patch('crmsh.bootstrap.adjust_priority_fencing_delay')
@mock.patch('crmsh.bootstrap.adjust_priority_in_rsc_defaults')
@mock.patch('crmsh.qdevice.QDevice.remove_certification_files_on_qnetd')
@mock.patch('crmsh.qdevice.QDevice.remove_qdevice_db')
@mock.patch('crmsh.qdevice.QDevice.remove_qdevice_config')
Expand All @@ -917,7 +921,7 @@ def test_remove_qdevice_not_confirmed(self, mock_qdevice_configured, mock_confir
@mock.patch('crmsh.bootstrap.confirm')
@mock.patch('crmsh.utils.is_qdevice_configured')
def test_remove_qdevice_reload(self, mock_qdevice_configured, mock_confirm, mock_reachable, mock_evaluate,
mock_status, mock_invoke, mock_status_long, mock_update_votes, mock_remove_config, mock_remove_db, mock_remove_files):
mock_status, mock_invoke, mock_status_long, mock_update_votes, mock_remove_config, mock_remove_db, mock_remove_files, mock_adjust_priority, mock_adjust_fence_delay):
mock_qdevice_configured.return_value = True
mock_confirm.return_value = True
mock_evaluate.return_value = qdevice.QdevicePolicy.QDEVICE_RELOAD
Expand Down Expand Up @@ -1062,6 +1066,64 @@ def test_adjust_pcmk_delay_and_stonith_timeout(self, mock_is_active, mock_adjust
mock_adjust_pcmk_delay.assert_called_once_with()
mock_adjust_timeout.assert_called_once_with()

@mock.patch('crmsh.utils.set_property')
@mock.patch('crmsh.utils.is_2node_cluster_without_qdevice')
def test_adjust_priority_in_rsc_defaults_2node(self, mock_2node, mock_set):
mock_2node.return_value = True
bootstrap.adjust_priority_in_rsc_defaults()
mock_set.assert_called_once_with('priority', 1, property_type='rsc_defaults', property_id='rsc-options', conditional=True)

@mock.patch('crmsh.utils.set_property')
@mock.patch('crmsh.utils.is_2node_cluster_without_qdevice')
def test_adjust_priority_in_rsc_defaults(self, mock_2node, mock_set):
mock_2node.return_value = False
bootstrap.adjust_priority_in_rsc_defaults()
mock_set.assert_called_once_with('priority', 0, property_type='rsc_defaults', property_id='rsc-options')

@mock.patch('crmsh.utils.get_stdout_or_raise_error')
@mock.patch('crmsh.utils.service_is_active')
def test_adjust_priority_fencing_delay_no_run(self, mock_is_active, mock_run):
mock_is_active.return_value = False
bootstrap.adjust_priority_fencing_delay()
mock_is_active.assert_called_once_with("pacemaker.service")
mock_run.assert_not_called()

@mock.patch('crmsh.utils.get_stdout_or_raise_error')
@mock.patch('crmsh.utils.service_is_active')
def test_adjust_priority_fencing_delay_no_fence_agent(self, mock_is_active, mock_run):
mock_is_active.return_value = True
mock_run.return_value = None
bootstrap.adjust_priority_fencing_delay()
mock_is_active.assert_called_once_with("pacemaker.service")
mock_run.assert_called_once_with("crm configure show related:stonith:external/sbd")

@mock.patch('crmsh.utils.set_property')
@mock.patch('crmsh.utils.get_stdout_or_raise_error')
@mock.patch('crmsh.utils.service_is_active')
def test_adjust_priority_fencing_delay_no_pcmk_delay(self, mock_is_active, mock_run, mock_set):
mock_is_active.return_value = True
mock_run.return_value = "data"
bootstrap.adjust_priority_fencing_delay()
mock_is_active.assert_called_once_with("pacemaker.service")
mock_run.assert_called_once_with("crm configure show related:stonith:external/sbd")
mock_set.assert_called_once_with("priority-fencing-delay", 0)

@mock.patch('crmsh.utils.is_int')
@mock.patch('crmsh.utils.get_stdout_or_raise_error')
@mock.patch('crmsh.utils.service_is_active')
def test_adjust_priority_fencing_delay_invalid_value(self, mock_is_active, mock_run, mock_is_int):
mock_is_active.return_value = True
mock_run.return_value = """
primitive stonith-sbd stonith:external/sbd \
params pcmk_delay_max=test
"""
mock_is_int.return_value = False
with self.assertRaises(ValueError) as err:
bootstrap.adjust_priority_fencing_delay()
self.assertEqual("pcmk_delay_max's value \"test\" is invalid", str(err.exception))
mock_is_active.assert_called_once_with("pacemaker.service")
mock_run.assert_called_once_with("crm configure show related:stonith:external/sbd")


class TestValidation(unittest.TestCase):
"""
Expand Down Expand Up @@ -1517,6 +1579,8 @@ def test_remove_node_from_cluster_rm_csync_failed(self, mock_get_ip, mock_stop,
])
mock_error.assert_called_once_with("Removing the node node1 from {} failed".format(bootstrap.CSYNC2_CFG))

@mock.patch('crmsh.bootstrap.adjust_priority_fencing_delay')
@mock.patch('crmsh.bootstrap.adjust_priority_in_rsc_defaults')
@mock.patch('crmsh.bootstrap.csync2_update')
@mock.patch('crmsh.bootstrap.decrease_expected_votes')
@mock.patch('crmsh.corosync.del_node')
Expand All @@ -1528,7 +1592,7 @@ def test_remove_node_from_cluster_rm_csync_failed(self, mock_get_ip, mock_stop,
@mock.patch('crmsh.bootstrap.stop_services')
@mock.patch('crmsh.bootstrap.set_cluster_node_ip')
def test_remove_node_from_cluster_hostname(self, mock_get_ip, mock_stop, mock_status,
mock_invoke, mock_invokerc, mock_error, mock_get_values, mock_del, mock_decrease, mock_csync2):
mock_invoke, mock_invokerc, mock_error, mock_get_values, mock_del, mock_decrease, mock_csync2, mock_adjust_priority, mock_adjust_fence_delay):
mock_invoke.side_effect = [(True, None, None), (True, None, None), (True, None, None)]
mock_invokerc.return_value = True
mock_get_values.return_value = ["10.10.10.1"]
Expand Down
2 changes: 1 addition & 1 deletion test/unittests/test_qdevice.py
Original file line number Diff line number Diff line change
Expand Up @@ -981,7 +981,7 @@ def test_adjust_sbd_watchdog_timeout_with_qdevice(self, mock_check_reachable, mo
mock_evaluate.assert_called_once_with(qdevice.QDEVICE_ADD, True)
mock_get_sbd_value.assert_called_once_with("SBD_WATCHDOG_TIMEOUT")
mock_update_config.assert_called_once_with({"SBD_WATCHDOG_TIMEOUT": str(sbd.SBDTimeout.SBD_WATCHDOG_TIMEOUT_DEFAULT_WITH_QDEVICE)})
mock_set_property.assert_called_once_with(stonith_timeout=100)
mock_set_property.assert_called_once_with("stonith-timeout", 100)

@mock.patch('crmsh.qdevice.QDevice.start_qnetd')
@mock.patch('crmsh.qdevice.QDevice.enable_qnetd')
Expand Down
2 changes: 1 addition & 1 deletion test/unittests/test_sbd.py
Original file line number Diff line number Diff line change
Expand Up @@ -689,7 +689,7 @@ def test_configure_sbd_resource_and_properties(self, mock_package, mock_enabled,
mock_enabled.assert_called_once_with("sbd.service")
mock_configured.assert_called_once_with(sbd.SBDManager.SBD_RA)
mock_run.assert_called_once_with("crm configure primitive {} {}".format(sbd.SBDManager.SBD_RA_ID, sbd.SBDManager.SBD_RA))
mock_set_property.assert_called_once_with(stonith_enabled="true")
mock_set_property.assert_called_once_with("stonith-enabled", "true")

@mock.patch('crmsh.utils.package_is_installed')
def test_join_sbd_config_not_installed(self, mock_package):
Expand Down
12 changes: 2 additions & 10 deletions test/unittests/test_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -1618,8 +1618,8 @@ def test_get_property(mock_run, mock_env):

@mock.patch('crmsh.utils.get_stdout_or_raise_error')
def test_set_property(mock_run):
utils.set_property(no_quorum_policy="stop")
mock_run.assert_called_once_with("crm configure property no-quorum-policy=stop")
utils.set_property("no-quorum-policy", "stop")
mock_run.assert_called_once_with("crm_attribute -t crm_config -n no-quorum-policy -v stop")


@mock.patch('crmsh.utils.is_dlm_configured')
Expand Down Expand Up @@ -1657,14 +1657,6 @@ def test_get_systemd_timeout_start_in_sec():
assert res == 91


@mock.patch('crmsh.utils.get_stdout_or_raise_error')
@mock.patch('crmsh.utils.get_property')
def test_set_property_conditionally(mock_get_property, mock_run):
mock_get_property.return_value = "100s"
utils.set_property_conditionally("stonith-timeout", 101)
mock_run.assert_called_once_with("crm configure property stonith-timeout=101")


@mock.patch('crmsh.utils.is_larger_than_min_version')
@mock.patch('crmsh.cibconfig.cib_factory')
def test_is_ocf_1_1_cib_schema_detected(mock_cib, mock_larger):
Expand Down

0 comments on commit 672e905

Please sign in to comment.