mirror of
https://gerrit.googlesource.com/git-repo
synced 2025-01-20 16:14:25 +00:00
74737da1ab
Now that we don't need to support Python 2, we can switch to this API for better contextmanager logic. Change-Id: I2d03e391121886547e7808a3b5c3b470c411533f Reviewed-on: https://gerrit-review.googlesource.com/c/git-repo/+/337515 Reviewed-by: LaMont Jones <lamontjones@google.com> Tested-by: Mike Frysinger <vapier@google.com>
558 lines
20 KiB
Python
558 lines
20 KiB
Python
# Copyright (C) 2015 The Android Open Source Project
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
"""Unittests for the wrapper.py module."""
|
|
|
|
from io import StringIO
|
|
import os
|
|
import re
|
|
import sys
|
|
import tempfile
|
|
import unittest
|
|
from unittest import mock
|
|
|
|
import git_command
|
|
import main
|
|
import wrapper
|
|
|
|
|
|
def fixture(*paths):
|
|
"""Return a path relative to tests/fixtures.
|
|
"""
|
|
return os.path.join(os.path.dirname(__file__), 'fixtures', *paths)
|
|
|
|
|
|
class RepoWrapperTestCase(unittest.TestCase):
|
|
"""TestCase for the wrapper module."""
|
|
|
|
def setUp(self):
|
|
"""Load the wrapper module every time."""
|
|
wrapper._wrapper_module = None
|
|
self.wrapper = wrapper.Wrapper()
|
|
|
|
|
|
class RepoWrapperUnitTest(RepoWrapperTestCase):
|
|
"""Tests helper functions in the repo wrapper
|
|
"""
|
|
|
|
def test_version(self):
|
|
"""Make sure _Version works."""
|
|
with self.assertRaises(SystemExit) as e:
|
|
with mock.patch('sys.stdout', new_callable=StringIO) as stdout:
|
|
with mock.patch('sys.stderr', new_callable=StringIO) as stderr:
|
|
self.wrapper._Version()
|
|
self.assertEqual(0, e.exception.code)
|
|
self.assertEqual('', stderr.getvalue())
|
|
self.assertIn('repo launcher version', stdout.getvalue())
|
|
|
|
def test_python_constraints(self):
|
|
"""The launcher should never require newer than main.py."""
|
|
self.assertGreaterEqual(main.MIN_PYTHON_VERSION_HARD,
|
|
wrapper.MIN_PYTHON_VERSION_HARD)
|
|
self.assertGreaterEqual(main.MIN_PYTHON_VERSION_SOFT,
|
|
wrapper.MIN_PYTHON_VERSION_SOFT)
|
|
# Make sure the versions are themselves in sync.
|
|
self.assertGreaterEqual(wrapper.MIN_PYTHON_VERSION_SOFT,
|
|
wrapper.MIN_PYTHON_VERSION_HARD)
|
|
|
|
def test_init_parser(self):
|
|
"""Make sure 'init' GetParser works."""
|
|
parser = self.wrapper.GetParser(gitc_init=False)
|
|
opts, args = parser.parse_args([])
|
|
self.assertEqual([], args)
|
|
self.assertIsNone(opts.manifest_url)
|
|
|
|
def test_gitc_init_parser(self):
|
|
"""Make sure 'gitc-init' GetParser works."""
|
|
parser = self.wrapper.GetParser(gitc_init=True)
|
|
opts, args = parser.parse_args([])
|
|
self.assertEqual([], args)
|
|
self.assertIsNone(opts.manifest_file)
|
|
|
|
def test_get_gitc_manifest_dir_no_gitc(self):
|
|
"""
|
|
Test reading a missing gitc config file
|
|
"""
|
|
self.wrapper.GITC_CONFIG_FILE = fixture('missing_gitc_config')
|
|
val = self.wrapper.get_gitc_manifest_dir()
|
|
self.assertEqual(val, '')
|
|
|
|
def test_get_gitc_manifest_dir(self):
|
|
"""
|
|
Test reading the gitc config file and parsing the directory
|
|
"""
|
|
self.wrapper.GITC_CONFIG_FILE = fixture('gitc_config')
|
|
val = self.wrapper.get_gitc_manifest_dir()
|
|
self.assertEqual(val, '/test/usr/local/google/gitc')
|
|
|
|
def test_gitc_parse_clientdir_no_gitc(self):
|
|
"""
|
|
Test parsing the gitc clientdir without gitc running
|
|
"""
|
|
self.wrapper.GITC_CONFIG_FILE = fixture('missing_gitc_config')
|
|
self.assertEqual(self.wrapper.gitc_parse_clientdir('/something'), None)
|
|
self.assertEqual(self.wrapper.gitc_parse_clientdir('/gitc/manifest-rw/test'), 'test')
|
|
|
|
def test_gitc_parse_clientdir(self):
|
|
"""
|
|
Test parsing the gitc clientdir
|
|
"""
|
|
self.wrapper.GITC_CONFIG_FILE = fixture('gitc_config')
|
|
self.assertEqual(self.wrapper.gitc_parse_clientdir('/something'), None)
|
|
self.assertEqual(self.wrapper.gitc_parse_clientdir('/gitc/manifest-rw/test'), 'test')
|
|
self.assertEqual(self.wrapper.gitc_parse_clientdir('/gitc/manifest-rw/test/'), 'test')
|
|
self.assertEqual(self.wrapper.gitc_parse_clientdir('/gitc/manifest-rw/test/extra'), 'test')
|
|
self.assertEqual(self.wrapper.gitc_parse_clientdir('/test/usr/local/google/gitc/test'), 'test')
|
|
self.assertEqual(self.wrapper.gitc_parse_clientdir('/test/usr/local/google/gitc/test/'), 'test')
|
|
self.assertEqual(self.wrapper.gitc_parse_clientdir('/test/usr/local/google/gitc/test/extra'),
|
|
'test')
|
|
self.assertEqual(self.wrapper.gitc_parse_clientdir('/gitc/manifest-rw/'), None)
|
|
self.assertEqual(self.wrapper.gitc_parse_clientdir('/test/usr/local/google/gitc/'), None)
|
|
|
|
|
|
class SetGitTrace2ParentSid(RepoWrapperTestCase):
|
|
"""Check SetGitTrace2ParentSid behavior."""
|
|
|
|
KEY = 'GIT_TRACE2_PARENT_SID'
|
|
VALID_FORMAT = re.compile(r'^repo-[0-9]{8}T[0-9]{6}Z-P[0-9a-f]{8}$')
|
|
|
|
def test_first_set(self):
|
|
"""Test env var not yet set."""
|
|
env = {}
|
|
self.wrapper.SetGitTrace2ParentSid(env)
|
|
self.assertIn(self.KEY, env)
|
|
value = env[self.KEY]
|
|
self.assertRegex(value, self.VALID_FORMAT)
|
|
|
|
def test_append(self):
|
|
"""Test env var is appended."""
|
|
env = {self.KEY: 'pfx'}
|
|
self.wrapper.SetGitTrace2ParentSid(env)
|
|
self.assertIn(self.KEY, env)
|
|
value = env[self.KEY]
|
|
self.assertTrue(value.startswith('pfx/'))
|
|
self.assertRegex(value[4:], self.VALID_FORMAT)
|
|
|
|
def test_global_context(self):
|
|
"""Check os.environ gets updated by default."""
|
|
os.environ.pop(self.KEY, None)
|
|
self.wrapper.SetGitTrace2ParentSid()
|
|
self.assertIn(self.KEY, os.environ)
|
|
value = os.environ[self.KEY]
|
|
self.assertRegex(value, self.VALID_FORMAT)
|
|
|
|
|
|
class RunCommand(RepoWrapperTestCase):
|
|
"""Check run_command behavior."""
|
|
|
|
def test_capture(self):
|
|
"""Check capture_output handling."""
|
|
ret = self.wrapper.run_command(['echo', 'hi'], capture_output=True)
|
|
self.assertEqual(ret.stdout, 'hi\n')
|
|
|
|
def test_check(self):
|
|
"""Check check handling."""
|
|
self.wrapper.run_command(['true'], check=False)
|
|
self.wrapper.run_command(['true'], check=True)
|
|
self.wrapper.run_command(['false'], check=False)
|
|
with self.assertRaises(self.wrapper.RunError):
|
|
self.wrapper.run_command(['false'], check=True)
|
|
|
|
|
|
class RunGit(RepoWrapperTestCase):
|
|
"""Check run_git behavior."""
|
|
|
|
def test_capture(self):
|
|
"""Check capture_output handling."""
|
|
ret = self.wrapper.run_git('--version')
|
|
self.assertIn('git', ret.stdout)
|
|
|
|
def test_check(self):
|
|
"""Check check handling."""
|
|
with self.assertRaises(self.wrapper.CloneFailure):
|
|
self.wrapper.run_git('--version-asdfasdf')
|
|
self.wrapper.run_git('--version-asdfasdf', check=False)
|
|
|
|
|
|
class ParseGitVersion(RepoWrapperTestCase):
|
|
"""Check ParseGitVersion behavior."""
|
|
|
|
def test_autoload(self):
|
|
"""Check we can load the version from the live git."""
|
|
ret = self.wrapper.ParseGitVersion()
|
|
self.assertIsNotNone(ret)
|
|
|
|
def test_bad_ver(self):
|
|
"""Check handling of bad git versions."""
|
|
ret = self.wrapper.ParseGitVersion(ver_str='asdf')
|
|
self.assertIsNone(ret)
|
|
|
|
def test_normal_ver(self):
|
|
"""Check handling of normal git versions."""
|
|
ret = self.wrapper.ParseGitVersion(ver_str='git version 2.25.1')
|
|
self.assertEqual(2, ret.major)
|
|
self.assertEqual(25, ret.minor)
|
|
self.assertEqual(1, ret.micro)
|
|
self.assertEqual('2.25.1', ret.full)
|
|
|
|
def test_extended_ver(self):
|
|
"""Check handling of extended distro git versions."""
|
|
ret = self.wrapper.ParseGitVersion(
|
|
ver_str='git version 1.30.50.696.g5e7596f4ac-goog')
|
|
self.assertEqual(1, ret.major)
|
|
self.assertEqual(30, ret.minor)
|
|
self.assertEqual(50, ret.micro)
|
|
self.assertEqual('1.30.50.696.g5e7596f4ac-goog', ret.full)
|
|
|
|
|
|
class CheckGitVersion(RepoWrapperTestCase):
|
|
"""Check _CheckGitVersion behavior."""
|
|
|
|
def test_unknown(self):
|
|
"""Unknown versions should abort."""
|
|
with mock.patch.object(self.wrapper, 'ParseGitVersion', return_value=None):
|
|
with self.assertRaises(self.wrapper.CloneFailure):
|
|
self.wrapper._CheckGitVersion()
|
|
|
|
def test_old(self):
|
|
"""Old versions should abort."""
|
|
with mock.patch.object(
|
|
self.wrapper, 'ParseGitVersion',
|
|
return_value=self.wrapper.GitVersion(1, 0, 0, '1.0.0')):
|
|
with self.assertRaises(self.wrapper.CloneFailure):
|
|
self.wrapper._CheckGitVersion()
|
|
|
|
def test_new(self):
|
|
"""Newer versions should run fine."""
|
|
with mock.patch.object(
|
|
self.wrapper, 'ParseGitVersion',
|
|
return_value=self.wrapper.GitVersion(100, 0, 0, '100.0.0')):
|
|
self.wrapper._CheckGitVersion()
|
|
|
|
|
|
class Requirements(RepoWrapperTestCase):
|
|
"""Check Requirements handling."""
|
|
|
|
def test_missing_file(self):
|
|
"""Don't crash if the file is missing (old version)."""
|
|
testdir = os.path.dirname(os.path.realpath(__file__))
|
|
self.assertIsNone(self.wrapper.Requirements.from_dir(testdir))
|
|
self.assertIsNone(self.wrapper.Requirements.from_file(
|
|
os.path.join(testdir, 'xxxxxxxxxxxxxxxxxxxxxxxx')))
|
|
|
|
def test_corrupt_data(self):
|
|
"""If the file can't be parsed, don't blow up."""
|
|
self.assertIsNone(self.wrapper.Requirements.from_file(__file__))
|
|
self.assertIsNone(self.wrapper.Requirements.from_data(b'x'))
|
|
|
|
def test_valid_data(self):
|
|
"""Make sure we can parse the file we ship."""
|
|
self.assertIsNotNone(self.wrapper.Requirements.from_data(b'{}'))
|
|
rootdir = os.path.dirname(os.path.dirname(os.path.realpath(__file__)))
|
|
self.assertIsNotNone(self.wrapper.Requirements.from_dir(rootdir))
|
|
self.assertIsNotNone(self.wrapper.Requirements.from_file(os.path.join(
|
|
rootdir, 'requirements.json')))
|
|
|
|
def test_format_ver(self):
|
|
"""Check format_ver can format."""
|
|
self.assertEqual('1.2.3', self.wrapper.Requirements._format_ver((1, 2, 3)))
|
|
self.assertEqual('1', self.wrapper.Requirements._format_ver([1]))
|
|
|
|
def test_assert_all_unknown(self):
|
|
"""Check assert_all works with incompatible file."""
|
|
reqs = self.wrapper.Requirements({})
|
|
reqs.assert_all()
|
|
|
|
def test_assert_all_new_repo(self):
|
|
"""Check assert_all accepts new enough repo."""
|
|
reqs = self.wrapper.Requirements({'repo': {'hard': [1, 0]}})
|
|
reqs.assert_all()
|
|
|
|
def test_assert_all_old_repo(self):
|
|
"""Check assert_all rejects old repo."""
|
|
reqs = self.wrapper.Requirements({'repo': {'hard': [99999, 0]}})
|
|
with self.assertRaises(SystemExit):
|
|
reqs.assert_all()
|
|
|
|
def test_assert_all_new_python(self):
|
|
"""Check assert_all accepts new enough python."""
|
|
reqs = self.wrapper.Requirements({'python': {'hard': sys.version_info}})
|
|
reqs.assert_all()
|
|
|
|
def test_assert_all_old_python(self):
|
|
"""Check assert_all rejects old python."""
|
|
reqs = self.wrapper.Requirements({'python': {'hard': [99999, 0]}})
|
|
with self.assertRaises(SystemExit):
|
|
reqs.assert_all()
|
|
|
|
def test_assert_ver_unknown(self):
|
|
"""Check assert_ver works with incompatible file."""
|
|
reqs = self.wrapper.Requirements({})
|
|
reqs.assert_ver('xxx', (1, 0))
|
|
|
|
def test_assert_ver_new(self):
|
|
"""Check assert_ver allows new enough versions."""
|
|
reqs = self.wrapper.Requirements({'git': {'hard': [1, 0], 'soft': [2, 0]}})
|
|
reqs.assert_ver('git', (1, 0))
|
|
reqs.assert_ver('git', (1, 5))
|
|
reqs.assert_ver('git', (2, 0))
|
|
reqs.assert_ver('git', (2, 5))
|
|
|
|
def test_assert_ver_old(self):
|
|
"""Check assert_ver rejects old versions."""
|
|
reqs = self.wrapper.Requirements({'git': {'hard': [1, 0], 'soft': [2, 0]}})
|
|
with self.assertRaises(SystemExit):
|
|
reqs.assert_ver('git', (0, 5))
|
|
|
|
|
|
class NeedSetupGnuPG(RepoWrapperTestCase):
|
|
"""Check NeedSetupGnuPG behavior."""
|
|
|
|
def test_missing_dir(self):
|
|
"""The ~/.repoconfig tree doesn't exist yet."""
|
|
with tempfile.TemporaryDirectory(prefix='repo-tests') as tempdir:
|
|
self.wrapper.home_dot_repo = os.path.join(tempdir, 'foo')
|
|
self.assertTrue(self.wrapper.NeedSetupGnuPG())
|
|
|
|
def test_missing_keyring(self):
|
|
"""The keyring-version file doesn't exist yet."""
|
|
with tempfile.TemporaryDirectory(prefix='repo-tests') as tempdir:
|
|
self.wrapper.home_dot_repo = tempdir
|
|
self.assertTrue(self.wrapper.NeedSetupGnuPG())
|
|
|
|
def test_empty_keyring(self):
|
|
"""The keyring-version file exists, but is empty."""
|
|
with tempfile.TemporaryDirectory(prefix='repo-tests') as tempdir:
|
|
self.wrapper.home_dot_repo = tempdir
|
|
with open(os.path.join(tempdir, 'keyring-version'), 'w'):
|
|
pass
|
|
self.assertTrue(self.wrapper.NeedSetupGnuPG())
|
|
|
|
def test_old_keyring(self):
|
|
"""The keyring-version file exists, but it's old."""
|
|
with tempfile.TemporaryDirectory(prefix='repo-tests') as tempdir:
|
|
self.wrapper.home_dot_repo = tempdir
|
|
with open(os.path.join(tempdir, 'keyring-version'), 'w') as fp:
|
|
fp.write('1.0\n')
|
|
self.assertTrue(self.wrapper.NeedSetupGnuPG())
|
|
|
|
def test_new_keyring(self):
|
|
"""The keyring-version file exists, and is up-to-date."""
|
|
with tempfile.TemporaryDirectory(prefix='repo-tests') as tempdir:
|
|
self.wrapper.home_dot_repo = tempdir
|
|
with open(os.path.join(tempdir, 'keyring-version'), 'w') as fp:
|
|
fp.write('1000.0\n')
|
|
self.assertFalse(self.wrapper.NeedSetupGnuPG())
|
|
|
|
|
|
class SetupGnuPG(RepoWrapperTestCase):
|
|
"""Check SetupGnuPG behavior."""
|
|
|
|
def test_full(self):
|
|
"""Make sure it works completely."""
|
|
with tempfile.TemporaryDirectory(prefix='repo-tests') as tempdir:
|
|
self.wrapper.home_dot_repo = tempdir
|
|
self.wrapper.gpg_dir = os.path.join(self.wrapper.home_dot_repo, 'gnupg')
|
|
self.assertTrue(self.wrapper.SetupGnuPG(True))
|
|
with open(os.path.join(tempdir, 'keyring-version'), 'r') as fp:
|
|
data = fp.read()
|
|
self.assertEqual('.'.join(str(x) for x in self.wrapper.KEYRING_VERSION),
|
|
data.strip())
|
|
|
|
|
|
class VerifyRev(RepoWrapperTestCase):
|
|
"""Check verify_rev behavior."""
|
|
|
|
def test_verify_passes(self):
|
|
"""Check when we have a valid signed tag."""
|
|
desc_result = self.wrapper.RunResult(0, 'v1.0\n', '')
|
|
gpg_result = self.wrapper.RunResult(0, '', '')
|
|
with mock.patch.object(self.wrapper, 'run_git',
|
|
side_effect=(desc_result, gpg_result)):
|
|
ret = self.wrapper.verify_rev('/', 'refs/heads/stable', '1234', True)
|
|
self.assertEqual('v1.0^0', ret)
|
|
|
|
def test_unsigned_commit(self):
|
|
"""Check we fall back to signed tag when we have an unsigned commit."""
|
|
desc_result = self.wrapper.RunResult(0, 'v1.0-10-g1234\n', '')
|
|
gpg_result = self.wrapper.RunResult(0, '', '')
|
|
with mock.patch.object(self.wrapper, 'run_git',
|
|
side_effect=(desc_result, gpg_result)):
|
|
ret = self.wrapper.verify_rev('/', 'refs/heads/stable', '1234', True)
|
|
self.assertEqual('v1.0^0', ret)
|
|
|
|
def test_verify_fails(self):
|
|
"""Check we fall back to signed tag when we have an unsigned commit."""
|
|
desc_result = self.wrapper.RunResult(0, 'v1.0-10-g1234\n', '')
|
|
gpg_result = Exception
|
|
with mock.patch.object(self.wrapper, 'run_git',
|
|
side_effect=(desc_result, gpg_result)):
|
|
with self.assertRaises(Exception):
|
|
self.wrapper.verify_rev('/', 'refs/heads/stable', '1234', True)
|
|
|
|
|
|
class GitCheckoutTestCase(RepoWrapperTestCase):
|
|
"""Tests that use a real/small git checkout."""
|
|
|
|
GIT_DIR = None
|
|
REV_LIST = None
|
|
|
|
@classmethod
|
|
def setUpClass(cls):
|
|
# Create a repo to operate on, but do it once per-class.
|
|
cls.tempdirobj = tempfile.TemporaryDirectory(prefix='repo-rev-tests')
|
|
cls.GIT_DIR = cls.tempdirobj.name
|
|
run_git = wrapper.Wrapper().run_git
|
|
|
|
remote = os.path.join(cls.GIT_DIR, 'remote')
|
|
os.mkdir(remote)
|
|
|
|
# Tests need to assume, that main is default branch at init,
|
|
# which is not supported in config until 2.28.
|
|
if git_command.git_require((2, 28, 0)):
|
|
initstr = '--initial-branch=main'
|
|
else:
|
|
# Use template dir for init.
|
|
templatedir = tempfile.mkdtemp(prefix='.test-template')
|
|
with open(os.path.join(templatedir, 'HEAD'), 'w') as fp:
|
|
fp.write('ref: refs/heads/main\n')
|
|
initstr = '--template=' + templatedir
|
|
|
|
run_git('init', initstr, cwd=remote)
|
|
run_git('commit', '--allow-empty', '-minit', cwd=remote)
|
|
run_git('branch', 'stable', cwd=remote)
|
|
run_git('tag', 'v1.0', cwd=remote)
|
|
run_git('commit', '--allow-empty', '-m2nd commit', cwd=remote)
|
|
cls.REV_LIST = run_git('rev-list', 'HEAD', cwd=remote).stdout.splitlines()
|
|
|
|
run_git('init', cwd=cls.GIT_DIR)
|
|
run_git('fetch', remote, '+refs/heads/*:refs/remotes/origin/*', cwd=cls.GIT_DIR)
|
|
|
|
@classmethod
|
|
def tearDownClass(cls):
|
|
if not cls.tempdirobj:
|
|
return
|
|
|
|
cls.tempdirobj.cleanup()
|
|
|
|
|
|
class ResolveRepoRev(GitCheckoutTestCase):
|
|
"""Check resolve_repo_rev behavior."""
|
|
|
|
def test_explicit_branch(self):
|
|
"""Check refs/heads/branch argument."""
|
|
rrev, lrev = self.wrapper.resolve_repo_rev(self.GIT_DIR, 'refs/heads/stable')
|
|
self.assertEqual('refs/heads/stable', rrev)
|
|
self.assertEqual(self.REV_LIST[1], lrev)
|
|
|
|
with self.assertRaises(wrapper.CloneFailure):
|
|
self.wrapper.resolve_repo_rev(self.GIT_DIR, 'refs/heads/unknown')
|
|
|
|
def test_explicit_tag(self):
|
|
"""Check refs/tags/tag argument."""
|
|
rrev, lrev = self.wrapper.resolve_repo_rev(self.GIT_DIR, 'refs/tags/v1.0')
|
|
self.assertEqual('refs/tags/v1.0', rrev)
|
|
self.assertEqual(self.REV_LIST[1], lrev)
|
|
|
|
with self.assertRaises(wrapper.CloneFailure):
|
|
self.wrapper.resolve_repo_rev(self.GIT_DIR, 'refs/tags/unknown')
|
|
|
|
def test_branch_name(self):
|
|
"""Check branch argument."""
|
|
rrev, lrev = self.wrapper.resolve_repo_rev(self.GIT_DIR, 'stable')
|
|
self.assertEqual('refs/heads/stable', rrev)
|
|
self.assertEqual(self.REV_LIST[1], lrev)
|
|
|
|
rrev, lrev = self.wrapper.resolve_repo_rev(self.GIT_DIR, 'main')
|
|
self.assertEqual('refs/heads/main', rrev)
|
|
self.assertEqual(self.REV_LIST[0], lrev)
|
|
|
|
def test_tag_name(self):
|
|
"""Check tag argument."""
|
|
rrev, lrev = self.wrapper.resolve_repo_rev(self.GIT_DIR, 'v1.0')
|
|
self.assertEqual('refs/tags/v1.0', rrev)
|
|
self.assertEqual(self.REV_LIST[1], lrev)
|
|
|
|
def test_full_commit(self):
|
|
"""Check specific commit argument."""
|
|
commit = self.REV_LIST[0]
|
|
rrev, lrev = self.wrapper.resolve_repo_rev(self.GIT_DIR, commit)
|
|
self.assertEqual(commit, rrev)
|
|
self.assertEqual(commit, lrev)
|
|
|
|
def test_partial_commit(self):
|
|
"""Check specific (partial) commit argument."""
|
|
commit = self.REV_LIST[0][0:20]
|
|
rrev, lrev = self.wrapper.resolve_repo_rev(self.GIT_DIR, commit)
|
|
self.assertEqual(self.REV_LIST[0], rrev)
|
|
self.assertEqual(self.REV_LIST[0], lrev)
|
|
|
|
def test_unknown(self):
|
|
"""Check unknown ref/commit argument."""
|
|
with self.assertRaises(wrapper.CloneFailure):
|
|
self.wrapper.resolve_repo_rev(self.GIT_DIR, 'boooooooya')
|
|
|
|
|
|
class CheckRepoVerify(RepoWrapperTestCase):
|
|
"""Check check_repo_verify behavior."""
|
|
|
|
def test_no_verify(self):
|
|
"""Always fail with --no-repo-verify."""
|
|
self.assertFalse(self.wrapper.check_repo_verify(False))
|
|
|
|
def test_gpg_initialized(self):
|
|
"""Should pass if gpg is setup already."""
|
|
with mock.patch.object(self.wrapper, 'NeedSetupGnuPG', return_value=False):
|
|
self.assertTrue(self.wrapper.check_repo_verify(True))
|
|
|
|
def test_need_gpg_setup(self):
|
|
"""Should pass/fail based on gpg setup."""
|
|
with mock.patch.object(self.wrapper, 'NeedSetupGnuPG', return_value=True):
|
|
with mock.patch.object(self.wrapper, 'SetupGnuPG') as m:
|
|
m.return_value = True
|
|
self.assertTrue(self.wrapper.check_repo_verify(True))
|
|
|
|
m.return_value = False
|
|
self.assertFalse(self.wrapper.check_repo_verify(True))
|
|
|
|
|
|
class CheckRepoRev(GitCheckoutTestCase):
|
|
"""Check check_repo_rev behavior."""
|
|
|
|
def test_verify_works(self):
|
|
"""Should pass when verification passes."""
|
|
with mock.patch.object(self.wrapper, 'check_repo_verify', return_value=True):
|
|
with mock.patch.object(self.wrapper, 'verify_rev', return_value='12345'):
|
|
rrev, lrev = self.wrapper.check_repo_rev(self.GIT_DIR, 'stable')
|
|
self.assertEqual('refs/heads/stable', rrev)
|
|
self.assertEqual('12345', lrev)
|
|
|
|
def test_verify_fails(self):
|
|
"""Should fail when verification fails."""
|
|
with mock.patch.object(self.wrapper, 'check_repo_verify', return_value=True):
|
|
with mock.patch.object(self.wrapper, 'verify_rev', side_effect=Exception):
|
|
with self.assertRaises(Exception):
|
|
self.wrapper.check_repo_rev(self.GIT_DIR, 'stable')
|
|
|
|
def test_verify_ignore(self):
|
|
"""Should pass when verification is disabled."""
|
|
with mock.patch.object(self.wrapper, 'verify_rev', side_effect=Exception):
|
|
rrev, lrev = self.wrapper.check_repo_rev(self.GIT_DIR, 'stable', repo_verify=False)
|
|
self.assertEqual('refs/heads/stable', rrev)
|
|
self.assertEqual(self.REV_LIST[1], lrev)
|
|
|
|
|
|
if __name__ == '__main__':
|
|
unittest.main()
|