Skip to content

Commit

Permalink
Time Comparison:
Browse files Browse the repository at this point in the history
- Fix delta calculation for shifts
- Add tests for new changes
  • Loading branch information
Antonio-RiveroMartnez committed May 14, 2024
1 parent ae37968 commit c3cd602
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 7 deletions.
7 changes: 4 additions & 3 deletions superset/utils/date_parser.py
Original file line number Diff line number Diff line change
Expand Up @@ -263,9 +263,10 @@ def get_since_until( # pylint: disable=too-many-arguments,too-many-locals,too-m
)

if time_shift:
time_delta = parse_past_timedelta(time_shift)
_since = _since if _since is None else (_since - time_delta)
_until = _until if _until is None else (_until - time_delta)
time_delta_since = parse_past_timedelta(time_shift, _since)
time_delta_until = parse_past_timedelta(time_shift, _until)
_since = _since if _since is None else (_since - time_delta_since)
_until = _until if _until is None else (_until - time_delta_until)

if instant_time_comparison_range:
# This is only set using the new time comparison controls
Expand Down
29 changes: 25 additions & 4 deletions tests/unit_tests/utils/date_parser_tests.py
Original file line number Diff line number Diff line change
Expand Up @@ -165,28 +165,49 @@ def test_get_since_until() -> None:
time_range="2000-01-01T00:00:00 : 2018-01-01T00:00:00",
instant_time_comparison_range="y",
)
expected = datetime(2000, 1, 1), datetime(2018, 1, 1)
expected = datetime(1999, 1, 1), datetime(2017, 1, 1)
assert result == expected

result = get_since_until(
time_range="2000-01-01T00:00:00 : 2018-01-01T00:00:00",
instant_time_comparison_range="m",
)
expected = datetime(2000, 1, 1), datetime(2018, 1, 1)
expected = datetime(1999, 12, 1), datetime(2017, 12, 1)
assert result == expected

result = get_since_until(
time_range="2000-01-01T00:00:00 : 2018-01-01T00:00:00",
instant_time_comparison_range="w",
)
expected = datetime(2000, 1, 1), datetime(2018, 1, 1)
expected = datetime(1999, 12, 25), datetime(2017, 12, 25)
assert result == expected

result = get_since_until(
time_range="2000-01-01T00:00:00 : 2018-01-01T00:00:00",
instant_time_comparison_range="r",
)
expected = datetime(2000, 1, 1), datetime(2018, 1, 1)
expected = datetime(1981, 12, 31), datetime(2000, 1, 1)
assert result == expected

result = get_since_until(
time_range="2000-01-01T00:00:00 : 2018-01-01T00:00:00",
time_shift="1 year ago",
)
expected = datetime(1999, 1, 1), datetime(2017, 1, 1)
assert result == expected

result = get_since_until(
time_range="2000-01-01T00:00:00 : 2018-01-01T00:00:00",
time_shift="1 month ago",
)
expected = datetime(1999, 12, 1), datetime(2017, 12, 1)
assert result == expected

result = get_since_until(
time_range="2000-01-01T00:00:00 : 2018-01-01T00:00:00",
time_shift="1 week ago",
)
expected = datetime(1999, 12, 25), datetime(2017, 12, 25)
assert result == expected

with pytest.raises(ValueError):
Expand Down

0 comments on commit c3cd602

Please sign in to comment.