self = <swh.loader.git.tests.test_loader.TestGitLoader2 object at 0x7f94472270b8>
mocker = <pytest_mock.plugin.MockerFixture object at 0x7f94426728d0>
def test_load_incremental(self, mocker):
statsd_report = mocker.patch("swh.core.statsd.statsd._report")
snapshot_id = b"\x01" * 20
now = datetime.datetime.now(tz=datetime.timezone.utc)
def ovgl(origin_url, allowed_statuses, require_snapshot, type):
if origin_url == f"base://{self.repo_url}":
return OriginVisit(origin=origin_url, visit=42, date=now, type="git")
else:
return None
self.loader.storage.origin_visit_get_latest.side_effect = ovgl
self.loader.storage.origin_visit_status_get_latest.return_value = (
OriginVisitStatus(
origin=f"base://{self.repo_url}",
visit=42,
snapshot=snapshot_id,
date=now,
status="full",
)
)
self.loader.storage.snapshot_get_branches.return_value = {
"id": snapshot_id,
"branches": {
b"refs/heads/master": SNAPSHOT1.branches[b"refs/heads/master"]
},
"next_branch": None,
}
res = self.loader.load()
assert res == {"status": "eventful"}
self.fetcher_cls.assert_called_once_with(
credentials={},
lister_name="fake-lister",
lister_instance_name="",
origin=Origin(url=self.repo_url),
)
self.fetcher.get_parent_origins.assert_called_once_with()
# First tries the same origin
assert self.loader.storage.origin_visit_get_latest.mock_calls == [
call(
self.repo_url,
allowed_statuses=None,
require_snapshot=True,
type=None,
),
# As it does not already have a snapshot, fall back to the parent origin
call(
f"base://{self.repo_url}",
allowed_statuses=None,
require_snapshot=True,
type=None,
),
]
p = "swh.loader.git"
assert [c for c in statsd_report.mock_calls if c[1][0].startswith(p)] == [
call(f"{p}.loader.incremental.from_parent_origin", "c", 1, None, 1),
call(
f"{p}.loader.ratio_ignored_refs",
"h",
0.0,
{"incremental": "from_parent_origin"},
1,
),
call(
f"{p}.loader.ratio_known_refs",
"h",
0.25,
{"incremental": "from_parent_origin"},
1,
),
]
self.fetcher.reset_mock()
self.fetcher_cls.reset_mock()
if sys.version_info >= (3, 9, 0):
self.loader.storage.reset_mock(return_value=True, side_effect=True)
else:
# Reimplement https://github.com/python/cpython/commit/aef7dc89879d099dc704bd8037b8a7686fb72838 # noqa
# for old Python versions:
def reset_mock(m):
m.reset_mock(return_value=True, side_effect=True)
for child in m._mock_children.values():
reset_mock(child)
reset_mock(self.loader.storage)
statsd_report.reset_mock()
# Load again
res = self.loader.load()
assert res == {"status": "uneventful"}
self.fetcher_cls.assert_called_once_with(
credentials={},
lister_name="fake-lister",
lister_instance_name="",
origin=Origin(url=self.repo_url),
)
self.fetcher.get_parent_origins.assert_not_called()
assert self.loader.storage.origin_visit_get_latest.mock_calls == [
# Tries the same origin, and finds a snapshot
call(
self.repo_url,
type=None,
allowed_statuses=None,
require_snapshot=True,
),
# -> does not need to fall back to the parent
]
p = "swh.loader.git"
> assert [c for c in statsd_report.mock_calls if c.args[0].startswith(p)] == [
call(f"{p}.loader.incremental.from_same_origin", "c", 1, None, 1),
call(
f"{p}.loader.ratio_ignored_refs",
"h",
0.0,
{"incremental": "from_same_origin"},
1,
),
call(
f"{p}.loader.ratio_known_refs",
"h",
1.0,
{"incremental": "from_same_origin"},
1,
),
]
E AssertionError: assert [] == [call('swh.lo..._origin'}, 1)]
E Right contains 3 more items, first extra item: call('swh.loader.git.loader.incremental.from_same_origin', 'c', 1, None, 1)
E Full diff:
E [
E + ,
E - call('swh.loader.git.loader.incremental.from_same_origin', 'c', 1, None, 1),
E - call('swh.loader.git.loader.ratio_ignored_refs', 'h', 0.0, {'incremental': 'from_same_origin'}, 1),
E - call('swh.loader.git.loader.ratio_known_refs', 'h', 1.0, {'incremental': 'from_same_origin'}, 1),...
E
E ...Full output truncated (2 lines hidden), use '-vv' to show
.tox/py3/lib/python3.7/site-packages/swh/loader/git/tests/test_loader.py:321: AssertionError
TEST RESULT
TEST RESULT
- Run At
- May 4 2022, 1:18 PM