mirror of
https://github.com/spl0k/supysonic.git
synced 2024-11-10 04:02:17 +00:00
parent
306fc202bd
commit
8132e38d46
@ -13,7 +13,7 @@ import uuid
|
|||||||
from pony.orm import select
|
from pony.orm import select
|
||||||
from pony.orm import ObjectNotFound
|
from pony.orm import ObjectNotFound
|
||||||
|
|
||||||
from ..db import Folder, Track, Artist, Album
|
from ..db import Folder, Track, Artist, Album, User, RatingTrack, StarredTrack
|
||||||
from ..py23 import strtype
|
from ..py23 import strtype
|
||||||
|
|
||||||
class FolderManager:
|
class FolderManager:
|
||||||
@ -51,6 +51,11 @@ class FolderManager:
|
|||||||
if not folder.root:
|
if not folder.root:
|
||||||
raise ObjectNotFound(Folder)
|
raise ObjectNotFound(Folder)
|
||||||
|
|
||||||
|
for user in User.select(lambda u: u.last_play.root_folder == folder):
|
||||||
|
user.last_play = None
|
||||||
|
RatingTrack.select(lambda r: r.rated.root_folder == folder).delete(bulk = True)
|
||||||
|
StarredTrack.select(lambda s: s.starred.root_folder == folder).delete(bulk = True)
|
||||||
|
|
||||||
Track.select(lambda t: t.root_folder == folder).delete(bulk = True)
|
Track.select(lambda t: t.root_folder == folder).delete(bulk = True)
|
||||||
Album.prune()
|
Album.prune()
|
||||||
Artist.prune()
|
Artist.prune()
|
||||||
|
@ -16,6 +16,7 @@ from . import api
|
|||||||
from . import frontend
|
from . import frontend
|
||||||
|
|
||||||
from .issue101 import Issue101TestCase
|
from .issue101 import Issue101TestCase
|
||||||
|
from .issue129 import Issue129TestCase
|
||||||
|
|
||||||
def suite():
|
def suite():
|
||||||
suite = unittest.TestSuite()
|
suite = unittest.TestSuite()
|
||||||
@ -25,6 +26,7 @@ def suite():
|
|||||||
suite.addTest(api.suite())
|
suite.addTest(api.suite())
|
||||||
suite.addTest(frontend.suite())
|
suite.addTest(frontend.suite())
|
||||||
suite.addTest(unittest.makeSuite(Issue101TestCase))
|
suite.addTest(unittest.makeSuite(Issue101TestCase))
|
||||||
|
suite.addTest(unittest.makeSuite(Issue129TestCase))
|
||||||
|
|
||||||
return suite
|
return suite
|
||||||
|
|
||||||
|
52
tests/issue129.py
Normal file
52
tests/issue129.py
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
# coding: utf-8
|
||||||
|
#
|
||||||
|
# This file is part of Supysonic.
|
||||||
|
# Supysonic is a Python implementation of the Subsonic server API.
|
||||||
|
#
|
||||||
|
# Copyright (C) 2018 Alban 'spl0k' Féron
|
||||||
|
#
|
||||||
|
# Distributed under terms of the GNU AGPLv3 license.
|
||||||
|
|
||||||
|
import os.path
|
||||||
|
import unittest
|
||||||
|
|
||||||
|
from pony.orm import db_session
|
||||||
|
|
||||||
|
from supysonic.db import User, Track, StarredTrack, RatingTrack
|
||||||
|
from supysonic.managers.folder import FolderManager
|
||||||
|
from supysonic.scanner import Scanner
|
||||||
|
|
||||||
|
from .testbase import TestBase
|
||||||
|
|
||||||
|
class Issue129TestCase(TestBase):
|
||||||
|
def setUp(self):
|
||||||
|
super(Issue129TestCase, self).setUp()
|
||||||
|
|
||||||
|
with db_session:
|
||||||
|
folder = FolderManager.add('folder', os.path.abspath('tests/assets/folder'))
|
||||||
|
scanner = Scanner()
|
||||||
|
scanner.scan(folder)
|
||||||
|
scanner.finish()
|
||||||
|
|
||||||
|
self.trackid = Track.select().first().id
|
||||||
|
self.userid = User.get(name = 'alice').id
|
||||||
|
|
||||||
|
def test_last_play(self):
|
||||||
|
with db_session:
|
||||||
|
User[self.userid].last_play = Track[self.trackid]
|
||||||
|
with db_session:
|
||||||
|
FolderManager.delete_by_name('folder')
|
||||||
|
|
||||||
|
def test_starred(self):
|
||||||
|
with db_session:
|
||||||
|
StarredTrack(user = self.userid, starred = self.trackid)
|
||||||
|
FolderManager.delete_by_name('folder')
|
||||||
|
|
||||||
|
def test_rating(self):
|
||||||
|
with db_session:
|
||||||
|
RatingTrack(user = self.userid, rated = self.trackid, rating = 5)
|
||||||
|
FolderManager.delete_by_name('folder')
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
Loading…
Reference in New Issue
Block a user