From 5c6e452679c7a22a54f80b886085c32a6958432a Mon Sep 17 00:00:00 2001 From: Craig Date: Tue, 11 Jun 2024 05:36:10 +0200 Subject: [PATCH] Fix for [BUG] max() iterable argument is empty #677 (#683) * seems to work - halt progress if this info is missing * Minor fixes --------- Co-authored-by: Nathan Thomas --- streamrip/client/downloadable.py | 9 +++++++-- streamrip/media/playlist.py | 2 +- 2 files changed, 8 insertions(+), 3 deletions(-) diff --git a/streamrip/client/downloadable.py b/streamrip/client/downloadable.py index 9eba477..d778a8f 100644 --- a/streamrip/client/downloadable.py +++ b/streamrip/client/downloadable.py @@ -124,9 +124,14 @@ def __init__(self, session: aiohttp.ClientSession, info: dict): self.session = session self.url = info["url"] self.source: str = "deezer" - max_quality_available = max( + qualities_available = [ i for i, size in enumerate(info["quality_to_size"]) if size > 0 - ) + ] + if len(qualities_available) == 0: + raise NonStreamableError( + "Missing download info. Skipping.", + ) + max_quality_available = max(qualities_available) self.quality = min(info["quality"], max_quality_available) self._size = info["quality_to_size"][self.quality] if self.quality <= 1: diff --git a/streamrip/media/playlist.py b/streamrip/media/playlist.py index 858b3c0..bf3bbbe 100644 --- a/streamrip/media/playlist.py +++ b/streamrip/media/playlist.py @@ -79,7 +79,7 @@ async def resolve(self) -> Track | None: self.client.get_downloadable(self.id, quality), ) except NonStreamableError as e: - logger.error("Error fetching download info for track: %s", e) + logger.error(f"Error fetching download info for track {self.id}: {e}") self.db.set_failed(self.client.source, "track", self.id) return None