salt/tests/unit/modules/test_alternatives.py
rallytime 3273bbdab7
Merge branch '2017.7' into '2018.3'
Conflicts:
  - doc/ref/configuration/master.rst
  - doc/ref/modules/all/index.rst
  - doc/topics/grains/index.rst
  - doc/topics/releases/2016.3.4.rst
  - doc/topics/spm/spm_formula.rst
  - doc/topics/tutorials/cron.rst
  - doc/topics/tutorials/index.rst
  - doc/topics/tutorials/stormpath.rst
  - salt/engines/slack.py
  - salt/log/handlers/fluent_mod.py
  - salt/modules/cyg.py
  - salt/modules/junos.py
  - salt/modules/namecheap_dns.py
  - salt/modules/namecheap_domains.py
  - salt/modules/namecheap_ns.py
  - salt/modules/namecheap_ssl.py
  - salt/modules/namecheap_users.py
  - salt/modules/reg.py
  - salt/modules/tomcat.py
  - salt/modules/vault.py
  - salt/modules/win_file.py
  - salt/modules/zpool.py
  - salt/output/highstate.py
  - salt/renderers/pass.py
  - salt/runners/cache.py
  - salt/states/boto_apigateway.py
  - salt/states/boto_iam.py
  - salt/states/boto_route53.py
  - salt/states/msteams.py
  - salt/states/reg.py
  - salt/states/win_iis.py
  - tests/integration/modules/test_cmdmod.py
  - tests/integration/states/test_user.py
  - tests/support/helpers.py
  - tests/unit/cloud/clouds/test_openstack.py
  - tests/unit/fileserver/test_gitfs.py
  - tests/unit/modules/test_junos.py
  - tests/unit/pillar/test_git.py
  - tests/unit/states/test_win_path.py
  - tests/unit/test_pillar.py
  - tests/unit/utils/test_format_call.py
  - tests/unit/utils/test_utils.py
  - tests/unit/utils/test_warnings.py
2018-06-01 14:54:12 -04:00

197 lines
7.9 KiB
Python

# -*- coding: utf-8 -*-
'''
:codeauthor: Pedro Algarvio (pedro@algarvio.me)
tests.unit.modules.alternatives_test
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
'''
# Import python libs
from __future__ import absolute_import, print_function, unicode_literals
# Import Salt Testing libs
from tests.support.mixins import LoaderModuleMockMixin
from tests.support.unit import skipIf, TestCase
from tests.support.helpers import TestsLoggingHandler
from tests.support.mock import NO_MOCK, NO_MOCK_REASON, MagicMock, patch
# Import salt libs
import salt.modules.alternatives as alternatives
@skipIf(NO_MOCK, NO_MOCK_REASON)
class AlternativesTestCase(TestCase, LoaderModuleMockMixin):
def setup_loader_modules(self):
return {alternatives: {}}
def test_display(self):
with patch.dict(alternatives.__grains__, {'os_family': 'RedHat'}):
mock = MagicMock(return_value={'retcode': 0, 'stdout': 'salt'})
with patch.dict(alternatives.__salt__, {'cmd.run_all': mock}):
solution = alternatives.display('better-world')
self.assertEqual('salt', solution)
mock.assert_called_once_with(
['alternatives', '--display', 'better-world'],
python_shell=False
)
with patch.dict(alternatives.__grains__, {'os_family': 'Suse'}):
mock = MagicMock(
return_value={'retcode': 0, 'stdout': 'undoubtedly-salt'}
)
with patch.dict(alternatives.__salt__, {'cmd.run_all': mock}):
solution = alternatives.display('better-world')
self.assertEqual('undoubtedly-salt', solution)
mock.assert_called_once_with(
['update-alternatives', '--display', 'better-world'],
python_shell=False
)
with patch.dict(alternatives.__grains__, {'os_family': 'RedHat'}):
mock = MagicMock(
return_value={
'retcode': 1,
'stdout': 'salt-out',
'stderr': 'salt-err'
}
)
with patch.dict(alternatives.__salt__, {'cmd.run_all': mock}):
solution = alternatives.display('better-world')
self.assertEqual('salt-err', solution)
mock.assert_called_once_with(
['alternatives', '--display', 'better-world'],
python_shell=False
)
def test_show_current(self):
mock = MagicMock(return_value='/etc/alternatives/salt')
with patch('salt.utils.path.readlink', mock):
ret = alternatives.show_current('better-world')
self.assertEqual('/etc/alternatives/salt', ret)
mock.assert_called_once_with('/etc/alternatives/better-world')
with TestsLoggingHandler() as handler:
mock.side_effect = OSError('Hell was not found!!!')
self.assertFalse(alternatives.show_current('hell'))
mock.assert_called_with('/etc/alternatives/hell')
self.assertIn('ERROR:alternative: hell does not exist',
handler.messages)
def test_check_installed(self):
mock = MagicMock(return_value='/etc/alternatives/salt')
with patch('salt.utils.path.readlink', mock):
self.assertTrue(
alternatives.check_installed(
'better-world', '/etc/alternatives/salt'
)
)
mock.return_value = False
self.assertFalse(
alternatives.check_installed(
'help', '/etc/alternatives/salt'
)
)
def test_install(self):
with patch.dict(alternatives.__grains__, {'os_family': 'RedHat'}):
mock = MagicMock(return_value={'retcode': 0, 'stdout': 'salt'})
with patch.dict(alternatives.__salt__, {'cmd.run_all': mock}):
solution = alternatives.install(
'better-world',
'/usr/bin/better-world',
'/usr/bin/salt',
100
)
self.assertEqual('salt', solution)
mock.assert_called_once_with(
['alternatives', '--install', '/usr/bin/better-world',
'better-world', '/usr/bin/salt', '100'],
python_shell=False
)
with patch.dict(alternatives.__grains__, {'os_family': 'Debian'}):
mock = MagicMock(return_value={'retcode': 0, 'stdout': 'salt'})
with patch.dict(alternatives.__salt__, {'cmd.run_all': mock}):
solution = alternatives.install(
'better-world',
'/usr/bin/better-world',
'/usr/bin/salt',
100
)
self.assertEqual('salt', solution)
mock.assert_called_once_with(
['update-alternatives', '--install', '/usr/bin/better-world',
'better-world', '/usr/bin/salt', '100'],
python_shell=False
)
with patch.dict(alternatives.__grains__, {'os_family': 'RedHat'}):
mock = MagicMock(
return_value={
'retcode': 1,
'stdout': 'salt-out',
'stderr': 'salt-err'
}
)
with patch.dict(alternatives.__salt__, {'cmd.run_all': mock}):
ret = alternatives.install(
'better-world',
'/usr/bin/better-world',
'/usr/bin/salt',
100
)
self.assertEqual('salt-err', ret)
mock.assert_called_once_with(
['alternatives', '--install', '/usr/bin/better-world',
'better-world', '/usr/bin/salt', '100'],
python_shell=False
)
def test_remove(self):
with patch.dict(alternatives.__grains__, {'os_family': 'RedHat'}):
mock = MagicMock(return_value={'retcode': 0, 'stdout': 'salt'})
with patch.dict(alternatives.__salt__, {'cmd.run_all': mock}):
solution = alternatives.remove(
'better-world',
'/usr/bin/better-world',
)
self.assertEqual('salt', solution)
mock.assert_called_once_with(
['alternatives', '--remove', 'better-world',
'/usr/bin/better-world'], python_shell=False
)
with patch.dict(alternatives.__grains__, {'os_family': 'Debian'}):
mock = MagicMock(return_value={'retcode': 0, 'stdout': 'salt'})
with patch.dict(alternatives.__salt__, {'cmd.run_all': mock}):
solution = alternatives.remove(
'better-world',
'/usr/bin/better-world',
)
self.assertEqual('salt', solution)
mock.assert_called_once_with(
['update-alternatives', '--remove', 'better-world',
'/usr/bin/better-world'], python_shell=False
)
with patch.dict(alternatives.__grains__, {'os_family': 'RedHat'}):
mock = MagicMock(
return_value={
'retcode': 1,
'stdout': 'salt-out',
'stderr': 'salt-err'
}
)
with patch.dict(alternatives.__salt__, {'cmd.run_all': mock}):
solution = alternatives.remove(
'better-world',
'/usr/bin/better-world',
)
self.assertEqual('salt-err', solution)
mock.assert_called_once_with(
['alternatives', '--remove', 'better-world',
'/usr/bin/better-world'], python_shell=False
)