-
Notifications
You must be signed in to change notification settings - Fork 28
/
Copy pathconftest.py
76 lines (65 loc) · 2.81 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
73
74
75
76
from pathlib import Path
import fakeredis
import pytest
import vcr
from django.conf import settings
from shared.reports.resources import Report, ReportFile, ReportLine
from shared.utils.sessions import Session
# we need to enable this in the test environment since we're often creating
# timeseries data and then asserting something about the aggregates all in
# a single transaction. calling `refresh_continuous_aggregate` doesn't work
# either since it cannot be called in a transaction.
settings.TIMESERIES_REAL_TIME_AGGREGATES = True
def pytest_configure(config):
"""
pytest_configure is the canonical way to configure test server for entire testing suite
"""
pass
@pytest.fixture
def codecov_vcr(request):
current_path = Path(request.node.fspath)
current_path_name = current_path.name.replace(".py", "")
cassette_path = current_path.parent / "cassetes" / current_path_name
if request.node.cls:
cls_name = request.node.cls.__name__
cassette_path = cassette_path / cls_name
current_name = request.node.name
cassette_file_path = str(cassette_path / f"{current_name}.yaml")
with vcr.use_cassette(
cassette_file_path,
filter_headers=["authorization"],
match_on=["method", "scheme", "host", "port", "path"],
) as cassette_maker:
yield cassette_maker
@pytest.fixture
def mock_redis(mocker):
m = mocker.patch("services.redis_configuration._get_redis_instance_from_url")
redis_server = fakeredis.FakeStrictRedis()
m.return_value = redis_server
yield redis_server
@pytest.fixture(scope="class")
def sample_report(request):
report = Report()
first_file = ReportFile("foo/file1.py")
first_file.append(
1, ReportLine.create(coverage=1, sessions=[[0, 1]], complexity=(10, 2))
)
first_file.append(2, ReportLine.create(coverage=0, sessions=[[0, 1]]))
first_file.append(3, ReportLine.create(coverage=1, sessions=[[0, 1]]))
first_file.append(5, ReportLine.create(coverage=1, sessions=[[0, 1]]))
first_file.append(6, ReportLine.create(coverage=0, sessions=[[0, 1]]))
first_file.append(8, ReportLine.create(coverage=1, sessions=[[0, 1]]))
first_file.append(9, ReportLine.create(coverage=1, sessions=[[0, 1]]))
first_file.append(10, ReportLine.create(coverage=0, sessions=[[0, 1]]))
second_file = ReportFile("bar/file2.py")
second_file.append(12, ReportLine.create(coverage=1, sessions=[[0, 1]]))
second_file.append(
51, ReportLine.create(coverage="1/2", type="b", sessions=[[0, 1]])
)
third_file = ReportFile("file3.py")
third_file.append(1, ReportLine.create(coverage=1, sessions=[[0, 1]]))
report.append(first_file)
report.append(second_file)
report.append(third_file)
report.add_session(Session(flags=["flag1", "flag2"]))
request.cls.sample_report = report