Fix chzzk campaign feed filter being broken by new raw_json_v2 field
All checks were successful
Deploy to Server / deploy (push) Successful in 21s

This commit is contained in:
Joakim Hellsén 2026-04-05 05:16:59 +02:00
commit bd66d2f503
Signed by: Joakim Hellsén
SSH key fingerprint: SHA256:/9h/CsExpFp+PRhsfA0xznFx2CGfTT5R/kpuFfUgEQk
2 changed files with 68 additions and 1 deletions

View file

@ -103,3 +103,67 @@ class ChzzkDashboardViewTests(TestCase):
assert "watch" in content assert "watch" in content
assert "100" in content assert "100" in content
assert "No" in content # ios_based_reward=False assert "No" in content # ios_based_reward=False
def test_campaign_feed_only_includes_campaigns_with_raw_json(self) -> None:
"""Test that the RSS feed only includes campaigns with raw JSON data."""
now: datetime = timezone.now()
excluded: ChzzkCampaign = ChzzkCampaign.objects.create(
campaign_no=3001,
title="No JSON campaign",
description="Excluded because no raw JSON",
category_type="game",
category_id="1",
category_value="TestGame",
service_id="chzzk",
state="ACTIVE",
start_date=now - timedelta(days=1),
end_date=now + timedelta(days=1),
has_ios_based_reward=False,
drops_campaign_not_started=False,
source_api="unit-test",
)
included_v1: ChzzkCampaign = ChzzkCampaign.objects.create(
campaign_no=3002,
title="JSON v1 campaign",
description="Included because raw_json_v1 is present",
category_type="game",
category_id="1",
category_value="TestGame",
service_id="chzzk",
state="ACTIVE",
start_date=now - timedelta(days=1),
end_date=now + timedelta(days=1),
has_ios_based_reward=False,
drops_campaign_not_started=False,
source_api="unit-test",
raw_json_v1={"foo": "bar"},
)
included_v2: ChzzkCampaign = ChzzkCampaign.objects.create(
campaign_no=3003,
title="JSON v2 campaign",
description="Included because raw_json_v2 is present",
category_type="game",
category_id="1",
category_value="TestGame",
service_id="chzzk",
state="ACTIVE",
start_date=now - timedelta(days=2),
end_date=now + timedelta(days=2),
has_ios_based_reward=False,
drops_campaign_not_started=False,
source_api="unit-test",
raw_json_v2={"foo": "bar"},
)
response: _MonkeyPatchedWSGIResponse = self.client.get(
reverse("chzzk:campaign_feed"),
)
assert response.status_code == 200
content: str = response.content.decode()
assert included_v1.title in content
assert included_v2.title in content
assert excluded.title not in content

View file

@ -1,5 +1,6 @@
from typing import TYPE_CHECKING from typing import TYPE_CHECKING
from django.db.models import Q
from django.db.models.query import QuerySet from django.db.models.query import QuerySet
from django.shortcuts import get_object_or_404 from django.shortcuts import get_object_or_404
from django.shortcuts import render from django.shortcuts import render
@ -112,7 +113,9 @@ class ChzzkCampaignFeed(TTVDropsBaseFeed):
QuerySet: A queryset of ChzzkCampaign objects. QuerySet: A queryset of ChzzkCampaign objects.
""" """
limit: int = self._limit if self._limit is not None else 50 limit: int = self._limit if self._limit is not None else 50
return models.ChzzkCampaign.objects.filter(raw_json__isnull=False).order_by( return models.ChzzkCampaign.objects.filter(
Q(raw_json_v1__isnull=False) | Q(raw_json_v2__isnull=False),
).order_by(
"-start_date", "-start_date",
)[:limit] )[:limit]