Replaced model_mummy with factory_boy
This commit is contained in:
parent
a6d04ea1d7
commit
e9c3eb59a3
|
@ -0,0 +1,12 @@
|
||||||
|
import factory
|
||||||
|
from funkwhale_api.music.tests import factories
|
||||||
|
|
||||||
|
from funkwhale_api.users.tests.factories import UserFactory
|
||||||
|
|
||||||
|
|
||||||
|
class ListeningFactory(factory.django.DjangoModelFactory):
|
||||||
|
user = factory.SubFactory(UserFactory)
|
||||||
|
track = factory.SubFactory(factories.TrackFactory)
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
model = 'history.Listening'
|
|
@ -5,11 +5,12 @@ from django.core.urlresolvers import reverse
|
||||||
from django.core.exceptions import ValidationError
|
from django.core.exceptions import ValidationError
|
||||||
from django.utils import timezone
|
from django.utils import timezone
|
||||||
|
|
||||||
from model_mommy import mommy
|
from funkwhale_api.music.tests.factories import TrackFactory
|
||||||
|
|
||||||
from funkwhale_api.users.models import User
|
from funkwhale_api.users.models import User
|
||||||
from funkwhale_api.history import models
|
from funkwhale_api.history import models
|
||||||
|
|
||||||
|
|
||||||
class TestHistory(TestCase):
|
class TestHistory(TestCase):
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
|
@ -17,12 +18,12 @@ class TestHistory(TestCase):
|
||||||
self.user = User.objects.create_user(username='test', email='test@test.com', password='test')
|
self.user = User.objects.create_user(username='test', email='test@test.com', password='test')
|
||||||
|
|
||||||
def test_can_create_listening(self):
|
def test_can_create_listening(self):
|
||||||
track = mommy.make('music.Track')
|
track = TrackFactory()
|
||||||
now = timezone.now()
|
now = timezone.now()
|
||||||
l = models.Listening.objects.create(user=self.user, track=track)
|
l = models.Listening.objects.create(user=self.user, track=track)
|
||||||
|
|
||||||
def test_anonymous_user_can_create_listening_via_api(self):
|
def test_anonymous_user_can_create_listening_via_api(self):
|
||||||
track = mommy.make('music.Track')
|
track = TrackFactory()
|
||||||
url = self.reverse('api:v1:history:listenings-list')
|
url = self.reverse('api:v1:history:listenings-list')
|
||||||
response = self.client.post(url, {
|
response = self.client.post(url, {
|
||||||
'track': track.pk,
|
'track': track.pk,
|
||||||
|
@ -34,7 +35,7 @@ class TestHistory(TestCase):
|
||||||
self.assertIsNotNone(listening.session_key)
|
self.assertIsNotNone(listening.session_key)
|
||||||
|
|
||||||
def test_logged_in_user_can_create_listening_via_api(self):
|
def test_logged_in_user_can_create_listening_via_api(self):
|
||||||
track = mommy.make('music.Track')
|
track = TrackFactory()
|
||||||
|
|
||||||
self.client.login(username=self.user.username, password='test')
|
self.client.login(username=self.user.username, password='test')
|
||||||
|
|
||||||
|
|
|
@ -59,3 +59,30 @@ class ImportJobFactory(factory.django.DjangoModelFactory):
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
model = 'music.ImportJob'
|
model = 'music.ImportJob'
|
||||||
|
|
||||||
|
|
||||||
|
class WorkFactory(factory.django.DjangoModelFactory):
|
||||||
|
mbid = factory.Faker('uuid4')
|
||||||
|
language = 'eng'
|
||||||
|
nature = 'song'
|
||||||
|
title = factory.Faker('sentence', nb_words=3)
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
model = 'music.Work'
|
||||||
|
|
||||||
|
|
||||||
|
class LyricsFactory(factory.django.DjangoModelFactory):
|
||||||
|
work = factory.SubFactory(WorkFactory)
|
||||||
|
url = factory.Faker('url')
|
||||||
|
content = factory.Faker('paragraphs', nb=4)
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
model = 'music.Lyrics'
|
||||||
|
|
||||||
|
|
||||||
|
class TagFactory(factory.django.DjangoModelFactory):
|
||||||
|
name = factory.SelfAttribute('slug')
|
||||||
|
slug = factory.Faker('slug')
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
model = 'taggit.Tag'
|
||||||
|
|
|
@ -2,24 +2,25 @@ import json
|
||||||
import unittest
|
import unittest
|
||||||
from test_plus.test import TestCase
|
from test_plus.test import TestCase
|
||||||
from django.core.urlresolvers import reverse
|
from django.core.urlresolvers import reverse
|
||||||
from model_mommy import mommy
|
|
||||||
|
|
||||||
from funkwhale_api.music import models
|
from funkwhale_api.music import models
|
||||||
from funkwhale_api.musicbrainz import api
|
from funkwhale_api.musicbrainz import api
|
||||||
from funkwhale_api.music import serializers
|
from funkwhale_api.music import serializers
|
||||||
from funkwhale_api.users.models import User
|
from funkwhale_api.users.models import User
|
||||||
|
from funkwhale_api.music import lyrics as lyrics_utils
|
||||||
|
|
||||||
from .mocking import lyricswiki
|
from .mocking import lyricswiki
|
||||||
|
from . import factories
|
||||||
from . import data as api_data
|
from . import data as api_data
|
||||||
from funkwhale_api.music import lyrics as lyrics_utils
|
|
||||||
|
|
||||||
|
|
||||||
class TestLyrics(TestCase):
|
class TestLyrics(TestCase):
|
||||||
|
|
||||||
@unittest.mock.patch('funkwhale_api.music.lyrics._get_html',
|
@unittest.mock.patch('funkwhale_api.music.lyrics._get_html',
|
||||||
return_value=lyricswiki.content)
|
return_value=lyricswiki.content)
|
||||||
def test_works_import_lyrics_if_any(self, *mocks):
|
def test_works_import_lyrics_if_any(self, *mocks):
|
||||||
lyrics = mommy.make(
|
lyrics = factories.LyricsFactory(
|
||||||
models.Lyrics,
|
|
||||||
url='http://lyrics.wikia.com/System_Of_A_Down:Chop_Suey!')
|
url='http://lyrics.wikia.com/System_Of_A_Down:Chop_Suey!')
|
||||||
|
|
||||||
lyrics.fetch_content()
|
lyrics.fetch_content()
|
||||||
|
@ -42,7 +43,7 @@ Is it me you're looking for?
|
||||||
content = """Hello
|
content = """Hello
|
||||||
Is it me you're looking for?"""
|
Is it me you're looking for?"""
|
||||||
|
|
||||||
l = mommy.make(models.Lyrics, content=content)
|
l = factories.LyricsFactory(content=content)
|
||||||
|
|
||||||
expected = "<p>Hello<br />Is it me you're looking for?</p>"
|
expected = "<p>Hello<br />Is it me you're looking for?</p>"
|
||||||
self.assertHTMLEqual(expected, l.content_rendered)
|
self.assertHTMLEqual(expected, l.content_rendered)
|
||||||
|
@ -54,8 +55,7 @@ Is it me you're looking for?"""
|
||||||
@unittest.mock.patch('funkwhale_api.music.lyrics._get_html',
|
@unittest.mock.patch('funkwhale_api.music.lyrics._get_html',
|
||||||
return_value=lyricswiki.content)
|
return_value=lyricswiki.content)
|
||||||
def test_works_import_lyrics_if_any(self, *mocks):
|
def test_works_import_lyrics_if_any(self, *mocks):
|
||||||
track = mommy.make(
|
track = factories.TrackFactory(
|
||||||
models.Track,
|
|
||||||
work=None,
|
work=None,
|
||||||
mbid='07ca77cf-f513-4e9c-b190-d7e24bbad448')
|
mbid='07ca77cf-f513-4e9c-b190-d7e24bbad448')
|
||||||
|
|
||||||
|
|
|
@ -2,13 +2,11 @@ from test_plus.test import TestCase
|
||||||
import unittest.mock
|
import unittest.mock
|
||||||
from funkwhale_api.music import models
|
from funkwhale_api.music import models
|
||||||
import datetime
|
import datetime
|
||||||
from model_mommy import mommy
|
|
||||||
|
from . import factories
|
||||||
from . import data as api_data
|
from . import data as api_data
|
||||||
from .cover import binary_data
|
from .cover import binary_data
|
||||||
|
|
||||||
def prettyprint(d):
|
|
||||||
import json
|
|
||||||
print(json.dumps(d, sort_keys=True, indent=4))
|
|
||||||
|
|
||||||
class TestMusic(TestCase):
|
class TestMusic(TestCase):
|
||||||
|
|
||||||
|
@ -79,9 +77,9 @@ class TestMusic(TestCase):
|
||||||
self.assertEqual(track, track2)
|
self.assertEqual(track, track2)
|
||||||
|
|
||||||
def test_album_tags_deduced_from_tracks_tags(self):
|
def test_album_tags_deduced_from_tracks_tags(self):
|
||||||
tag = mommy.make('taggit.Tag')
|
tag = factories.TagFactory()
|
||||||
album = mommy.make('music.Album')
|
album = factories.AlbumFactory()
|
||||||
tracks = mommy.make('music.Track', album=album, _quantity=5)
|
tracks = factories.TrackFactory.create_batch(album=album, size=5)
|
||||||
|
|
||||||
for track in tracks:
|
for track in tracks:
|
||||||
track.tags.add(tag)
|
track.tags.add(tag)
|
||||||
|
@ -92,10 +90,10 @@ class TestMusic(TestCase):
|
||||||
self.assertIn(tag, album.tags)
|
self.assertIn(tag, album.tags)
|
||||||
|
|
||||||
def test_artist_tags_deduced_from_album_tags(self):
|
def test_artist_tags_deduced_from_album_tags(self):
|
||||||
tag = mommy.make('taggit.Tag')
|
tag = factories.TagFactory()
|
||||||
artist = mommy.make('music.Artist')
|
artist = factories.ArtistFactory()
|
||||||
album = mommy.make('music.Album', artist=artist)
|
album = factories.AlbumFactory(artist=artist)
|
||||||
tracks = mommy.make('music.Track', album=album, _quantity=5)
|
tracks = factories.TrackFactory.create_batch(album=album, size=5)
|
||||||
|
|
||||||
for track in tracks:
|
for track in tracks:
|
||||||
track.tags.add(tag)
|
track.tags.add(tag)
|
||||||
|
@ -108,7 +106,7 @@ class TestMusic(TestCase):
|
||||||
@unittest.mock.patch('funkwhale_api.musicbrainz.api.images.get_front', return_value=binary_data)
|
@unittest.mock.patch('funkwhale_api.musicbrainz.api.images.get_front', return_value=binary_data)
|
||||||
def test_can_download_image_file_for_album(self, *mocks):
|
def test_can_download_image_file_for_album(self, *mocks):
|
||||||
# client._api.get_image_front('55ea4f82-b42b-423e-a0e5-290ccdf443ed')
|
# client._api.get_image_front('55ea4f82-b42b-423e-a0e5-290ccdf443ed')
|
||||||
album = mommy.make('music.Album', mbid='55ea4f82-b42b-423e-a0e5-290ccdf443ed')
|
album = factories.AlbumFactory(mbid='55ea4f82-b42b-423e-a0e5-290ccdf443ed')
|
||||||
album.get_image()
|
album.get_image()
|
||||||
album.save()
|
album.save()
|
||||||
|
|
||||||
|
|
|
@ -2,22 +2,23 @@ import json
|
||||||
import unittest
|
import unittest
|
||||||
from test_plus.test import TestCase
|
from test_plus.test import TestCase
|
||||||
from django.core.urlresolvers import reverse
|
from django.core.urlresolvers import reverse
|
||||||
from model_mommy import mommy
|
|
||||||
|
|
||||||
from funkwhale_api.music import models
|
from funkwhale_api.music import models
|
||||||
from funkwhale_api.musicbrainz import api
|
from funkwhale_api.musicbrainz import api
|
||||||
from funkwhale_api.music import serializers
|
from funkwhale_api.music import serializers
|
||||||
|
from funkwhale_api.music.tests import factories
|
||||||
from funkwhale_api.users.models import User
|
from funkwhale_api.users.models import User
|
||||||
|
|
||||||
from . import data as api_data
|
from . import data as api_data
|
||||||
|
|
||||||
|
|
||||||
class TestWorks(TestCase):
|
class TestWorks(TestCase):
|
||||||
|
|
||||||
@unittest.mock.patch('funkwhale_api.musicbrainz.api.works.get',
|
@unittest.mock.patch('funkwhale_api.musicbrainz.api.works.get',
|
||||||
return_value=api_data.works['get']['chop_suey'])
|
return_value=api_data.works['get']['chop_suey'])
|
||||||
def test_can_import_work(self, *mocks):
|
def test_can_import_work(self, *mocks):
|
||||||
recording = mommy.make(
|
recording = factories.TrackFactory(
|
||||||
models.Track, mbid='07ca77cf-f513-4e9c-b190-d7e24bbad448')
|
mbid='07ca77cf-f513-4e9c-b190-d7e24bbad448')
|
||||||
mbid = 'e2ecabc4-1b9d-30b2-8f30-3596ec423dc5'
|
mbid = 'e2ecabc4-1b9d-30b2-8f30-3596ec423dc5'
|
||||||
work = models.Work.create_from_api(id=mbid)
|
work = models.Work.create_from_api(id=mbid)
|
||||||
|
|
||||||
|
@ -36,8 +37,7 @@ class TestWorks(TestCase):
|
||||||
@unittest.mock.patch('funkwhale_api.musicbrainz.api.recordings.get',
|
@unittest.mock.patch('funkwhale_api.musicbrainz.api.recordings.get',
|
||||||
return_value=api_data.tracks['get']['chop_suey'])
|
return_value=api_data.tracks['get']['chop_suey'])
|
||||||
def test_can_get_work_from_recording(self, *mocks):
|
def test_can_get_work_from_recording(self, *mocks):
|
||||||
recording = mommy.make(
|
recording = factories.TrackFactory(
|
||||||
models.Track,
|
|
||||||
work=None,
|
work=None,
|
||||||
mbid='07ca77cf-f513-4e9c-b190-d7e24bbad448')
|
mbid='07ca77cf-f513-4e9c-b190-d7e24bbad448')
|
||||||
mbid = 'e2ecabc4-1b9d-30b2-8f30-3596ec423dc5'
|
mbid = 'e2ecabc4-1b9d-30b2-8f30-3596ec423dc5'
|
||||||
|
|
|
@ -4,8 +4,7 @@ from django.core.urlresolvers import reverse
|
||||||
from django.core.exceptions import ValidationError
|
from django.core.exceptions import ValidationError
|
||||||
from django.utils import timezone
|
from django.utils import timezone
|
||||||
|
|
||||||
from model_mommy import mommy
|
from funkwhale_api.music.tests import factories
|
||||||
|
|
||||||
from funkwhale_api.users.models import User
|
from funkwhale_api.users.models import User
|
||||||
from funkwhale_api.playlists import models
|
from funkwhale_api.playlists import models
|
||||||
from funkwhale_api.playlists.serializers import PlaylistSerializer
|
from funkwhale_api.playlists.serializers import PlaylistSerializer
|
||||||
|
@ -18,7 +17,7 @@ class TestPlayLists(TestCase):
|
||||||
self.user = User.objects.create_user(username='test', email='test@test.com', password='test')
|
self.user = User.objects.create_user(username='test', email='test@test.com', password='test')
|
||||||
|
|
||||||
def test_can_create_playlist(self):
|
def test_can_create_playlist(self):
|
||||||
tracks = list(mommy.make('music.Track', _quantity=5))
|
tracks = factories.TrackFactory.create_batch(size=5)
|
||||||
playlist = models.Playlist.objects.create(user=self.user, name="test")
|
playlist = models.Playlist.objects.create(user=self.user, name="test")
|
||||||
|
|
||||||
previous = None
|
previous = None
|
||||||
|
@ -49,7 +48,7 @@ class TestPlayLists(TestCase):
|
||||||
self.assertEqual(playlist.name, 'test')
|
self.assertEqual(playlist.name, 'test')
|
||||||
|
|
||||||
def test_can_add_playlist_track_via_api(self):
|
def test_can_add_playlist_track_via_api(self):
|
||||||
tracks = list(mommy.make('music.Track', _quantity=5))
|
tracks = factories.TrackFactory.create_batch(size=5)
|
||||||
playlist = models.Playlist.objects.create(user=self.user, name="test")
|
playlist = models.Playlist.objects.create(user=self.user, name="test")
|
||||||
|
|
||||||
self.client.login(username=self.user.username, password='test')
|
self.client.login(username=self.user.username, password='test')
|
||||||
|
|
|
@ -4,13 +4,15 @@ from test_plus.test import TestCase
|
||||||
from django.core.urlresolvers import reverse
|
from django.core.urlresolvers import reverse
|
||||||
from django.core.exceptions import ValidationError
|
from django.core.exceptions import ValidationError
|
||||||
|
|
||||||
from model_mommy import mommy
|
|
||||||
|
|
||||||
from funkwhale_api.radios import radios
|
from funkwhale_api.radios import radios
|
||||||
from funkwhale_api.radios import models
|
from funkwhale_api.radios import models
|
||||||
from funkwhale_api.favorites.models import TrackFavorite
|
from funkwhale_api.favorites.models import TrackFavorite
|
||||||
from funkwhale_api.users.models import User
|
from funkwhale_api.users.models import User
|
||||||
from funkwhale_api.music.models import Artist
|
from funkwhale_api.music.models import Artist
|
||||||
|
from funkwhale_api.music.tests import factories
|
||||||
|
from funkwhale_api.history.tests.factories import ListeningFactory
|
||||||
|
|
||||||
|
|
||||||
class TestRadios(TestCase):
|
class TestRadios(TestCase):
|
||||||
|
|
||||||
|
@ -55,7 +57,7 @@ class TestRadios(TestCase):
|
||||||
self.assertTrue(picks[2] > picks[1])
|
self.assertTrue(picks[2] > picks[1])
|
||||||
|
|
||||||
def test_can_get_choices_for_favorites_radio(self):
|
def test_can_get_choices_for_favorites_radio(self):
|
||||||
tracks = mommy.make('music.Track', _quantity=100)
|
tracks = factories.TrackFactory.create_batch(size=100)
|
||||||
|
|
||||||
for i in range(20):
|
for i in range(20):
|
||||||
TrackFavorite.add(track=random.choice(tracks), user=self.user)
|
TrackFavorite.add(track=random.choice(tracks), user=self.user)
|
||||||
|
@ -73,7 +75,7 @@ class TestRadios(TestCase):
|
||||||
self.assertIn(pick, choices)
|
self.assertIn(pick, choices)
|
||||||
|
|
||||||
def test_can_use_radio_session_to_filter_choices(self):
|
def test_can_use_radio_session_to_filter_choices(self):
|
||||||
tracks = mommy.make('music.Track', _quantity=30)
|
tracks = factories.TrackFactory.create_batch(size=30)
|
||||||
radio = radios.RandomRadio()
|
radio = radios.RandomRadio()
|
||||||
session = radio.start_session(self.user)
|
session = radio.start_session(self.user)
|
||||||
|
|
||||||
|
@ -85,7 +87,7 @@ class TestRadios(TestCase):
|
||||||
self.assertEqual(len(set(tracks_id)), 30)
|
self.assertEqual(len(set(tracks_id)), 30)
|
||||||
|
|
||||||
def test_can_restore_radio_from_previous_session(self):
|
def test_can_restore_radio_from_previous_session(self):
|
||||||
tracks = mommy.make('music.Track', _quantity=30)
|
tracks = factories.TrackFactory.create_batch(size=30)
|
||||||
|
|
||||||
radio = radios.RandomRadio()
|
radio = radios.RandomRadio()
|
||||||
session = radio.start_session(self.user)
|
session = radio.start_session(self.user)
|
||||||
|
@ -115,7 +117,7 @@ class TestRadios(TestCase):
|
||||||
self.assertIsNotNone(session.session_key)
|
self.assertIsNotNone(session.session_key)
|
||||||
|
|
||||||
def test_can_get_track_for_session_from_api(self):
|
def test_can_get_track_for_session_from_api(self):
|
||||||
tracks = mommy.make('music.Track', _quantity=1)
|
tracks = factories.TrackFactory.create_batch(size=1)
|
||||||
|
|
||||||
self.client.login(username=self.user.username, password='test')
|
self.client.login(username=self.user.username, password='test')
|
||||||
url = reverse('api:v1:radios:sessions-list')
|
url = reverse('api:v1:radios:sessions-list')
|
||||||
|
@ -129,7 +131,7 @@ class TestRadios(TestCase):
|
||||||
self.assertEqual(data['track']['id'], tracks[0].id)
|
self.assertEqual(data['track']['id'], tracks[0].id)
|
||||||
self.assertEqual(data['position'], 1)
|
self.assertEqual(data['position'], 1)
|
||||||
|
|
||||||
next_track = mommy.make('music.Track')
|
next_track = factories.TrackFactory()
|
||||||
response = self.client.post(url, {'session': session.pk})
|
response = self.client.post(url, {'session': session.pk})
|
||||||
data = json.loads(response.content.decode('utf-8'))
|
data = json.loads(response.content.decode('utf-8'))
|
||||||
|
|
||||||
|
@ -148,9 +150,10 @@ class TestRadios(TestCase):
|
||||||
radio.start_session(self.user, related_object=self.user)
|
radio.start_session(self.user, related_object=self.user)
|
||||||
|
|
||||||
def test_can_start_artist_radio(self):
|
def test_can_start_artist_radio(self):
|
||||||
artist = mommy.make('music.Artist')
|
artist = factories.ArtistFactory()
|
||||||
wrong_tracks = mommy.make('music.Track', _quantity=30)
|
wrong_tracks = factories.TrackFactory.create_batch(size=30)
|
||||||
good_tracks = mommy.make('music.Track', artist=artist, _quantity=5)
|
good_tracks = factories.TrackFactory.create_batch(
|
||||||
|
artist=artist, size=5)
|
||||||
|
|
||||||
radio = radios.ArtistRadio()
|
radio = radios.ArtistRadio()
|
||||||
session = radio.start_session(self.user, related_object=artist)
|
session = radio.start_session(self.user, related_object=artist)
|
||||||
|
@ -159,9 +162,9 @@ class TestRadios(TestCase):
|
||||||
self.assertIn(radio.pick(), good_tracks)
|
self.assertIn(radio.pick(), good_tracks)
|
||||||
|
|
||||||
def test_can_start_tag_radio(self):
|
def test_can_start_tag_radio(self):
|
||||||
tag = mommy.make('taggit.Tag')
|
tag = factories.TagFactory()
|
||||||
wrong_tracks = mommy.make('music.Track', _quantity=30)
|
wrong_tracks = factories.TrackFactory.create_batch(size=30)
|
||||||
good_tracks = mommy.make('music.Track', _quantity=5)
|
good_tracks = factories.TrackFactory.create_batch(size=5)
|
||||||
for track in good_tracks:
|
for track in good_tracks:
|
||||||
track.tags.add(tag)
|
track.tags.add(tag)
|
||||||
|
|
||||||
|
@ -172,7 +175,7 @@ class TestRadios(TestCase):
|
||||||
self.assertIn(radio.pick(), good_tracks)
|
self.assertIn(radio.pick(), good_tracks)
|
||||||
|
|
||||||
def test_can_start_artist_radio_from_api(self):
|
def test_can_start_artist_radio_from_api(self):
|
||||||
artist = mommy.make('music.Artist')
|
artist = factories.ArtistFactory()
|
||||||
url = reverse('api:v1:radios:sessions-list')
|
url = reverse('api:v1:radios:sessions-list')
|
||||||
|
|
||||||
response = self.client.post(url, {'radio_type': 'artist', 'related_object_id': artist.id})
|
response = self.client.post(url, {'radio_type': 'artist', 'related_object_id': artist.id})
|
||||||
|
@ -181,10 +184,10 @@ class TestRadios(TestCase):
|
||||||
self.assertEqual(session.related_object, artist)
|
self.assertEqual(session.related_object, artist)
|
||||||
|
|
||||||
def test_can_start_less_listened_radio(self):
|
def test_can_start_less_listened_radio(self):
|
||||||
history = mommy.make('history.Listening', _quantity=5, user=self.user)
|
history = ListeningFactory.create_batch(size=5, user=self.user)
|
||||||
wrong_tracks = [h.track for h in history]
|
wrong_tracks = [h.track for h in history]
|
||||||
|
|
||||||
good_tracks = mommy.make('music.Track', _quantity=30)
|
good_tracks = factories.TrackFactory.create_batch(size=30)
|
||||||
|
|
||||||
radio = radios.LessListenedRadio()
|
radio = radios.LessListenedRadio()
|
||||||
session = radio.start_session(self.user)
|
session = radio.start_session(self.user)
|
||||||
|
|
|
@ -3,7 +3,6 @@
|
||||||
|
|
||||||
|
|
||||||
flake8==2.5.0
|
flake8==2.5.0
|
||||||
model-mommy==1.3.2
|
|
||||||
pytest
|
pytest
|
||||||
pytest-django
|
pytest-django
|
||||||
pytest-mock
|
pytest-mock
|
||||||
|
|
Loading…
Reference in New Issue