Skip to content
This repository has been archived by the owner on Sep 1, 2024. It is now read-only.

Commit

Permalink
Add freezegun test
Browse files Browse the repository at this point in the history
A user reported an issue in which freezegun (specifically, the
`@freeze_time()` decorator) was impacting the test start and end
timestamps reported to Unflakable. It turns out that this issue was
fixed in freezegun 1.2.2. This change adds a new test case and checks
timestamp consistency for every test case.
  • Loading branch information
ramosbugs committed Mar 16, 2024
1 parent 71f5edc commit 7108cf2
Show file tree
Hide file tree
Showing 3 changed files with 86 additions and 0 deletions.
2 changes: 2 additions & 0 deletions setup.cfg
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,8 @@ install_requires =

[options.extras_require]
dev =
# freezegun 1.2.2 fixed pytest timing interference.
freezegun>=1.2.2
requests-mock[fixture]

[options.entry_points]
Expand Down
30 changes: 30 additions & 0 deletions tests/common.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,8 @@
import os
import re
import subprocess
import time
from datetime import datetime, timezone
from enum import Enum
from pathlib import Path
from typing import (TYPE_CHECKING, Callable, Dict, Iterable, List, Optional,
Expand Down Expand Up @@ -404,6 +406,8 @@ def run_test_case(
) + list(extra_args)
)

start_time = datetime.fromtimestamp(time.time(), timezone.utc).isoformat('T', 'microseconds')

__pytest_current_test = os.environ['PYTEST_CURRENT_TEST']
if monkeypatch is not None:
with monkeypatch.context() as mp:
Expand All @@ -414,6 +418,10 @@ def run_test_case(
else:
result = pytester.runpytest(*pytest_args)

end_time = datetime.fromtimestamp(time.time(), timezone.utc).isoformat('T', 'microseconds')

assert end_time >= start_time

# pytester clears PYTEST_CURRENT_TEST for some reason.
os.environ['PYTEST_CURRENT_TEST'] = __pytest_current_test

Expand Down Expand Up @@ -649,7 +657,12 @@ def run_test_case(
)

assert_regex(TIMESTAMP_REGEX, upload_body['start_time'])
assert upload_body['start_time'] >= start_time

assert_regex(TIMESTAMP_REGEX, upload_body['end_time'])
assert upload_body['end_time'] <= end_time

assert upload_body['end_time'] >= upload_body['start_time']

actual_test_runs = {
(test_run_record['filename'], tuple(test_run_record['name'])): [
Expand All @@ -659,6 +672,23 @@ def run_test_case(
}
assert actual_test_runs == expected_uploaded_test_runs

for test_run_record in upload_body['test_runs']:
for attempt in test_run_record['attempts']:
attempt_start_time = attempt['start_time']
assert isinstance(attempt_start_time, str)
assert_regex(TIMESTAMP_REGEX, attempt_start_time)
# Check for timestamp interference (e.g., from freezetime).
assert attempt_start_time >= start_time

attempt_end_time = attempt['end_time']
assert isinstance(attempt_end_time, str)
assert_regex(TIMESTAMP_REGEX, attempt_end_time)
assert attempt_end_time <= end_time

assert attempt_end_time >= attempt_start_time

assert isinstance(attempt['duration_ms'], int)

# Make sure there aren't any duplicate test keys.
assert len(upload_body['test_runs']) == len(actual_test_runs)

Expand Down
54 changes: 54 additions & 0 deletions tests/test_unflakable.py
Original file line number Diff line number Diff line change
Expand Up @@ -2255,3 +2255,57 @@ def test_pass():
extra_args=XDIST_ARGS if xdist else [],
failed_upload_requests=1,
)


@pytest.mark.parametrize(TEST_PARAMS_VERBOSE_XDIST_ARG_NAMES,
TEST_PARAMS_VERBOSE_XDIST_ARG_VALUES)
def test_freeze_time(
pytester: pytest.Pytester,
subprocess_mock: GitMock,
verbose: bool,
xdist: bool,
) -> None:
pytester.makepyfile(test_input="""
from freezegun import freeze_time
import unittest
@freeze_time("2023-02-04")
class FrozenTimeTests(unittest.TestCase):
@freeze_time("2024-01-01")
def test_pass(self):
pass
@freeze_time("2024-01-02")
def test_pass2(self):
pass
@freeze_time("2024-01-03")
def test_pass3(self):
pass
""")

subprocess_mock.update(branch=None, commit=None)

run_test_case(
pytester,
manifest={'quarantined_tests': []},
expected_test_file_outcomes=[
('test_input.py', [
(('FrozenTimeTests', 'test_pass'), [_TestAttemptOutcome.PASSED]),
(('FrozenTimeTests', 'test_pass2'), [_TestAttemptOutcome.PASSED]),
(('FrozenTimeTests', 'test_pass3'), [_TestAttemptOutcome.PASSED]),
])
],
expected_test_result_counts=_TestResultCounts(num_passed=3),
expected_uploaded_test_runs={
('test_input.py', ('FrozenTimeTests', 'test_pass')): ['pass'],
('test_input.py', ('FrozenTimeTests', 'test_pass2')): ['pass'],
('test_input.py', ('FrozenTimeTests', 'test_pass3')): ['pass'],
},
expected_exit_code=ExitCode.OK,
expected_branch=None,
expected_commit=None,
expect_xdist=xdist,
extra_args=XDIST_ARGS if xdist else [],
verbose=verbose,
)

0 comments on commit 7108cf2

Please sign in to comment.