123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293 |
- # -*- coding: utf-8 -*-
- """
- unit tests for the git_pillar runner
- """
- # Import Python Libs
- from __future__ import absolute_import, print_function, unicode_literals
- import copy
- import errno
- import logging
- import tempfile
- # Import Salt Libs
- import salt.runners.git_pillar as git_pillar
- import salt.utils.files
- import salt.utils.gitfs
- # Import Salt Testing Libs
- from tests.support.gitfs import _OPTS
- from tests.support.mixins import LoaderModuleMockMixin
- from tests.support.mock import patch
- from tests.support.runtests import RUNTIME_VARS
- from tests.support.unit import TestCase
- log = logging.getLogger(__name__)
- class GitPillarTest(TestCase, LoaderModuleMockMixin):
- """
- Validate the git_pillar runner
- """
- @classmethod
- def setUpClass(cls):
- cls.tmp_cachedir = tempfile.mkdtemp(dir=RUNTIME_VARS.TMP)
- @classmethod
- def tearDownClass(cls):
- try:
- salt.utils.files.rm_rf(cls.tmp_cachedir)
- except OSError as exc:
- if exc.errno == errno.EACCES:
- log.error("Access error removing file %s", cls.tmp_cachedir)
- elif exc.errno != errno.EEXIST:
- raise
- def setup_loader_modules(self):
- opts = copy.copy(_OPTS)
- opts["cachedir"] = self.tmp_cachedir
- opts["verified_git_pillar_provider"] = "gitfoo"
- opts["ext_pillar"] = [
- {
- "git": [
- "master https://someurl/some",
- {"dev https://otherurl/other": [{"name": "somename"}]},
- ]
- }
- ]
- return {git_pillar: {"__opts__": opts}}
- def test_update(self):
- """
- test git_pillar.update
- """
- class MockGitProvider(
- salt.utils.gitfs.GitProvider
- ): # pylint: disable=abstract-method
- def init_remote(self):
- new = False
- self.repo = True
- return new
- def fetch(self):
- return True
- def clear_lock(self, lock_type="update"):
- pass # return success, failed
- git_providers = {"gitfoo": MockGitProvider}
- repo1 = {"master https://someurl/some": True}
- repo2 = {"dev https://otherurl/other": True}
- all_repos = {
- "master https://someurl/some": True,
- "dev https://otherurl/other": True,
- }
- with patch.object(salt.utils.gitfs, "GIT_PROVIDERS", git_providers):
- self.assertEqual(git_pillar.update(), all_repos)
- self.assertEqual(git_pillar.update(branch="master"), repo1)
- self.assertEqual(git_pillar.update(branch="dev"), repo2)
- self.assertEqual(git_pillar.update(repo="somename"), repo2)
|