Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Unified to UTC #7665

Merged
merged 8 commits into from
Jun 29, 2023
Merged
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
30 changes: 15 additions & 15 deletions tests/functional/simple_snapshot/test_hard_delete_snapshot.py
Original file line number Diff line number Diff line change
@@ -1,9 +1,5 @@
import os
from datetime import datetime
from datetime import timedelta
from datetime import timezone
import time

from datetime import datetime, timedelta
import pytz
import pytest
from dbt.tests.util import run_dbt, check_relations_equal
Expand All @@ -18,14 +14,6 @@
# These tests uses the same seed data, containing 20 records of which we hard delete the last 10.
# These deleted records set the dbt_valid_to to time the snapshot was ran.

# Using replace on a timestamp won't account for hour differences unless given the local timezone.
# We can force python as utc but not postgres fields which need to be handled as local timestamps.
def currenttz():
if time.daylight:
return timezone(timedelta(seconds=-time.altzone), time.tzname[1])
else:
return timezone(timedelta(seconds=-time.timezone), time.tzname[0])


def datetime_snapshot():
NUM_SNAPSHOT_MODELS = 1
Expand Down Expand Up @@ -94,7 +82,13 @@ def test_snapshot_hard_delete(project):
for result in snapshotted[10:]:
# result is a tuple, the dbt_valid_to column is the latest
assert isinstance(result[-1], datetime)
assert result[-1].replace(tzinfo=currenttz()) >= invalidated_snapshot_datetime
# Plenty of wiggle room if clocks aren't perfectly sync'd, etc
tolerance = timedelta(minutes=1)
assert (
result[-1].replace(tzinfo=pytz.UTC) > (invalidated_snapshot_datetime - tolerance)
) and (
result[-1].replace(tzinfo=pytz.UTC) < (invalidated_snapshot_datetime + tolerance)
), f"SQL timestamp {result[-1].replace(tzinfo=pytz.UTC).isoformat()} is not close enough to Python UTC {result[-1].replace(tzinfo=pytz.UTC).isoformat()}"
dbeatty10 marked this conversation as resolved.
Show resolved Hide resolved

# revive records
# Timestamp must have microseconds for tests below to be meaningful
Expand Down Expand Up @@ -133,7 +127,13 @@ def test_snapshot_hard_delete(project):
for result in invalidated_records:
# result is a tuple, the dbt_valid_to column is the latest
assert isinstance(result[1], datetime)
assert result[1].replace(tzinfo=currenttz()) >= invalidated_snapshot_datetime
# Plenty of wiggle room if clocks aren't perfectly sync'd, etc
tolerance = timedelta(minutes=1)
assert (
result[1].replace(tzinfo=pytz.UTC) > (invalidated_snapshot_datetime - tolerance)
) and (
result[1].replace(tzinfo=pytz.UTC) < (invalidated_snapshot_datetime + tolerance)
), f"SQL timestamp {result[1].replace(tzinfo=pytz.UTC).isoformat()} is not close enough to Python UTC {result[1].replace(tzinfo=pytz.UTC).isoformat()}"
dbeatty10 marked this conversation as resolved.
Show resolved Hide resolved

# records which were revived (id = 10, 11)
# dbt_valid_to is null
Expand Down