Skip to content

Commit

Permalink
also exclude empty playlist names
Browse files Browse the repository at this point in the history
  • Loading branch information
raquelmsmith committed Dec 28, 2024
1 parent ec843fd commit f7f5964
Show file tree
Hide file tree
Showing 2 changed files with 50 additions and 4 deletions.
10 changes: 7 additions & 3 deletions posthog/tasks/periodic_digest.py
Original file line number Diff line number Diff line change
Expand Up @@ -66,9 +66,12 @@ def get_teams_with_new_event_definitions(end: datetime, begin: datetime) -> Quer


def get_teams_with_new_playlists(end: datetime, begin: datetime) -> QuerySet:
return SessionRecordingPlaylist.objects.filter(created_at__gt=begin, created_at__lte=end).values(
"team_id", "name", "short_id"
)
return SessionRecordingPlaylist.objects.filter(
created_at__gt=begin,
created_at__lte=end,
name__isnull=False,
name__gt="", # Excludes empty strings
).values("team_id", "name", "short_id")


def get_teams_with_new_experiments_launched(end: datetime, begin: datetime) -> QuerySet:
Expand Down Expand Up @@ -150,6 +153,7 @@ def get_periodic_digest_report(all_digest_data: dict[str, Any], team: Team) -> p
new_playlists=[
{"name": playlist.get("name"), "id": playlist.get("short_id")}
for playlist in all_digest_data["teams_with_new_playlists"].get(team.id, [])
if playlist.get("name") # Extra safety check to exclude any playlists without names
],
new_experiments_launched=[
{
Expand Down
44 changes: 43 additions & 1 deletion posthog/tasks/test/test_periodic_digest.py
Original file line number Diff line number Diff line change
Expand Up @@ -44,11 +44,20 @@ def test_periodic_digest_report(self, mock_capture: MagicMock) -> None:
name="Test Event",
)

# Create a playlist
# Create playlists - one with name, one without name, one with empty string name
playlist = SessionRecordingPlaylist.objects.create(
team=self.team,
name="Test Playlist",
)
# These should be excluded from the digest
SessionRecordingPlaylist.objects.create(
team=self.team,
name=None,
)
SessionRecordingPlaylist.objects.create(
team=self.team,
name="",
)

# Create experiments
# this flag should not be included in the digest
Expand Down Expand Up @@ -357,3 +366,36 @@ def test_periodic_digest_dry_run_no_record(self, mock_capture: MagicMock) -> Non
# Verify no capture call and no messaging record
mock_capture.delay.assert_not_called()
self.assertEqual(MessagingRecord.objects.count(), 0)

@freeze_time("2024-01-20T00:01:00Z")
@patch("posthog.tasks.periodic_digest.capture_report")
def test_periodic_digest_excludes_playlists_without_names(self, mock_capture: MagicMock) -> None:
# Create test data from "last week"
with freeze_time("2024-01-15T00:01:00Z"):
# Create playlists with various name states
valid_playlist = SessionRecordingPlaylist.objects.create(
team=self.team,
name="Valid Playlist",
)
SessionRecordingPlaylist.objects.create(
team=self.team,
name=None, # Null name should be excluded
)
SessionRecordingPlaylist.objects.create(
team=self.team,
name="", # Empty string name should be excluded
)

# Run the periodic digest report task
send_all_periodic_digest_reports()

# Extract the playlists from the capture call
call_args = mock_capture.delay.call_args
self.assertIsNotNone(call_args)
full_report_dict = call_args[1]["full_report_dict"]
playlists = full_report_dict["new_playlists"]

# Verify only the valid playlist is included
self.assertEqual(len(playlists), 1)
self.assertEqual(playlists[0]["name"], "Valid Playlist")
self.assertEqual(playlists[0]["id"], valid_playlist.short_id)

0 comments on commit f7f5964

Please sign in to comment.