Moved test date check into a dedicated function

This commit is contained in:
Eliot Berriot 2019-07-29 10:44:01 +02:00
parent b3de851e6f
commit 32445c5113
No known key found for this signature in database
GPG Key ID: DD6965E2476E5C27
8 changed files with 59 additions and 52 deletions

View File

@ -1,5 +1,4 @@
import contextlib import contextlib
import datetime
import io import io
import os import os
import PIL import PIL
@ -22,7 +21,6 @@ from django.db.models import QuerySet
from aioresponses import aioresponses from aioresponses import aioresponses
from dynamic_preferences.registries import global_preferences_registry from dynamic_preferences.registries import global_preferences_registry
from rest_framework import fields as rest_fields
from rest_framework.test import APIClient, APIRequestFactory from rest_framework.test import APIClient, APIRequestFactory
from funkwhale_api.activity import record from funkwhale_api.activity import record
@ -30,6 +28,7 @@ from funkwhale_api.federation import actors
from funkwhale_api.moderation import mrf from funkwhale_api.moderation import mrf
from funkwhale_api.music import licenses from funkwhale_api.music import licenses
from . import utils as test_utils
pytest_plugins = "aiohttp.pytest_plugin" pytest_plugins = "aiohttp.pytest_plugin"
@ -297,18 +296,9 @@ def authenticated_actor(factories, mocker):
yield actor yield actor
@pytest.fixture @pytest.fixture(scope="session")
def to_api_date(): def to_api_date():
def inner(value): return test_utils.to_api_date
if isinstance(value, datetime.datetime):
f = rest_fields.DateTimeField()
return f.to_representation(value)
if isinstance(value, datetime.date):
f = rest_fields.DateField()
return f.to_representation(value)
raise ValueError("Invalid value: {}".format(value))
return inner
@pytest.fixture() @pytest.fixture()

View File

@ -4,7 +4,7 @@ from funkwhale_api.federation import api_serializers
from funkwhale_api.federation import serializers from funkwhale_api.federation import serializers
def test_library_serializer(factories): def test_library_serializer(factories, to_api_date):
library = factories["music.Library"](uploads_count=5678) library = factories["music.Library"](uploads_count=5678)
expected = { expected = {
"fid": library.fid, "fid": library.fid,
@ -12,7 +12,7 @@ def test_library_serializer(factories):
"actor": serializers.APIActorSerializer(library.actor).data, "actor": serializers.APIActorSerializer(library.actor).data,
"name": library.name, "name": library.name,
"description": library.description, "description": library.description,
"creation_date": library.creation_date.isoformat().split("+")[0] + "Z", "creation_date": to_api_date(library.creation_date),
"uploads_count": library.uploads_count, "uploads_count": library.uploads_count,
"privacy_level": library.privacy_level, "privacy_level": library.privacy_level,
"follow": None, "follow": None,
@ -34,7 +34,7 @@ def test_library_serializer_latest_scan(factories):
assert serializer.data["latest_scan"] == expected assert serializer.data["latest_scan"] == expected
def test_library_serializer_with_follow(factories): def test_library_serializer_with_follow(factories, to_api_date):
library = factories["music.Library"](uploads_count=5678) library = factories["music.Library"](uploads_count=5678)
follow = factories["federation.LibraryFollow"](target=library) follow = factories["federation.LibraryFollow"](target=library)
@ -45,7 +45,7 @@ def test_library_serializer_with_follow(factories):
"actor": serializers.APIActorSerializer(library.actor).data, "actor": serializers.APIActorSerializer(library.actor).data,
"name": library.name, "name": library.name,
"description": library.description, "description": library.description,
"creation_date": library.creation_date.isoformat().split("+")[0] + "Z", "creation_date": to_api_date(library.creation_date),
"uploads_count": library.uploads_count, "uploads_count": library.uploads_count,
"privacy_level": library.privacy_level, "privacy_level": library.privacy_level,
"follow": api_serializers.NestedLibraryFollowSerializer(follow).data, "follow": api_serializers.NestedLibraryFollowSerializer(follow).data,

View File

@ -39,13 +39,13 @@ def test_user_update_permission(factories):
assert user.permission_settings is False assert user.permission_settings is False
def test_manage_domain_serializer(factories, now): def test_manage_domain_serializer(factories, now, to_api_date):
domain = factories["federation.Domain"](nodeinfo_fetch_date=None) domain = factories["federation.Domain"](nodeinfo_fetch_date=None)
setattr(domain, "actors_count", 42) setattr(domain, "actors_count", 42)
setattr(domain, "outbox_activities_count", 23) setattr(domain, "outbox_activities_count", 23)
expected = { expected = {
"name": domain.name, "name": domain.name,
"creation_date": domain.creation_date.isoformat().split("+")[0] + "Z", "creation_date": to_api_date(domain.creation_date),
"actors_count": 42, "actors_count": 42,
"outbox_activities_count": 23, "outbox_activities_count": 23,
"nodeinfo": {}, "nodeinfo": {},
@ -65,14 +65,14 @@ def test_manage_domain_serializer_validates_hostname(db):
s.is_valid(raise_exception=True) s.is_valid(raise_exception=True)
def test_manage_actor_serializer(factories, now): def test_manage_actor_serializer(factories, now, to_api_date):
actor = factories["federation.Actor"]() actor = factories["federation.Actor"]()
setattr(actor, "uploads_count", 66) setattr(actor, "uploads_count", 66)
expected = { expected = {
"id": actor.id, "id": actor.id,
"name": actor.name, "name": actor.name,
"creation_date": actor.creation_date.isoformat().split("+")[0] + "Z", "creation_date": to_api_date(actor.creation_date),
"last_fetch_date": actor.last_fetch_date.isoformat().split("+")[0] + "Z", "last_fetch_date": to_api_date(actor.last_fetch_date),
"uploads_count": 66, "uploads_count": 66,
"fid": actor.fid, "fid": actor.fid,
"url": actor.url, "url": actor.url,
@ -110,13 +110,15 @@ def test_manage_actor_serializer(factories, now):
), ),
], ],
) )
def test_instance_policy_serializer_repr(factories, factory_kwargs, expected): def test_instance_policy_serializer_repr(
factories, factory_kwargs, expected, to_api_date
):
policy = factories["moderation.InstancePolicy"](block_all=True, **factory_kwargs) policy = factories["moderation.InstancePolicy"](block_all=True, **factory_kwargs)
e = { e = {
"id": policy.id, "id": policy.id,
"uuid": str(policy.uuid), "uuid": str(policy.uuid),
"creation_date": policy.creation_date.isoformat().split("+")[0] + "Z", "creation_date": to_api_date(policy.creation_date),
"actor": policy.actor.full_username, "actor": policy.actor.full_username,
"block_all": True, "block_all": True,
"silence_activity": False, "silence_activity": False,
@ -280,7 +282,7 @@ def test_instance_policy_serializer_purges_target_actor(
assert on_commit.call_count == 0 assert on_commit.call_count == 0
def test_manage_artist_serializer(factories, now): def test_manage_artist_serializer(factories, now, to_api_date):
artist = factories["music.Artist"](attributed=True) artist = factories["music.Artist"](attributed=True)
track = factories["music.Track"](artist=artist) track = factories["music.Track"](artist=artist)
album = factories["music.Album"](artist=artist) album = factories["music.Album"](artist=artist)
@ -291,7 +293,7 @@ def test_manage_artist_serializer(factories, now):
"fid": artist.fid, "fid": artist.fid,
"name": artist.name, "name": artist.name,
"mbid": artist.mbid, "mbid": artist.mbid,
"creation_date": artist.creation_date.isoformat().split("+")[0] + "Z", "creation_date": to_api_date(artist.creation_date),
"albums": [serializers.ManageNestedAlbumSerializer(album).data], "albums": [serializers.ManageNestedAlbumSerializer(album).data],
"tracks": [serializers.ManageNestedTrackSerializer(track).data], "tracks": [serializers.ManageNestedTrackSerializer(track).data],
"attributed_to": serializers.ManageBaseActorSerializer( "attributed_to": serializers.ManageBaseActorSerializer(
@ -304,7 +306,7 @@ def test_manage_artist_serializer(factories, now):
assert s.data == expected assert s.data == expected
def test_manage_nested_track_serializer(factories, now): def test_manage_nested_track_serializer(factories, now, to_api_date):
track = factories["music.Track"]() track = factories["music.Track"]()
expected = { expected = {
"id": track.id, "id": track.id,
@ -313,7 +315,7 @@ def test_manage_nested_track_serializer(factories, now):
"fid": track.fid, "fid": track.fid,
"title": track.title, "title": track.title,
"mbid": track.mbid, "mbid": track.mbid,
"creation_date": track.creation_date.isoformat().split("+")[0] + "Z", "creation_date": to_api_date(track.creation_date),
"position": track.position, "position": track.position,
"disc_number": track.disc_number, "disc_number": track.disc_number,
"copyright": track.copyright, "copyright": track.copyright,
@ -324,7 +326,7 @@ def test_manage_nested_track_serializer(factories, now):
assert s.data == expected assert s.data == expected
def test_manage_nested_album_serializer(factories, now): def test_manage_nested_album_serializer(factories, now, to_api_date):
album = factories["music.Album"]() album = factories["music.Album"]()
setattr(album, "tracks_count", 44) setattr(album, "tracks_count", 44)
expected = { expected = {
@ -334,7 +336,7 @@ def test_manage_nested_album_serializer(factories, now):
"fid": album.fid, "fid": album.fid,
"title": album.title, "title": album.title,
"mbid": album.mbid, "mbid": album.mbid,
"creation_date": album.creation_date.isoformat().split("+")[0] + "Z", "creation_date": to_api_date(album.creation_date),
"release_date": album.release_date.isoformat(), "release_date": album.release_date.isoformat(),
"cover": { "cover": {
"original": album.cover.url, "original": album.cover.url,
@ -349,7 +351,7 @@ def test_manage_nested_album_serializer(factories, now):
assert s.data == expected assert s.data == expected
def test_manage_nested_artist_serializer(factories, now): def test_manage_nested_artist_serializer(factories, now, to_api_date):
artist = factories["music.Artist"]() artist = factories["music.Artist"]()
expected = { expected = {
"id": artist.id, "id": artist.id,
@ -358,14 +360,14 @@ def test_manage_nested_artist_serializer(factories, now):
"fid": artist.fid, "fid": artist.fid,
"name": artist.name, "name": artist.name,
"mbid": artist.mbid, "mbid": artist.mbid,
"creation_date": artist.creation_date.isoformat().split("+")[0] + "Z", "creation_date": to_api_date(artist.creation_date),
} }
s = serializers.ManageNestedArtistSerializer(artist) s = serializers.ManageNestedArtistSerializer(artist)
assert s.data == expected assert s.data == expected
def test_manage_album_serializer(factories, now): def test_manage_album_serializer(factories, now, to_api_date):
album = factories["music.Album"](attributed=True) album = factories["music.Album"](attributed=True)
track = factories["music.Track"](album=album) track = factories["music.Track"](album=album)
expected = { expected = {
@ -375,7 +377,7 @@ def test_manage_album_serializer(factories, now):
"fid": album.fid, "fid": album.fid,
"title": album.title, "title": album.title,
"mbid": album.mbid, "mbid": album.mbid,
"creation_date": album.creation_date.isoformat().split("+")[0] + "Z", "creation_date": to_api_date(album.creation_date),
"release_date": album.release_date.isoformat(), "release_date": album.release_date.isoformat(),
"cover": { "cover": {
"original": album.cover.url, "original": album.cover.url,
@ -395,7 +397,7 @@ def test_manage_album_serializer(factories, now):
assert s.data == expected assert s.data == expected
def test_manage_track_serializer(factories, now): def test_manage_track_serializer(factories, now, to_api_date):
track = factories["music.Track"](attributed=True) track = factories["music.Track"](attributed=True)
setattr(track, "uploads_count", 44) setattr(track, "uploads_count", 44)
expected = { expected = {
@ -409,7 +411,7 @@ def test_manage_track_serializer(factories, now):
"position": track.position, "position": track.position,
"copyright": track.copyright, "copyright": track.copyright,
"license": track.license, "license": track.license,
"creation_date": track.creation_date.isoformat().split("+")[0] + "Z", "creation_date": to_api_date(track.creation_date),
"artist": serializers.ManageNestedArtistSerializer(track.artist).data, "artist": serializers.ManageNestedArtistSerializer(track.artist).data,
"album": serializers.ManageTrackAlbumSerializer(track.album).data, "album": serializers.ManageTrackAlbumSerializer(track.album).data,
"attributed_to": serializers.ManageBaseActorSerializer( "attributed_to": serializers.ManageBaseActorSerializer(
@ -423,7 +425,7 @@ def test_manage_track_serializer(factories, now):
assert s.data == expected assert s.data == expected
def test_manage_library_serializer(factories, now): def test_manage_library_serializer(factories, now, to_api_date):
library = factories["music.Library"]() library = factories["music.Library"]()
setattr(library, "followers_count", 42) setattr(library, "followers_count", 42)
setattr(library, "_uploads_count", 44) setattr(library, "_uploads_count", 44)
@ -438,7 +440,7 @@ def test_manage_library_serializer(factories, now):
"name": library.name, "name": library.name,
"description": library.description, "description": library.description,
"privacy_level": library.privacy_level, "privacy_level": library.privacy_level,
"creation_date": library.creation_date.isoformat().split("+")[0] + "Z", "creation_date": to_api_date(library.creation_date),
"actor": serializers.ManageBaseActorSerializer(library.actor).data, "actor": serializers.ManageBaseActorSerializer(library.actor).data,
"uploads_count": 44, "uploads_count": 44,
"followers_count": 42, "followers_count": 42,
@ -448,7 +450,7 @@ def test_manage_library_serializer(factories, now):
assert s.data == expected assert s.data == expected
def test_manage_upload_serializer(factories, now): def test_manage_upload_serializer(factories, now, to_api_date):
upload = factories["music.Upload"]() upload = factories["music.Upload"]()
expected = { expected = {
@ -466,8 +468,8 @@ def test_manage_upload_serializer(factories, now):
"source": upload.source, "source": upload.source,
"filename": upload.filename, "filename": upload.filename,
"metadata": upload.metadata, "metadata": upload.metadata,
"creation_date": upload.creation_date.isoformat().split("+")[0] + "Z", "creation_date": to_api_date(upload.creation_date),
"modification_date": upload.modification_date.isoformat().split("+")[0] + "Z", "modification_date": to_api_date(upload.modification_date),
"accessed_date": None, "accessed_date": None,
"import_date": None, "import_date": None,
"import_metadata": upload.import_metadata, "import_metadata": upload.import_metadata,
@ -502,7 +504,7 @@ def test_action_serializer_delete(factory, serializer_class, factories):
assert objects[0].__class__.objects.count() == 0 assert objects[0].__class__.objects.count() == 0
def test_manage_tag_serializer(factories): def test_manage_tag_serializer(factories, to_api_date):
tag = factories["tags.Tag"]() tag = factories["tags.Tag"]()
setattr(tag, "_tracks_count", 42) setattr(tag, "_tracks_count", 42)
@ -511,7 +513,7 @@ def test_manage_tag_serializer(factories):
expected = { expected = {
"id": tag.id, "id": tag.id,
"name": tag.name, "name": tag.name,
"creation_date": tag.creation_date.isoformat().split("+")[0] + "Z", "creation_date": to_api_date(tag.creation_date),
"tracks_count": 42, "tracks_count": 42,
"albums_count": 54, "albums_count": 54,
"artists_count": 66, "artists_count": 66,

View File

@ -118,7 +118,7 @@ def test_upload_serializer(factories, to_api_date):
"bitrate": upload.bitrate, "bitrate": upload.bitrate,
"size": upload.size, "size": upload.size,
"library": serializers.LibraryForOwnerSerializer(upload.library).data, "library": serializers.LibraryForOwnerSerializer(upload.library).data,
"creation_date": upload.creation_date.isoformat().split("+")[0] + "Z", "creation_date": to_api_date(upload.creation_date),
"import_date": None, "import_date": None,
"import_status": "pending", "import_status": "pending",
} }
@ -145,7 +145,7 @@ def test_upload_owner_serializer(factories, to_api_date):
"bitrate": upload.bitrate, "bitrate": upload.bitrate,
"size": upload.size, "size": upload.size,
"library": serializers.LibraryForOwnerSerializer(upload.library).data, "library": serializers.LibraryForOwnerSerializer(upload.library).data,
"creation_date": upload.creation_date.isoformat().split("+")[0] + "Z", "creation_date": to_api_date(upload.creation_date),
"metadata": {"test": "metadata"}, "metadata": {"test": "metadata"},
"import_metadata": {"import": "metadata"}, "import_metadata": {"import": "metadata"},
"import_date": None, "import_date": None,

View File

@ -29,7 +29,7 @@ def test_create_artist_radio(factories):
assert session.related_object == artist assert session.related_object == artist
def test_tag_radio_repr(factories): def test_tag_radio_repr(factories, to_api_date):
tag = factories["tags.Tag"]() tag = factories["tags.Tag"]()
session = factories["radios.RadioSession"](related_object=tag, radio_type="tag") session = factories["radios.RadioSession"](related_object=tag, radio_type="tag")
@ -39,6 +39,6 @@ def test_tag_radio_repr(factories):
"custom_radio": None, "custom_radio": None,
"user": session.user.pk, "user": session.user.pk,
"related_object_id": tag.name, "related_object_id": tag.name,
"creation_date": session.creation_date.isoformat().split("+")[0] + "Z", "creation_date": to_api_date(session.creation_date),
} }
assert serializers.RadioSessionSerializer(session).data == expected assert serializers.RadioSessionSerializer(session).data == expected

View File

@ -3,15 +3,12 @@ import pytest
from funkwhale_api.tags import serializers from funkwhale_api.tags import serializers
def test_tag_serializer(factories): def test_tag_serializer(factories, to_api_date):
tag = factories["tags.Tag"]() tag = factories["tags.Tag"]()
serializer = serializers.TagSerializer(tag) serializer = serializers.TagSerializer(tag)
expected = { expected = {"name": tag.name, "creation_date": to_api_date(tag.creation_date)}
"name": tag.name,
"creation_date": tag.creation_date.isoformat().split("+")[0] + "Z",
}
assert serializer.data == expected assert serializer.data == expected

View File

@ -0,0 +1,6 @@
from . import utils as test_utils
def test_to_api_date(now):
assert test_utils.to_api_date(now) == now.isoformat().split("+")[0] + "Z"

12
api/tests/utils.py Normal file
View File

@ -0,0 +1,12 @@
import datetime
from rest_framework import fields as rest_fields
def to_api_date(value):
if isinstance(value, datetime.datetime):
f = rest_fields.DateTimeField()
return f.to_representation(value)
if isinstance(value, datetime.date):
f = rest_fields.DateField()
return f.to_representation(value)
raise ValueError("Invalid value: {}".format(value))