123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115 |
- # -*- coding: utf-8 -*-
- '''
- :codeauthor: Rahul Handay <rahulha@saltstack.com>
- '''
- # Import Python Libs
- from __future__ import absolute_import, unicode_literals, print_function
- import os
- # Import Salt Testing Libs
- from tests.support.mixins import LoaderModuleMockMixin
- from tests.support.unit import TestCase
- from tests.support.mock import (
- MagicMock,
- patch,
- )
- # Import Salt Libs
- import salt.config
- import salt.utils.path
- from salt.syspaths import BASE_FILE_ROOTS_DIR
- import salt.states.winrepo as winrepo
- class MockRunnerClient(object):
- '''
- Mock RunnerClient class
- '''
- def __init__(self):
- pass
- class RunnerClient(object):
- '''
- Mock RunnerClient class
- '''
- def __init__(self, master_config):
- '''
- init method
- '''
- @staticmethod
- def cmd(arg1, arg2):
- '''
- Mock cmd method
- '''
- # TODO: Figure out how to have this return an empty dict or a dict
- # TODO: with expected data
- return []
- class WinrepoTestCase(TestCase, LoaderModuleMockMixin):
- '''
- Validate the winrepo state
- '''
- def setup_loader_modules(self):
- patcher = patch('salt.states.winrepo.salt.runner', MockRunnerClient)
- patcher.start()
- self.addCleanup(patcher.stop)
- return {winrepo: {}}
- def test_genrepo(self):
- '''
- Test to refresh the winrepo.p file of the repository
- '''
- expected = {'name': 'salt',
- 'changes': {},
- 'result': False,
- 'comment': ''}
- mock_config = MagicMock(return_value={'winrepo_dir': 'salt',
- 'winrepo_cachefile': 'abc'})
- mock_stat = MagicMock(return_value=[0, 1, 2, 3, 4, 5, 6, 7, 8])
- mock_empty_list = MagicMock(return_value=[])
- with patch.object(salt.config, 'master_config', mock_config), \
- patch.object(os, 'stat', mock_stat), \
- patch.object(salt.utils.path, 'os_walk', mock_empty_list), \
- patch.dict(winrepo.__opts__, {'test': True}):
- # With test=True
- expected.update({'comment': '', 'result': None})
- self.assertDictEqual(winrepo.genrepo('salt'), expected)
- with patch.dict(winrepo.__opts__, {'test': False}):
- # With test=False
- expected.update({'result': True})
- self.assertDictEqual(winrepo.genrepo('salt'), expected)
- # Now with no changes, existing winrepo.p
- expected.update({'changes': {'winrepo': []}})
- self.assertDictEqual(winrepo.genrepo('salt', True), expected)
- def test_genrepo_no_dir(self):
- '''
- Test genrepo when the dir does not exist
- '''
- expected = {'name': 'salt',
- 'changes': {},
- 'result': False,
- 'comment': '{0} is missing'.format(
- os.sep.join([BASE_FILE_ROOTS_DIR, 'win', 'repo']))}
- with patch.dict(winrepo.__opts__, {'test': False}), \
- patch('os.path.exists', MagicMock(return_value=False)):
- ret = winrepo.genrepo('salt')
- self.assertDictEqual(ret, expected)
- def test_genrepo_no_dir_force(self):
- '''
- Test genrepo when the dir does not exist and force=True
- '''
- expected = {'name': 'salt',
- 'changes': {'winrepo': []},
- 'result': True,
- 'comment': ''}
- with patch.dict(winrepo.__opts__, {'test': False}), \
- patch('os.path.exists', MagicMock(return_value=False)):
- ret = winrepo.genrepo('salt', force=True)
- self.assertDictEqual(ret, expected)
|