From 7f2a196c5c7f2a2b3d98c2346c7092009610e192 Mon Sep 17 00:00:00 2001 From: pawel Date: Mon, 6 Jan 2020 17:57:07 +0100 Subject: [PATCH 1/2] install: tests: migrate to dir helpers --- tests/func/test_install.py | 85 +++++++++++++++++--------------------- 1 file changed, 39 insertions(+), 46 deletions(-) diff --git a/tests/func/test_install.py b/tests/func/test_install.py index 0b10b3ee6b..ba7d2d7e91 100644 --- a/tests/func/test_install.py +++ b/tests/func/test_install.py @@ -1,12 +1,12 @@ import os +import pathlib import sys import pytest from dvc.exceptions import GitHookAlreadyExistsError -from dvc.main import main -from dvc.stage import Stage -from dvc.utils import file_md5 +from dvc.remote import RemoteConfig +from dvc.utils import file_md5, fspath @pytest.mark.skipif( @@ -14,10 +14,10 @@ ) class TestInstall(object): def _hook(self, name): - return os.path.join(".git", "hooks", name) + return pathlib.Path(".git") / "hooks" / name - def test_should_create_hooks(self, git, dvc_repo): - assert main(["install"]) == 0 + def test_should_create_hooks(self, scm, dvc): + scm.install() hooks_with_commands = [ ("post-checkout", "exec dvc checkout"), @@ -26,55 +26,48 @@ def test_should_create_hooks(self, git, dvc_repo): ] for fname, command in hooks_with_commands: - assert os.path.isfile(self._hook(fname)) + hook_path = self._hook(fname) + assert hook_path.is_file() + assert command in hook_path.read_text() - with open(self._hook(fname), "r") as fobj: - assert command in fobj.read() - - def test_should_fail_if_file_already_exists(self, git, dvc_repo): - with open(self._hook("post-checkout"), "w") as fobj: - fobj.write("hook content") + def test_should_fail_if_file_already_exists(self, scm): + self._hook("post-checkout").write_text("hook content") with pytest.raises(GitHookAlreadyExistsError): - dvc_repo.scm.install() - - def test_should_post_checkout_hook_checkout(self, repo_dir, git, dvc_repo): - assert main(["install"]) == 0 - - stage_file = repo_dir.FOO + Stage.STAGE_FILE_SUFFIX - - dvc_repo.add(repo_dir.FOO) - dvc_repo.scm.add([".gitignore", stage_file]) - dvc_repo.scm.commit("add") - - os.unlink(repo_dir.FOO) - dvc_repo.scm.checkout("new_branch", create_new=True) - - assert os.path.isfile(repo_dir.FOO) + scm.install() - def test_should_pre_push_hook_push(self, repo_dir, git, dvc_repo): - assert main(["install"]) == 0 + def test_should_post_checkout_hook_checkout(self, tmp_dir, scm, dvc): + scm.install() + tmp_dir.dvc_gen({"file": "file content"}, commit="add") - temp = repo_dir.mkdtemp() - git_remote = os.path.join(temp, "project.git") - storage_path = os.path.join(temp, "dvc_storage") + os.unlink("file") + scm.checkout("new_branch", create_new=True) - foo_checksum = file_md5(repo_dir.FOO)[0] - expected_cache_path = dvc_repo.cache.local.get(foo_checksum) + assert os.path.isfile("file") - ret = main(["remote", "add", "-d", "store", storage_path]) - assert ret == 0 + def test_should_pre_push_hook_push( + self, tmp_dir, scm, dvc, tmp_path_factory + ): + scm.install() - ret = main(["add", repo_dir.FOO]) - assert ret == 0 + temp = tmp_path_factory.mktemp("external") + git_remote = temp / "project.git" + storage_path = temp / "dvc_storage" - stage_file = repo_dir.FOO + Stage.STAGE_FILE_SUFFIX - dvc_repo.scm.repo.index.add([stage_file, ".gitignore"]) - dvc_repo.scm.repo.index.commit("commit message") + RemoteConfig(dvc.config).add( + "store", fspath(storage_path), default=True + ) + tmp_dir.dvc_gen("file", "file_content", "commit message") - dvc_repo.scm.repo.clone(git_remote) - dvc_repo.scm.repo.create_remote("origin", git_remote) + file_checksum = file_md5("file")[0] + expected_storage_path = ( + storage_path / file_checksum[:2] / file_checksum[2:] + ) - dvc_repo.scm.repo.git.push("origin", "master") + scm.repo.clone(fspath(git_remote)) + scm.repo.create_remote("origin", fspath(git_remote)) - assert os.path.isfile(expected_cache_path) + assert not expected_storage_path.is_file() + scm.repo.git.push("origin", "master") + assert expected_storage_path.is_file() + assert expected_storage_path.read_text() == "file_content" From 1d00560612d6ec8fbeb0415d2f5b0555009f16ab Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pawe=C5=82=20Redzy=C5=84ski?= Date: Tue, 7 Jan 2020 10:16:32 +0100 Subject: [PATCH 2/2] fixup --- tests/func/test_install.py | 10 ++++------ 1 file changed, 4 insertions(+), 6 deletions(-) diff --git a/tests/func/test_install.py b/tests/func/test_install.py index ba7d2d7e91..311b21905b 100644 --- a/tests/func/test_install.py +++ b/tests/func/test_install.py @@ -16,7 +16,7 @@ class TestInstall(object): def _hook(self, name): return pathlib.Path(".git") / "hooks" / name - def test_should_create_hooks(self, scm, dvc): + def test_create_hooks(self, scm, dvc): scm.install() hooks_with_commands = [ @@ -30,13 +30,13 @@ def test_should_create_hooks(self, scm, dvc): assert hook_path.is_file() assert command in hook_path.read_text() - def test_should_fail_if_file_already_exists(self, scm): + def test_fail_if_hook_exists(self, scm): self._hook("post-checkout").write_text("hook content") with pytest.raises(GitHookAlreadyExistsError): scm.install() - def test_should_post_checkout_hook_checkout(self, tmp_dir, scm, dvc): + def test_post_checkout(self, tmp_dir, scm, dvc): scm.install() tmp_dir.dvc_gen({"file": "file content"}, commit="add") @@ -45,9 +45,7 @@ def test_should_post_checkout_hook_checkout(self, tmp_dir, scm, dvc): assert os.path.isfile("file") - def test_should_pre_push_hook_push( - self, tmp_dir, scm, dvc, tmp_path_factory - ): + def test_pre_push_hook(self, tmp_dir, scm, dvc, tmp_path_factory): scm.install() temp = tmp_path_factory.mktemp("external")