diff options
author | Eddy Pedroni <epedroni@pm.me> | 2025-07-17 15:14:38 +0200 |
---|---|---|
committer | Eddy Pedroni <epedroni@pm.me> | 2025-07-17 15:24:48 +0200 |
commit | 8fdbcd3b98f5bf5479e2a67e40f5746b184908d3 (patch) | |
tree | 8366c7647a1874ea75aec4c2c8a9bdf60e9054fb /solo-tool-project | |
parent | 89dcddce5e215400150232befddebc83f45d64d8 (diff) |
Purge all mention of song pool
Diffstat (limited to 'solo-tool-project')
8 files changed, 27 insertions, 57 deletions
diff --git a/solo-tool-project/src/solo_tool/session_manager.py b/solo-tool-project/src/solo_tool/session_manager.py index bf6e218..2e99937 100644 --- a/solo-tool-project/src/solo_tool/session_manager.py +++ b/solo-tool-project/src/solo_tool/session_manager.py @@ -19,12 +19,8 @@ class SessionManager(Protocol): def saveSession(self, soloTool: SoloTool, key: str) -> None: raise NotImplementedError - @abstractmethod - def addSong(self, name: str, content: BinaryIO) -> None: - raise NotImplementedError - @staticmethod - def _dict2st(session: dict, songPool: str, player) -> SoloTool: + def _dict2st(session: dict, player) -> SoloTool: st = SoloTool(player=player) for i, entry in enumerate(session): @@ -48,8 +44,7 @@ class SessionManager(Protocol): return session class _FileSystemSessionManager(SessionManager): - def __init__(self, songPool: str, sessionPath: str): - self._songPool = Path(songPool) + def __init__(self, sessionPath: str): self._sessionPath = Path(sessionPath) def getSessions(self) -> list[str]: @@ -58,23 +53,16 @@ class _FileSystemSessionManager(SessionManager): def loadSession(self, key: str, player=None) -> SoloTool: with open(self._sessionPath / f"{key}.json", "r") as f: session = json.load(f) - return SessionManager._dict2st(session, self._songPool, player) + return SessionManager._dict2st(session, player) def saveSession(self, soloTool: SoloTool, key: str) -> None: session = SessionManager._st2dict(soloTool) with open(self._sessionPath / f"{key}.json", "w") as f: json.dump(session, f) - def addSong(self, name: str, content: BinaryIO) -> None: - from shutil import copyfileobj - newSong = self._songPool / name - with open(newSong, "wb") as f: - copyfileobj(content, f) - class _FileBrowserSessionManager(SessionManager): - def __init__(self, songPoolUrl: str, sessionUrl: str): + def __init__(self, sessionUrl: str): self._baseUrl = "https://files.0xf7.com" - self._songPool = songPoolUrl self._username = "solo-tool" self._password = "mwC0ML8vLpJLPCLHKuxkiOxtIaE" self._apiKey = self._getApiKey() @@ -89,23 +77,20 @@ class _FileBrowserSessionManager(SessionManager): url = f"{self._baseUrl}/api/raw/sessions/{key}.json" response = requests.get(url, headers={"X-Auth":self._apiKey}) response.raise_for_status() - return SessionManager._dict2st(json.loads(response.content), self._songPool, player=player) + return SessionManager._dict2st(json.loads(response.content), player=player) def saveSession(self, soloTool: SoloTool, key: str) -> None: pass - def addSong(self, name: str, content: BinaryIO) -> None: - pass - def _getApiKey(self) -> str: response = requests.post(f"{self._baseUrl}/api/login", json={"username":self._username, "password":self._password}) return response.content -def getSessionManager(songPool: str, sessionPath: str) -> SessionManager: +def getSessionManager(sessionPath: str) -> SessionManager: from re import search match = search(r"^([a-z0-9]+://)", sessionPath) if not match or match.group(0) == "file://": - return _FileSystemSessionManager(songPool, sessionPath) + return _FileSystemSessionManager(sessionPath) elif match.group(0) in ["http://", "https://"]: - return _FileBrowserSessionManager(songPool, sessionPath) + return _FileBrowserSessionManager(sessionPath) diff --git a/solo-tool-project/test/fixtures.py b/solo-tool-project/test/fixtures.py index 3306388..1f2299f 100644 --- a/solo-tool-project/test/fixtures.py +++ b/solo-tool-project/test/fixtures.py @@ -10,12 +10,6 @@ def mockPlayer(): return MockPlayer() @pytest.fixture -def songPool(tmp_path): - path = tmp_path / "songs" - os.mkdir(path) - return path - -@pytest.fixture def sessionPath(tmp_path): path = tmp_path / "sessions" os.mkdir(path) @@ -26,11 +20,13 @@ def soloTool(mockPlayer): return SoloTool(player=mockPlayer) @pytest.fixture -def testSongs(songPool): +def testSongs(tmp_path): + path = tmp_path / "songs" + os.mkdir(path) songs = [ - songPool / "test.flac", - songPool / "test.mp3", - songPool / "test.mp4" + path / "test.flac", + path / "test.mp3", + path / "test.mp4" ] for song in songs: diff --git a/solo-tool-project/test/handlers_integrationtest.py b/solo-tool-project/test/handlers_integrationtest.py index 85050d6..6696f86 100644 --- a/solo-tool-project/test/handlers_integrationtest.py +++ b/solo-tool-project/test/handlers_integrationtest.py @@ -1,6 +1,6 @@ import pytest -from fixtures import soloTool, testSongs, mockPlayer, songPool +from fixtures import soloTool, testSongs, mockPlayer from solo_tool.handlers import keyPointRelative diff --git a/solo-tool-project/test/midi_launchpad_mini_integrationtest.py b/solo-tool-project/test/midi_launchpad_mini_integrationtest.py index be8ed88..1a99cd4 100644 --- a/solo-tool-project/test/midi_launchpad_mini_integrationtest.py +++ b/solo-tool-project/test/midi_launchpad_mini_integrationtest.py @@ -2,7 +2,7 @@ import pytest from mido import Message from solo_tool.midi_controller_launchpad_mini import MidiController -from fixtures import songPool, soloTool, mockPlayer, testSongs +from fixtures import soloTool, mockPlayer, testSongs LED_RED = 3 LED_YELLOW = 126 diff --git a/solo-tool-project/test/session_manager_unittest.py b/solo-tool-project/test/session_manager_unittest.py index bb40fdf..690bec0 100644 --- a/solo-tool-project/test/session_manager_unittest.py +++ b/solo-tool-project/test/session_manager_unittest.py @@ -3,7 +3,7 @@ from json import loads import os from solo_tool.session_manager import getSessionManager, _FileSystemSessionManager, _FileBrowserSessionManager -from fixtures import songPool, soloTool, mockPlayer, testSongs, sessionPath +from fixtures import soloTool, mockPlayer, testSongs, sessionPath @pytest.fixture def testSessionFile(sessionPath, testSongs): @@ -23,8 +23,8 @@ def testSessionFile(sessionPath, testSongs): return sessionFile @pytest.fixture -def sessionManager(sessionPath, songPool): - return getSessionManager(str(songPool), str(sessionPath)) +def sessionManager(sessionPath): + return getSessionManager(str(sessionPath)) def test_loadSession(sessionManager, mockPlayer, testSessionFile): sessions = sessionManager.getSessions() @@ -64,20 +64,9 @@ def test_loadAndSaveEmptySession(sessionManager, sessionPath, soloTool, tmp_path assert reloadedTool.songs == [] -def test_uploadSong(sessionManager, songPool, tmp_path): - song = tmp_path / "song-to-be-uploaded.mp3" - song.touch() - - expected = songPool / "song-to-be-uploaded.mp3" - assert not expected.exists() - - with open(song, "rb") as f: - sessionManager.addSong("song-to-be-uploaded.mp3", f) - assert expected.exists() - def test_sessionManagerFactory(): - assert type(getSessionManager("", "/some_absolute_dir")) is _FileSystemSessionManager - assert type(getSessionManager("", "file:///some_dir_with_protocol")) is _FileSystemSessionManager - assert type(getSessionManager("", "some_relative_dir")) is _FileSystemSessionManager - assert type(getSessionManager("", "http://some_server")) is _FileBrowserSessionManager - assert type(getSessionManager("", "https://some_secure_server")) is _FileBrowserSessionManager + assert type(getSessionManager("/some_absolute_dir")) is _FileSystemSessionManager + assert type(getSessionManager("file:///some_dir_with_protocol")) is _FileSystemSessionManager + assert type(getSessionManager("some_relative_dir")) is _FileSystemSessionManager + assert type(getSessionManager("http://some_server")) is _FileBrowserSessionManager + assert type(getSessionManager("https://some_secure_server")) is _FileBrowserSessionManager diff --git a/solo-tool-project/test/solo_tool_integrationtest.py b/solo-tool-project/test/solo_tool_integrationtest.py index 7b274a3..b92cd85 100644 --- a/solo-tool-project/test/solo_tool_integrationtest.py +++ b/solo-tool-project/test/solo_tool_integrationtest.py @@ -1,4 +1,4 @@ -from fixtures import soloTool as uut, songPool, mockPlayer, testSongs +from fixtures import soloTool as uut, mockPlayer, testSongs def test_playerControls(uut, mockPlayer): assert not mockPlayer.playing diff --git a/solo-tool-project/test/solo_tool_keypoints_integrationtest.py b/solo-tool-project/test/solo_tool_keypoints_integrationtest.py index 3db86f5..f79103d 100644 --- a/solo-tool-project/test/solo_tool_keypoints_integrationtest.py +++ b/solo-tool-project/test/solo_tool_keypoints_integrationtest.py @@ -1,6 +1,6 @@ import pytest -from fixtures import soloTool as uut, songPool, mockPlayer, testSongs +from fixtures import soloTool as uut, mockPlayer, testSongs def test_keyPointAndSongSelection(uut, mockPlayer, testSongs): def checkJump(before, expectedAfter): diff --git a/solo-tool-project/test/solo_tool_songs_integrationtest.py b/solo-tool-project/test/solo_tool_songs_integrationtest.py index 0acfc2b..caa4a30 100644 --- a/solo-tool-project/test/solo_tool_songs_integrationtest.py +++ b/solo-tool-project/test/solo_tool_songs_integrationtest.py @@ -1,6 +1,6 @@ import pytest -from fixtures import soloTool as uut, songPool, mockPlayer, testSongs +from fixtures import soloTool as uut, mockPlayer, testSongs def test_songSelectionFlow(uut, mockPlayer, testSongs): # Initially, song list is empty and no song is selected |