169 lines
6.4 KiB
Python
169 lines
6.4 KiB
Python
from datetime import datetime, timedelta, timezone
|
|
|
|
from django.conf import settings
|
|
from django.utils import dateparse
|
|
from model_bakery import baker
|
|
from rest_framework.test import APITestCase
|
|
|
|
from ...._fixtures import AUDIO_FILENAME
|
|
|
|
|
|
class TestScheduleViewSet(APITestCase):
|
|
@classmethod
|
|
def setUpTestData(cls):
|
|
cls.path = "/api/v2/schedule"
|
|
cls.token = settings.CONFIG.general.api_key
|
|
|
|
def test_schedule_item_full_length(self):
|
|
file = baker.make(
|
|
"storage.File",
|
|
mime="audio/mp3",
|
|
filepath=AUDIO_FILENAME,
|
|
length=timedelta(seconds=40.86),
|
|
cue_in=timedelta(seconds=0),
|
|
cue_out=timedelta(seconds=40.8131),
|
|
)
|
|
show = baker.make(
|
|
"schedule.ShowInstance",
|
|
starts_at=datetime.now(tz=timezone.utc) - timedelta(minutes=5),
|
|
ends_at=datetime.now(tz=timezone.utc) + timedelta(minutes=5),
|
|
)
|
|
schedule_item = baker.make(
|
|
"schedule.Schedule",
|
|
starts_at=datetime.now(tz=timezone.utc),
|
|
ends_at=datetime.now(tz=timezone.utc) + file.length,
|
|
cue_out=file.cue_out,
|
|
instance=show,
|
|
file=file,
|
|
)
|
|
self.client.credentials(HTTP_AUTHORIZATION=f"Api-Key {self.token}")
|
|
response = self.client.get(self.path)
|
|
self.assertEqual(response.status_code, 200)
|
|
result = response.json()
|
|
self.assertEqual(
|
|
dateparse.parse_datetime(result[0]["ends_at"]), schedule_item.ends_at
|
|
)
|
|
self.assertEqual(dateparse.parse_duration(result[0]["cue_out"]), file.cue_out)
|
|
|
|
def test_schedule_item_trunc(self):
|
|
file = baker.make(
|
|
"storage.File",
|
|
mime="audio/mp3",
|
|
filepath=AUDIO_FILENAME,
|
|
length=timedelta(seconds=40.86),
|
|
cue_in=timedelta(seconds=0),
|
|
cue_out=timedelta(seconds=40.8131),
|
|
)
|
|
show = baker.make(
|
|
"schedule.ShowInstance",
|
|
starts_at=datetime.now(tz=timezone.utc) - timedelta(minutes=5),
|
|
ends_at=datetime.now(tz=timezone.utc) + timedelta(seconds=20),
|
|
)
|
|
schedule_item = baker.make(
|
|
"schedule.Schedule",
|
|
starts_at=datetime.now(tz=timezone.utc),
|
|
ends_at=datetime.now(tz=timezone.utc) + file.length,
|
|
instance=show,
|
|
file=file,
|
|
)
|
|
self.client.credentials(HTTP_AUTHORIZATION=f"Api-Key {self.token}")
|
|
response = self.client.get(self.path)
|
|
self.assertEqual(response.status_code, 200)
|
|
result = response.json()
|
|
self.assertEqual(dateparse.parse_datetime(result[0]["ends_at"]), show.ends_at)
|
|
expected = show.ends_at - schedule_item.starts_at
|
|
self.assertEqual(dateparse.parse_duration(result[0]["cue_out"]), expected)
|
|
self.assertNotEqual(
|
|
dateparse.parse_datetime(result[0]["ends_at"]), schedule_item.ends_at
|
|
)
|
|
|
|
def test_schedule_item_invalid(self):
|
|
file = baker.make(
|
|
"storage.File",
|
|
mime="audio/mp3",
|
|
filepath=AUDIO_FILENAME,
|
|
length=timedelta(seconds=40.86),
|
|
cue_in=timedelta(seconds=0),
|
|
cue_out=timedelta(seconds=40.8131),
|
|
)
|
|
show = baker.make(
|
|
"schedule.ShowInstance",
|
|
starts_at=datetime.now(tz=timezone.utc) - timedelta(minutes=5),
|
|
ends_at=datetime.now(tz=timezone.utc) + timedelta(minutes=5),
|
|
)
|
|
schedule_item = baker.make(
|
|
"schedule.Schedule",
|
|
starts_at=datetime.now(tz=timezone.utc),
|
|
ends_at=datetime.now(tz=timezone.utc) + file.length,
|
|
cue_out=file.cue_out,
|
|
instance=show,
|
|
file=file,
|
|
)
|
|
invalid_schedule_item = baker.make( # pylint: disable=unused-variable
|
|
"schedule.Schedule",
|
|
starts_at=show.ends_at + timedelta(minutes=1),
|
|
ends_at=show.ends_at + timedelta(minutes=1) + file.length,
|
|
cue_out=file.cue_out,
|
|
instance=show,
|
|
file=file,
|
|
)
|
|
self.client.credentials(HTTP_AUTHORIZATION=f"Api-Key {self.token}")
|
|
response = self.client.get(self.path, {"overbooked": False})
|
|
self.assertEqual(response.status_code, 200)
|
|
result = response.json()
|
|
# The invalid item should be filtered out and not returned
|
|
self.assertEqual(len(result), 1)
|
|
self.assertEqual(
|
|
dateparse.parse_datetime(result[0]["ends_at"]), schedule_item.ends_at
|
|
)
|
|
self.assertEqual(dateparse.parse_duration(result[0]["cue_out"]), file.cue_out)
|
|
|
|
def test_schedule_item_range(self):
|
|
file = baker.make(
|
|
"storage.File",
|
|
mime="audio/mp3",
|
|
filepath=AUDIO_FILENAME,
|
|
length=timedelta(seconds=40.86),
|
|
cue_in=timedelta(seconds=0),
|
|
cue_out=timedelta(seconds=40.8131),
|
|
)
|
|
filter_point = datetime.now(tz=timezone.utc)
|
|
|
|
show = baker.make(
|
|
"schedule.ShowInstance",
|
|
starts_at=filter_point - timedelta(minutes=5),
|
|
ends_at=filter_point + timedelta(minutes=5),
|
|
)
|
|
schedule_item = baker.make(
|
|
"schedule.Schedule",
|
|
starts_at=filter_point,
|
|
ends_at=filter_point + file.length,
|
|
cue_out=file.cue_out,
|
|
instance=show,
|
|
file=file,
|
|
)
|
|
previous_item = baker.make( # pylint: disable=unused-variable
|
|
"schedule.Schedule",
|
|
starts_at=filter_point - timedelta(minutes=5),
|
|
ends_at=filter_point - timedelta(minutes=5) + file.length,
|
|
cue_out=file.cue_out,
|
|
instance=show,
|
|
file=file,
|
|
)
|
|
self.client.credentials(HTTP_AUTHORIZATION=f"Api-Key {self.token}")
|
|
range_start = (filter_point - timedelta(minutes=1)).isoformat(
|
|
timespec="seconds"
|
|
)
|
|
range_end = (filter_point + timedelta(minutes=1)).isoformat(timespec="seconds")
|
|
response = self.client.get(
|
|
self.path,
|
|
{"starts_after": range_start, "starts_before": range_end},
|
|
)
|
|
self.assertEqual(response.status_code, 200)
|
|
result = response.json()
|
|
# The previous_item should be filtered out and not returned
|
|
self.assertEqual(len(result), 1)
|
|
self.assertEqual(
|
|
dateparse.parse_datetime(result[0]["starts_at"]), schedule_item.starts_at
|
|
)
|