From b6232701d6b93415b0cb1bd49e6380cb25104e07 Mon Sep 17 00:00:00 2001 From: Antti Kaihola <13725+akaihola@users.noreply.github.com> Date: Wed, 21 Oct 2020 21:12:07 +0300 Subject: [PATCH] Add features to Git repository test fixture - get commit hash at HEAD - create a branch - refactor shell command invocation helpers --- src/darker/tests/conftest.py | 33 ++++++++++++++++++++++++++++----- 1 file changed, 28 insertions(+), 5 deletions(-) diff --git a/src/darker/tests/conftest.py b/src/darker/tests/conftest.py index 67f5bef6d..d06dfe769 100644 --- a/src/darker/tests/conftest.py +++ b/src/darker/tests/conftest.py @@ -1,5 +1,8 @@ +"""Configuration and fixtures for the Pytest based test suite""" + import sys import types +from pathlib import Path from subprocess import check_call from typing import Dict, Optional from unittest.mock import patch @@ -8,6 +11,8 @@ from black import find_project_root from py.path import local as LocalPath +from darker.git import _git_check_output_lines + @pytest.fixture def without_isort(): @@ -25,6 +30,16 @@ class GitRepoFixture: def __init__(self, root: LocalPath): self.root = root + @classmethod + def create_repository(cls, root: LocalPath) -> "GitRepoFixture": + """Fixture method for creating a Git repository in the given directory""" + check_call(["git", "init"], cwd=root) + return cls(root) + + def _run(self, *args: str) -> None: + """Helper method to run a Git command line in the repository root""" + check_call(["git"] + list(args), cwd=self.root) + def add( self, paths_and_contents: Dict[str, Optional[str]], commit: str = None ) -> Dict[str, LocalPath]: @@ -44,21 +59,29 @@ def add( for relative_path, content in paths_and_contents.items(): path = absolute_paths[relative_path] if content is None: - check_call(["git", "rm", "--", relative_path], cwd=self.root) + self._run("rm", "--", relative_path) else: path.write(content, ensure=True) - check_call(["git", "add", "--", relative_path], cwd=self.root) + self._run("add", "--", relative_path) if commit: - check_call(["git", "commit", "-m", commit], cwd=self.root) + self._run("commit", "-m", commit) return absolute_paths + def get_hash(self) -> str: + """Return the commit hash at HEAD in the Git repository""" + return _git_check_output_lines(["git", "rev-parse", "HEAD"], Path(self.root))[0] + + def create_branch(self, new_branch: str, start_point: str) -> None: + """Fixture method to create and check out new branch at given starting point""" + self._run("checkout", "-b", new_branch, start_point) + @pytest.fixture def git_repo(tmpdir, monkeypatch): """Create a temporary Git repository and change current working directory into it""" - check_call(["git", "init"], cwd=tmpdir) + repository = GitRepoFixture.create_repository(tmpdir) monkeypatch.chdir(tmpdir) - return GitRepoFixture(tmpdir) + return repository @pytest.fixture