forked from PostHog/posthog
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat(hogql): Added unit tests for the new trends query runner (PostHo…
…g#17730) * Added unit tests for the new trends query runner * Updated test file location * Remove pydantic * Update query snapshots * Update query snapshots --------- Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com>
- Loading branch information
1 parent
81ed338
commit 538369c
Showing
1 changed file
with
282 additions
and
0 deletions.
There are no files selected for viewing
282 changes: 282 additions & 0 deletions
282
posthog/hogql_queries/insights/trends/test/test_trends_query_runner.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,282 @@ | ||
from dataclasses import dataclass | ||
from typing import List, Optional | ||
from freezegun import freeze_time | ||
from posthog.hogql_queries.insights.trends.trends_query_runner import TrendsQueryRunner | ||
|
||
from posthog.schema import DateRange, EventsNode, IntervalType, TrendsFilter, TrendsQuery | ||
from posthog.test.base import APIBaseTest, ClickhouseTestMixin, _create_event, _create_person | ||
|
||
|
||
@dataclass | ||
class Series: | ||
event: str | ||
timestamps: List[str] | ||
|
||
|
||
@dataclass | ||
class SeriesTestData: | ||
distinct_id: str | ||
events: List[Series] | ||
|
||
|
||
class TestQuery(ClickhouseTestMixin, APIBaseTest): | ||
default_date_from = "2020-01-09" | ||
default_date_to = "2020-01-19" | ||
|
||
def _create_events(self, data: List[SeriesTestData]): | ||
person_result = [] | ||
for person in data: | ||
first_timestamp = person.events[0].timestamps[0] | ||
|
||
with freeze_time(first_timestamp): | ||
person_result.append( | ||
_create_person( | ||
team_id=self.team.pk, | ||
distinct_ids=[person.distinct_id], | ||
properties={ | ||
"name": person.distinct_id, | ||
**({"email": "[email protected]"} if person.distinct_id == "p1" else {}), | ||
}, | ||
) | ||
) | ||
for event in person.events: | ||
for timestamp in event.timestamps: | ||
_create_event(team=self.team, event=event.event, distinct_id=id, timestamp=timestamp) | ||
return person_result | ||
|
||
def _create_test_events(self): | ||
self._create_events( | ||
[ | ||
SeriesTestData( | ||
distinct_id="p1", | ||
events=[ | ||
Series( | ||
event="$pageview", | ||
timestamps=[ | ||
"2020-01-11T12:00:00Z", | ||
"2020-01-12T12:00:00Z", | ||
"2020-01-13T12:00:00Z", | ||
"2020-01-15T12:00:00Z", | ||
"2020-01-17T12:00:00Z", | ||
"2020-01-19T12:00:00Z", | ||
], | ||
), | ||
Series( | ||
event="$pageleave", | ||
timestamps=[ | ||
"2020-01-11T12:00:00Z", | ||
"2020-01-12T12:00:00Z", | ||
"2020-01-13T12:00:00Z", | ||
], | ||
), | ||
], | ||
), | ||
SeriesTestData( | ||
distinct_id="p2", | ||
events=[ | ||
Series(event="$pageview", timestamps=["2020-01-09T12:00:00Z", "2020-01-12T12:00:00Z"]), | ||
Series( | ||
event="$pageleave", | ||
timestamps=[ | ||
"2020-01-13T12:00:00Z", | ||
], | ||
), | ||
], | ||
), | ||
SeriesTestData( | ||
distinct_id="p3", | ||
events=[ | ||
Series(event="$pageview", timestamps=["2020-01-12T12:00:00Z"]), | ||
Series(event="$pageleave", timestamps=["2020-01-13T12:00:00Z"]), | ||
], | ||
), | ||
SeriesTestData( | ||
distinct_id="p4", | ||
events=[ | ||
Series(event="$pageview", timestamps=["2020-01-15T12:00:00Z"]), | ||
Series(event="$pageleave", timestamps=["2020-01-16T12:00:00Z"]), | ||
], | ||
), | ||
] | ||
) | ||
|
||
def _create_query_runner(self, date_from, date_to, interval, series, trends_filters) -> TrendsQueryRunner: | ||
query_series = [EventsNode(event="$pageview")] if series is None else series | ||
query = TrendsQuery( | ||
dateRange=DateRange(date_from=date_from, date_to=date_to), | ||
interval=interval, | ||
series=query_series, | ||
trendsFilter=trends_filters, | ||
) | ||
return TrendsQueryRunner(team=self.team, query=query) | ||
|
||
def _run_trends_query( | ||
self, date_from, date_to, interval, series=None, trends_filters: Optional[TrendsFilter] = None | ||
): | ||
return self._create_query_runner(date_from, date_to, interval, series, trends_filters).calculate() | ||
|
||
def test_trends_query_label(self): | ||
self._create_test_events() | ||
|
||
response = self._run_trends_query(self.default_date_from, self.default_date_to, IntervalType.day) | ||
|
||
self.assertEqual("$pageview", response.results[0]["label"]) | ||
|
||
def test_trends_query_count(self): | ||
self._create_test_events() | ||
|
||
response = self._run_trends_query(self.default_date_from, self.default_date_to, IntervalType.day) | ||
|
||
self.assertEqual(10, response.results[0]["count"]) | ||
|
||
def test_trends_query_data(self): | ||
self._create_test_events() | ||
|
||
response = self._run_trends_query(self.default_date_from, self.default_date_to, IntervalType.day) | ||
|
||
self.assertEqual([1, 0, 1, 3, 1, 0, 2, 0, 1, 0, 1], response.results[0]["data"]) | ||
|
||
def test_trends_query_days(self): | ||
self._create_test_events() | ||
|
||
response = self._run_trends_query(self.default_date_from, self.default_date_to, IntervalType.day) | ||
|
||
self.assertEqual( | ||
[ | ||
"2020-01-09", | ||
"2020-01-10", | ||
"2020-01-11", | ||
"2020-01-12", | ||
"2020-01-13", | ||
"2020-01-14", | ||
"2020-01-15", | ||
"2020-01-16", | ||
"2020-01-17", | ||
"2020-01-18", | ||
"2020-01-19", | ||
], | ||
response.results[0]["days"], | ||
) | ||
|
||
def test_trends_query_labels(self): | ||
self._create_test_events() | ||
|
||
response = self._run_trends_query(self.default_date_from, self.default_date_to, IntervalType.day) | ||
|
||
self.assertEqual( | ||
[ | ||
"9-Jan-2020", | ||
"10-Jan-2020", | ||
"11-Jan-2020", | ||
"12-Jan-2020", | ||
"13-Jan-2020", | ||
"14-Jan-2020", | ||
"15-Jan-2020", | ||
"16-Jan-2020", | ||
"17-Jan-2020", | ||
"18-Jan-2020", | ||
"19-Jan-2020", | ||
], | ||
response.results[0]["labels"], | ||
) | ||
|
||
def test_trends_query_multiple_series(self): | ||
self._create_test_events() | ||
|
||
response = self._run_trends_query( | ||
self.default_date_from, | ||
self.default_date_to, | ||
IntervalType.day, | ||
[EventsNode(event="$pageview"), EventsNode(event="$pageleave")], | ||
) | ||
|
||
self.assertEqual(2, len(response.results)) | ||
|
||
self.assertEqual("$pageview", response.results[0]["label"]) | ||
self.assertEqual("$pageleave", response.results[1]["label"]) | ||
|
||
self.assertEqual(10, response.results[0]["count"]) | ||
self.assertEqual(6, response.results[1]["count"]) | ||
|
||
self.assertEqual([1, 0, 1, 3, 1, 0, 2, 0, 1, 0, 1], response.results[0]["data"]) | ||
self.assertEqual([0, 0, 1, 1, 3, 0, 0, 1, 0, 0, 0], response.results[1]["data"]) | ||
|
||
def test_trends_query_formula(self): | ||
self._create_test_events() | ||
|
||
response = self._run_trends_query( | ||
self.default_date_from, | ||
self.default_date_to, | ||
IntervalType.day, | ||
[EventsNode(event="$pageview"), EventsNode(event="$pageleave")], | ||
TrendsFilter(formula="A+B"), | ||
) | ||
|
||
self.assertEqual(1, len(response.results)) | ||
self.assertEqual(16, response.results[0]["count"]) | ||
self.assertEqual("Formula (A+B)", response.results[0]["label"]) | ||
self.assertEqual([1, 0, 2, 4, 4, 0, 2, 1, 1, 0, 1], response.results[0]["data"]) | ||
|
||
def test_trends_query_compare(self): | ||
self._create_test_events() | ||
|
||
response = self._run_trends_query( | ||
"2020-01-15", "2020-01-19", IntervalType.day, [EventsNode(event="$pageview")], TrendsFilter(compare=True) | ||
) | ||
|
||
self.assertEqual(2, len(response.results)) | ||
|
||
self.assertEqual(True, response.results[0]["compare"]) | ||
self.assertEqual(True, response.results[1]["compare"]) | ||
|
||
self.assertEqual("current", response.results[0]["compare_label"]) | ||
self.assertEqual("previous", response.results[1]["compare_label"]) | ||
|
||
self.assertEqual( | ||
[ | ||
"2020-01-15", | ||
"2020-01-16", | ||
"2020-01-17", | ||
"2020-01-18", | ||
"2020-01-19", | ||
], | ||
response.results[0]["days"], | ||
) | ||
self.assertEqual( | ||
[ | ||
"2020-01-10", | ||
"2020-01-11", | ||
"2020-01-12", | ||
"2020-01-13", | ||
"2020-01-14", | ||
], | ||
response.results[1]["days"], | ||
) | ||
|
||
self.assertEqual(["day 0", "day 1", "day 2", "day 3", "day 4"], response.results[0]["labels"]) | ||
self.assertEqual(["day 0", "day 1", "day 2", "day 3", "day 4"], response.results[1]["labels"]) | ||
|
||
def test_trends_query_formula_with_compare(self): | ||
self._create_test_events() | ||
|
||
response = self._run_trends_query( | ||
"2020-01-15", | ||
"2020-01-19", | ||
IntervalType.day, | ||
[EventsNode(event="$pageview"), EventsNode(event="$pageleave")], | ||
TrendsFilter(formula="A+B", compare=True), | ||
) | ||
|
||
self.assertEqual(2, len(response.results)) | ||
|
||
self.assertEqual(5, response.results[0]["count"]) | ||
self.assertEqual(10, response.results[1]["count"]) | ||
|
||
self.assertEqual(True, response.results[0]["compare"]) | ||
self.assertEqual(True, response.results[1]["compare"]) | ||
|
||
self.assertEqual("current", response.results[0]["compare_label"]) | ||
self.assertEqual("previous", response.results[1]["compare_label"]) | ||
|
||
self.assertEqual("Formula (A+B)", response.results[0]["label"]) | ||
self.assertEqual("Formula (A+B)", response.results[1]["label"]) |