diff options
Diffstat (limited to 'utils/test')
| -rw-r--r-- | utils/test/cli_installer_tests.py | 59 | ||||
| -rw-r--r-- | utils/test/fixture.py | 17 | ||||
| -rw-r--r-- | utils/test/test_utils.py | 72 | 
3 files changed, 110 insertions, 38 deletions
| diff --git a/utils/test/cli_installer_tests.py b/utils/test/cli_installer_tests.py index 34392777b..36dc18034 100644 --- a/utils/test/cli_installer_tests.py +++ b/utils/test/cli_installer_tests.py @@ -842,7 +842,7 @@ class AttendedCliTests(OOCliFixture):      # interactive with config file and some installed some uninstalled hosts      @patch('ooinstall.openshift_ansible.run_main_playbook')      @patch('ooinstall.openshift_ansible.load_system_facts') -    def test_add_nodes(self, load_facts_mock, run_playbook_mock): +    def test_scaleup_hint(self, load_facts_mock, run_playbook_mock):          # Modify the mock facts to return a version indicating OpenShift          # is already installed on our master, and the first node. @@ -866,13 +866,12 @@ class AttendedCliTests(OOCliFixture):          result = self.runner.invoke(cli.cli,                                      self.cli_args,                                      input=cli_input) -        self.assert_result(result, 0) -        self._verify_load_facts(load_facts_mock) -        self._verify_run_playbook(run_playbook_mock, 3, 2) +        # This is testing the install workflow so we want to make sure we +        # exit with the appropriate hint. +        self.assertTrue('scaleup' in result.output) +        self.assert_result(result, 1) -        written_config = read_yaml(self.config_file) -        self._verify_config_hosts(written_config, 3)      @patch('ooinstall.openshift_ansible.run_main_playbook')      @patch('ooinstall.openshift_ansible.load_system_facts') @@ -897,30 +896,30 @@ class AttendedCliTests(OOCliFixture):          written_config = read_yaml(config_file)          self._verify_config_hosts(written_config, 3) -    #interactive with config file and all installed hosts -    @patch('ooinstall.openshift_ansible.run_main_playbook') -    @patch('ooinstall.openshift_ansible.load_system_facts') -    def test_get_hosts_to_run_on(self, load_facts_mock, run_playbook_mock): -        mock_facts = copy.deepcopy(MOCK_FACTS) -        mock_facts['10.0.0.1']['common']['version'] = "3.0.0" -        mock_facts['10.0.0.2']['common']['version'] = "3.0.0" - -        cli_input = build_input(hosts=[ -            ('10.0.0.1', True, False), -            ], -                                      add_nodes=[('10.0.0.2', False, False)], -                                      ssh_user='root', -                                      variant_num=1, -                                      schedulable_masters_ok=True, -                                      confirm_facts='y', -                                      storage='10.0.0.1',) - -        self._verify_get_hosts_to_run_on(mock_facts, load_facts_mock, -                                         run_playbook_mock, -                                         cli_input, -                                         exp_hosts_len=2, -                                         exp_hosts_to_run_on_len=2, -                                         force=False) +#    #interactive with config file and all installed hosts +#    @patch('ooinstall.openshift_ansible.run_main_playbook') +#    @patch('ooinstall.openshift_ansible.load_system_facts') +#    def test_get_hosts_to_run_on(self, load_facts_mock, run_playbook_mock): +#        mock_facts = copy.deepcopy(MOCK_FACTS) +#        mock_facts['10.0.0.1']['common']['version'] = "3.0.0" +#        mock_facts['10.0.0.2']['common']['version'] = "3.0.0" +# +#        cli_input = build_input(hosts=[ +#            ('10.0.0.1', True, False), +#            ], +#                                      add_nodes=[('10.0.0.2', False, False)], +#                                      ssh_user='root', +#                                      variant_num=1, +#                                      schedulable_masters_ok=True, +#                                      confirm_facts='y', +#                                      storage='10.0.0.1',) +# +#        self._verify_get_hosts_to_run_on(mock_facts, load_facts_mock, +#                                         run_playbook_mock, +#                                         cli_input, +#                                         exp_hosts_len=2, +#                                         exp_hosts_to_run_on_len=2, +#                                         force=False)      #interactive multimaster: one more node than master      @patch('ooinstall.openshift_ansible.run_main_playbook') diff --git a/utils/test/fixture.py b/utils/test/fixture.py index a883e5c56..62135c761 100644 --- a/utils/test/fixture.py +++ b/utils/test/fixture.py @@ -138,8 +138,8 @@ class OOCliFixture(OOInstallFixture):              written_config = read_yaml(config_file)              self._verify_config_hosts(written_config, exp_hosts_len) -        if "Uninstalled" in result.output: -            # verify we exited on seeing uninstalled hosts +        if "If you want to force reinstall" in result.output: +            # verify we exited on seeing installed hosts              self.assertEqual(result.exit_code, 1)          else:              self.assert_result(result, 0) @@ -156,7 +156,7 @@ class OOCliFixture(OOInstallFixture):  #pylint: disable=too-many-arguments,too-many-branches,too-many-statements  def build_input(ssh_user=None, hosts=None, variant_num=None,                  add_nodes=None, confirm_facts=None, schedulable_masters_ok=None, -                master_lb=None, storage=None): +                master_lb=('', False), storage=None):      """      Build an input string simulating a user entering values in an interactive      attended install. @@ -204,11 +204,11 @@ def build_input(ssh_user=None, hosts=None, variant_num=None,              i += 1      # You can pass a single master_lb or a list if you intend for one to get rejected: -    if master_lb: -        if isinstance(master_lb[0], list) or isinstance(master_lb[0], tuple): -            inputs.extend(master_lb[0]) -        else: -            inputs.append(master_lb[0]) +    if isinstance(master_lb[0], list) or isinstance(master_lb[0], tuple): +        inputs.extend(master_lb[0]) +    else: +        inputs.append(master_lb[0]) +    if master_lb[0]:          inputs.append('y' if master_lb[1] else 'n')      if storage: @@ -248,6 +248,7 @@ def build_input(ssh_user=None, hosts=None, variant_num=None,      inputs.extend([          confirm_facts,          'y',  # lets do this +        'y',      ])      return '\n'.join(inputs) diff --git a/utils/test/test_utils.py b/utils/test/test_utils.py new file mode 100644 index 000000000..8d59f388e --- /dev/null +++ b/utils/test/test_utils.py @@ -0,0 +1,72 @@ +""" +Unittests for ooinstall utils. +""" + +import unittest +import logging +import sys +import copy +from ooinstall.utils import debug_env +import mock + + +class TestUtils(unittest.TestCase): +    """ +    Parent unittest TestCase. +    """ + +    def setUp(self): +        self.debug_all_params = { +            'OPENSHIFT_FOO': 'bar', +            'ANSIBLE_FOO': 'bar', +            'OO_FOO': 'bar' +        } + +        self.expected = [ +            mock.call('ANSIBLE_FOO: bar'), +            mock.call('OPENSHIFT_FOO: bar'), +            mock.call('OO_FOO: bar'), +        ] + +        # python 2.x has assertItemsEqual, python 3.x has assertCountEqual +        if sys.version_info.major > 3: +            self.assertItemsEqual = self.assertCountEqual + +    ###################################################################### +    # Validate ooinstall.utils.debug_env functionality + +    def test_utils_debug_env_all_debugged(self): +        """Verify debug_env debugs specific env variables""" + +        with mock.patch('ooinstall.utils.installer_log') as _il: +            debug_env(self.debug_all_params) +            print _il.debug.call_args_list + +            # Debug was called for each item we expect +            self.assertEqual( +                len(self.debug_all_params), +                _il.debug.call_count) + +            # Each item we expect was logged +            self.assertItemsEqual( +                self.expected, +                _il.debug.call_args_list) + +    def test_utils_debug_env_some_debugged(self): +        """Verify debug_env skips non-wanted env variables""" +        debug_some_params = copy.deepcopy(self.debug_all_params) +        # This will not be logged by debug_env +        debug_some_params['MG_FRBBR'] = "SKIPPED" + +        with mock.patch('ooinstall.utils.installer_log') as _il: +            debug_env(debug_some_params) + +            # The actual number of debug calls was less than the +            # number of items passed to debug_env +            self.assertLess( +                _il.debug.call_count, +                len(debug_some_params)) + +            self.assertItemsEqual( +                self.expected, +                _il.debug.call_args_list) | 
