gecko-dev/python/mozversioncontrol/test/conftest.py
Andrew Halberstadt 812d9fb038 Bug 1413922 - [mozversioncontrol] Always use hglib.client if available and fall back to subprocesses if not, r=gps
Most HG commands use subprocesses, even if a context manager (and therefore an
hglib client) has been created. There are only two commands that make use of
the client, but they *only* work inside a context manager. I don't think
there are any technical reason these two commands *need* to use the context
manager.

This patch merges the HgRepository._run_in_client function with
HgRepository._run(). If a client exists, that will be used, otherwise a
subprocess will be used.

Differential Revision: https://phabricator.services.mozilla.com/D1809

--HG--
extra : moz-landing-system : lando
2018-07-10 20:41:49 +00:00

75 lines
1.6 KiB
Python

# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
from __future__ import absolute_import
import os
import subprocess
import pytest
SETUP = {
'hg': [
"""
echo "foo" > foo
echo "bar" > bar
hg init
hg add *
hg commit -m "Initial commit"
""",
"""
echo "[paths]\ndefault = ../remoterepo" > .hg/hgrc
""",
],
'git': [
"""
echo "foo" > foo
echo "bar" > bar
git init
git add *
git commit -am "Initial commit"
""",
"""
git remote add upstream ../remoterepo
git fetch upstream
git branch -u upstream/master
""",
]
}
def shell(cmd):
subprocess.check_call(cmd, shell=True)
@pytest.yield_fixture(params=['git', 'hg'])
def repo(tmpdir, request):
vcs = request.param
steps = SETUP[vcs]
if hasattr(request.module, 'STEPS'):
steps.extend(request.module.STEPS[vcs])
# tmpdir and repo are py.path objects
# http://py.readthedocs.io/en/latest/path.html
repo = tmpdir.mkdir('repo')
repo.vcs = vcs
# This creates a step iterator. Each time next() is called
# on it, the next set of instructions will be executed.
repo.step = (shell(cmd) for cmd in steps)
oldcwd = os.getcwd()
os.chdir(repo.strpath)
next(repo.step)
repo.copy(tmpdir.join('remoterepo'))
next(repo.step)
yield repo
os.chdir(oldcwd)