-
Notifications
You must be signed in to change notification settings - Fork 285
/
conftest.py
72 lines (55 loc) · 2.63 KB
/
conftest.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
# content of conftest.py
import os
from unittest import mock
import pytest
def pytest_addoption(parser):
parser.addoption(
"--runslow", action="store_true", default=False, help="run slow tests"
)
def pytest_configure(config):
"""Pytest configuration hook, for docs see:
https://docs.pytest.org/en/7.1.x/reference/reference.html#pytest.hookspec.pytest_configure
This hook runs before any tests are collected or run.
"""
config.addinivalue_line("markers", "slow: mark test as slow to run")
# This avoids running a version check when importing anything from lightly.
# See lightly/__init__.py. Note that we cannot mock the version check
# in __init__.py because it already runs when pytest collects the tests. This
# happens before any fixtures are applied and therefore the mocking is not yet in
# place.
os.environ["LIGHTLY_DID_VERSION_CHECK"] = "True"
# This avoids sending requests to the API.
os.environ["LIGHTLY_SERVER_LOCATION"] = "https://dummy-url"
def pytest_collection_modifyitems(config, items):
if config.getoption("--runslow"):
# --runslow given in cli: do not skip slow tests
return
skip_slow = pytest.mark.skip(reason="need --runslow option to run")
for item in items:
if "slow" in item.keywords:
item.add_marker(skip_slow)
@pytest.fixture(scope="module", autouse=True)
def mock_versioning_api():
"""Fixture that is applied to all tests and mocks the versioning API.
This is necessary because everytime an ApiWorkflowClient instance is created, a call
to the versioning API is made. This fixture makes sure that these calls succeed
while not actually sending any requests to the API.
It mocks:
- VersioningApi.get_latest_pip_version to always return the current version. This
avoids any errors/warnings related to not using the latest version.
- VersioningApi.get_minimum_compatible_pip_version to always return 1.0.0 which
should be compatible with all future versions.
"""
def mock_get_latest_pip_version(current_version: str, **kwargs) -> str:
return current_version
# NOTE(guarin, 2/6/23): Cannot use pytest mocker fixture here because it has not
# a "module" scope and it is not possible to use a fixture that has a tighter scope
# inside a fixture with a wider scope.
with mock.patch(
"lightly.api._version_checking.VersioningApi.get_latest_pip_version",
new=mock_get_latest_pip_version,
), mock.patch(
"lightly.api._version_checking.VersioningApi.get_minimum_compatible_pip_version",
return_value="1.0.0",
):
yield