forked from rc/aircox
157 lines
5.6 KiB
Python
157 lines
5.6 KiB
Python
import pytest
|
|
import random
|
|
import datetime
|
|
from model_bakery import baker
|
|
from django.utils import timezone as tz
|
|
from datetime import timedelta
|
|
from aircox.models import Diffusion
|
|
|
|
|
|
class TestDiffusionQuerySet:
|
|
@pytest.mark.django_db
|
|
def test_episode_by_obj(self, episodes):
|
|
key_episode = episodes[1]
|
|
another_episode = episodes[2]
|
|
diffusions_with_the_key_episode = baker.make(
|
|
Diffusion, _quantity=3, episode=key_episode
|
|
)
|
|
diffusions_without_the_key_episode = baker.make(
|
|
Diffusion, _quantity=3, episode=another_episode
|
|
)
|
|
result = Diffusion.objects.episode(episode=key_episode)
|
|
|
|
for diffusion in diffusions_with_the_key_episode:
|
|
assert diffusion in result
|
|
for diffusion in diffusions_without_the_key_episode:
|
|
assert diffusion not in result
|
|
|
|
@pytest.mark.django_db
|
|
def test_episode_by_id(self, episodes):
|
|
key_episode = episodes[1]
|
|
another_episode = episodes[2]
|
|
diffusions_with_the_key_episode = baker.make(
|
|
Diffusion, _quantity=3, episode=key_episode
|
|
)
|
|
diffusions_without_the_key_episode = baker.make(
|
|
Diffusion, _quantity=3, episode=another_episode
|
|
)
|
|
result = Diffusion.objects.episode(id=key_episode.id)
|
|
|
|
for diffusion in diffusions_with_the_key_episode:
|
|
assert diffusion in result
|
|
for diffusion in diffusions_without_the_key_episode:
|
|
assert diffusion not in result
|
|
|
|
@pytest.mark.django_db
|
|
def test_on_air(self, episodes):
|
|
for episode in episodes:
|
|
random_type = random.choice(
|
|
[Diffusion.TYPE_ON_AIR, Diffusion.TYPE_UNCONFIRMED]
|
|
)
|
|
baker.make(Diffusion, episode=episode, type=random_type)
|
|
result = Diffusion.objects.on_air()
|
|
|
|
for diffusion in result:
|
|
assert diffusion.type == Diffusion.TYPE_ON_AIR
|
|
assert diffusion.type != Diffusion.TYPE_UNCONFIRMED
|
|
|
|
@pytest.mark.django_db
|
|
def test_now(self, episodes):
|
|
now = tz.now()
|
|
random_episode = random.choice([episodes[1], episodes[0], episodes[2]])
|
|
now_diffusion = baker.make(
|
|
Diffusion,
|
|
episode=random_episode,
|
|
start=now - timedelta(minutes=30),
|
|
end=now + timedelta(minutes=30),
|
|
)
|
|
after_diffusion = baker.make(
|
|
Diffusion,
|
|
episode=random_episode,
|
|
start=now + timedelta(minutes=30),
|
|
end=now + timedelta(minutes=60),
|
|
)
|
|
before_diffusion = baker.make(
|
|
Diffusion,
|
|
episode=random_episode,
|
|
start=now - timedelta(minutes=60),
|
|
end=now - timedelta(minutes=30),
|
|
)
|
|
result = Diffusion.objects.now(now=now, order=True)
|
|
|
|
assert len(result) == 1
|
|
assert result[0] == now_diffusion
|
|
assert result[0].start <= now <= result[0].end
|
|
|
|
@pytest.mark.django_db
|
|
def test_date_without_date_arg(self, episodes):
|
|
today = datetime.date.today()
|
|
tomorrow = today + timedelta(days=1)
|
|
random_episode = random.choice([episodes[1], episodes[0], episodes[2]])
|
|
second_today_diffusion = baker.make(
|
|
Diffusion,
|
|
episode=random_episode,
|
|
start=tz.datetime.combine(today, datetime.time.min)
|
|
+ timedelta(minutes=30),
|
|
end=tz.datetime.combine(today, datetime.time.max)
|
|
+ timedelta(minutes=60),
|
|
)
|
|
first_today_diffusion = baker.make(
|
|
Diffusion,
|
|
episode=random_episode,
|
|
start=tz.datetime.combine(today, datetime.time.min),
|
|
end=tz.datetime.combine(today, datetime.time.max)
|
|
+ timedelta(minutes=30),
|
|
)
|
|
another_day_diffusion = baker.make(
|
|
Diffusion,
|
|
episode=random_episode,
|
|
start=tz.datetime.combine(tomorrow, datetime.time.min),
|
|
end=tz.datetime.combine(tomorrow, datetime.time.max),
|
|
)
|
|
|
|
result = Diffusion.objects.date()
|
|
|
|
assert len(result) == 2
|
|
assert result[0] == first_today_diffusion
|
|
assert result[1] == second_today_diffusion
|
|
|
|
@pytest.mark.django_db
|
|
def test_date_with_date_arg(self, episodes):
|
|
today = datetime.date.today()
|
|
tomorrow = today + timedelta(days=1)
|
|
random_episode = random.choice([episodes[1], episodes[0], episodes[2]])
|
|
first_today_diffusion = baker.make(
|
|
Diffusion,
|
|
episode=random_episode,
|
|
start=tz.datetime.combine(today, datetime.time.min)
|
|
- timedelta(minutes=30),
|
|
end=tz.datetime.combine(today, datetime.time.min)
|
|
+ timedelta(minutes=30),
|
|
)
|
|
second_tomorrow_diffusion = baker.make(
|
|
Diffusion,
|
|
episode=random_episode,
|
|
start=tz.datetime.combine(tomorrow, datetime.time.min)
|
|
+ timedelta(minutes=30),
|
|
end=tz.datetime.combine(tomorrow, datetime.time.min)
|
|
+ timedelta(minutes=60),
|
|
)
|
|
first_tomorrow_diffusion = baker.make(
|
|
Diffusion,
|
|
episode=random_episode,
|
|
start=tz.datetime.combine(tomorrow, datetime.time.min),
|
|
end=tz.datetime.combine(tomorrow, datetime.time.min)
|
|
+ timedelta(minutes=60),
|
|
)
|
|
|
|
result = Diffusion.objects.date(date=tomorrow)
|
|
|
|
assert len(result) == 2
|
|
assert result[0] == first_tomorrow_diffusion
|
|
assert result[1] == second_tomorrow_diffusion
|
|
|
|
# @pytest.mark.django_db
|
|
# def test_at(self, episodes):
|
|
# date = datetime.date.today()
|