Files
aircox-radiocampus/aircox/tests/models/test_diffusion.py
2023-05-11 15:36:56 +02:00

280 lines
9.0 KiB
Python

import pytest
import random
import datetime
from model_bakery import baker
from django.utils import timezone as tz
from datetime import timedelta
import pytz
from aircox.models import Diffusion
# TODO déplacer fixutre dans conftest.py / rechercher si il y a une méthode plus lisible que celle utilisée dans ce test pour utiliser ces deux fixtures.
@pytest.fixture
def diffusions_time_variation(episodes):
random_episode = random.choice([episodes[1], episodes[0], episodes[2]])
now = tz.now()
now_date = datetime.date.today()
now_datetime = tz.now()
tomorrow_datetime = now + timedelta(hours=25)
yesterday_datetime = now - timedelta(hours=25)
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),
)
tomorrow_diffusion = baker.make(
Diffusion,
episode=random_episode,
start=tomorrow_datetime,
end=tomorrow_datetime + timedelta(minutes=30),
)
before_diffusion = baker.make(
Diffusion,
episode=random_episode,
start=now - timedelta(minutes=60),
end=now - timedelta(minutes=30),
)
yesterday_diffusion = baker.make(
Diffusion,
episode=random_episode,
start=yesterday_datetime,
end=yesterday_datetime + timedelta(minutes=30),
)
return (
now_date,
now_datetime,
yesterday_diffusion,
before_diffusion,
now_diffusion,
after_diffusion,
tomorrow_diffusion,
)
@pytest.fixture
def diffusions_episode_variation(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
)
return (
key_episode,
another_episode,
diffusions_with_the_key_episode,
diffusions_without_the_key_episode,
)
class TestDiffusionQuerySet:
@pytest.mark.django_db
def test_episode_by_obj(self, diffusions_episode_variation):
(
key_episode,
_,
diffusions_with_the_key_episode,
diffusions_without_the_key_episode,
) = diffusions_episode_variation
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, diffusions_episode_variation):
(
key_episode,
_,
diffusions_with_the_key_episode,
diffusions_without_the_key_episode,
) = diffusions_episode_variation
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
# la méthode "now" filtre les diffusions en cours d'un moment précis.
# elle prend en compte un objet datetime (date + heure)
# les diffusions en cours sont définie en fonction de l'argument "now" ou de l'heure actuelle si now=None.
# la méthode distinct élimine les doublons de diffusions (si ils ont des valeurs identiques pour tous les champs de la db)
# TODO test si il y a doublon qu'un seul objet soit récupéré.
@pytest.mark.django_db
def test_now_test(self, diffusions_time_variation):
now = tz.now()
(
_,
_,
_,
_,
now_diffusion,
_,
_,
) = diffusions_time_variation
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
# méthode date filtre les diffusions en cours d'une date précise.
# elle ne prend pas en compte un objet datetime mais un "objet date" uniquement
# elle crée deux objets datetime (start and end) à partir de l'argument "date" (if none = today)
# elle utilise la méthode "combine" de la classe "datetime" pour créer ces deux objets à partir de la date
# elle filtre ensuite les diffusions qui ont lieu entre "start" et "end".
@pytest.mark.django_db
def test_date_without_date_arg(self, diffusions_time_variation):
(
_,
_,
_,
before_diffusion,
now_diffusion,
after_diffusion,
_,
) = diffusions_time_variation
result = Diffusion.objects.date()
assert len(result) == 3
assert result[0] == before_diffusion
assert result[1] == now_diffusion
assert result[2] == after_diffusion
@pytest.mark.django_db
def test_date_with_date_arg(self, diffusions_time_variation):
today_date = datetime.date.today()
tomorrow_date = today_date + timedelta(days=1)
(
_,
_,
_,
_,
_,
_,
tomorrow_diffusion,
) = diffusions_time_variation
result = Diffusion.objects.date(date=tomorrow_date)
assert len(result) == 1
assert result[0] == tomorrow_diffusion
# la méthode at récupère les diffusions à une date donnée.
# elle utilise la méthode now si la date est un objet datetime
# elle utilise la méthode date si la date est un objet date
@pytest.mark.django_db
def test_at_datetimeobj(self, diffusions_time_variation):
(
_,
now_datetime,
_,
_,
now_diffusion,
_,
_,
) = diffusions_time_variation
result = Diffusion.objects.at(date=now_datetime)
assert len(result) == 1
assert now_diffusion in result
@pytest.mark.django_db
def test_at_dateobj(self, diffusions_time_variation):
(
now_date,
_,
_,
before_diffusion,
now_diffusion,
after_diffusion,
_,
) = diffusions_time_variation
result = Diffusion.objects.at(date=now_date)
assert len(result) == 3
assert result[0] == before_diffusion
assert result[1] == now_diffusion
assert result[2] == after_diffusion
@pytest.mark.django_db
def test_after_without_date_arg(self, diffusions_time_variation):
(
_,
_,
yesterday_diffusion,
_,
now_diffusion,
_,
tomorrow_diffusion,
) = diffusions_time_variation
from_now_diffusions = Diffusion.objects.after()
assert tomorrow_diffusion in from_now_diffusions
assert now_diffusion in from_now_diffusions
assert yesterday_diffusion not in from_now_diffusions
@pytest.mark.django_db
def test_after_with_datetime_arg(self, diffusions_time_variation):
(
_,
now_datetime,
yesterday_diffusion,
before_diffusion,
now_diffusion,
after_diffusion,
tomorrow_diffusion,
) = diffusions_time_variation
from_now_diffusions = Diffusion.objects.after(date=now_datetime)
assert tomorrow_diffusion in from_now_diffusions
assert after_diffusion in from_now_diffusions
assert now_diffusion in from_now_diffusions
assert before_diffusion not in from_now_diffusions
assert yesterday_diffusion not in from_now_diffusions
@pytest.mark.django_db
def test_after_with_date_arg(self, diffusions_time_variation):
(
now_date,
_,
yesterday_diffusion,
before_diffusion,
now_diffusion,
after_diffusion,
tomorrow_diffusion,
) = diffusions_time_variation
from_today_diffusions = Diffusion.objects.after(date=now_date)
#assert now_date == 'today'
assert tomorrow_diffusion in from_today_diffusions
assert after_diffusion in from_today_diffusions
assert now_diffusion in from_today_diffusions
assert before_diffusion in from_today_diffusions
assert yesterday_diffusion not in from_today_diffusions