From ed7ceb5595986da560429ac38d6120664ffde7d2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Miro=20Hron=C4=8Dok?= Date: Sat, 21 Nov 2020 12:15:52 +0100 Subject: [PATCH] conftest.py: Make coverage optional (#2008) This allows to execute the tests without coverage installed. We plan to do that in Fedora, where we run the tests, but not measure coverage. --- tests/conftest.py | 48 ++++++++++++++++++++++++----------------------- 1 file changed, 25 insertions(+), 23 deletions(-) diff --git a/tests/conftest.py b/tests/conftest.py index 3fa0bba80..5fab330d8 100644 --- a/tests/conftest.py +++ b/tests/conftest.py @@ -8,7 +8,6 @@ from contextlib import contextmanager from functools import partial -import coverage import pytest import six @@ -236,28 +235,31 @@ def no_coverage(): pass -class EnableCoverage(object): - _COV_FILE = Path(coverage.__file__) - _ROOT_COV_FILES_AND_FOLDERS = [i for i in _COV_FILE.parents[1].iterdir() if i.name.startswith("coverage")] - - def __init__(self, link): - self.link = link - self.targets = [] - - def __enter__(self, creator): - site_packages = creator.purelib - for entry in self._ROOT_COV_FILES_AND_FOLDERS: - target = site_packages / entry.name - if not target.exists(): - clean = self.link(entry, target) - self.targets.append((target, clean)) - return self - - def __exit__(self, exc_type, exc_val, exc_tb): - for target, clean in self.targets: - if target.exists(): - clean() - assert self._COV_FILE.exists() +if COVERAGE_RUN: + import coverage + + class EnableCoverage(object): + _COV_FILE = Path(coverage.__file__) + _ROOT_COV_FILES_AND_FOLDERS = [i for i in _COV_FILE.parents[1].iterdir() if i.name.startswith("coverage")] + + def __init__(self, link): + self.link = link + self.targets = [] + + def __enter__(self, creator): + site_packages = creator.purelib + for entry in self._ROOT_COV_FILES_AND_FOLDERS: + target = site_packages / entry.name + if not target.exists(): + clean = self.link(entry, target) + self.targets.append((target, clean)) + return self + + def __exit__(self, exc_type, exc_val, exc_tb): + for target, clean in self.targets: + if target.exists(): + clean() + assert self._COV_FILE.exists() @pytest.fixture(scope="session")