Improve playlist download stability by skipping failed tracks

Added try-catch blocks in downloadPlaylistAsZip, downloadAlbumAsZip, and downloadDiscography to handle individual track download failures gracefully. Errors are now logged to the console, and the download process continues for the remaining tracks.
This commit is contained in:
Julien Maille 2025-12-26 11:38:21 +01:00
parent c5d4160e77
commit 2ae6b620f2

View file

@ -244,10 +244,10 @@ export async function downloadAlbumAsZip(album, tracks, api, quality, lyricsMana
updateBulkDownloadProgress(notification, i, tracks.length, trackTitle); updateBulkDownloadProgress(notification, i, tracks.length, trackTitle);
try {
const blob = await downloadTrackBlob(track, quality, api); const blob = await downloadTrackBlob(track, quality, api);
zip.file(`${folderName}/${filename}`, blob); zip.file(`${folderName}/${filename}`, blob);
try { try {
const meta = buildTrackMetadata(track, api); const meta = buildTrackMetadata(track, api);
const metaFilename = filename.replace(/\.[^.]+$/, '.json'); const metaFilename = filename.replace(/\.[^.]+$/, '.json');
@ -276,6 +276,9 @@ export async function downloadAlbumAsZip(album, tracks, api, quality, lyricsMana
console.log('Could not add lyrics for:', trackTitle); console.log('Could not add lyrics for:', trackTitle);
} }
} }
} catch (err) {
console.error(`Failed to download track ${trackTitle}:`, err);
}
} }
updateBulkDownloadProgress(notification, tracks.length, tracks.length, 'Creating ZIP...'); updateBulkDownloadProgress(notification, tracks.length, tracks.length, 'Creating ZIP...');
@ -323,6 +326,7 @@ export async function downloadPlaylistAsZip(playlist, tracks, api, quality, lyri
updateBulkDownloadProgress(notification, i, tracks.length, trackTitle); updateBulkDownloadProgress(notification, i, tracks.length, trackTitle);
try {
const blob = await downloadTrackBlob(track, quality, api); const blob = await downloadTrackBlob(track, quality, api);
zip.file(`${folderName}/${filename}`, blob); zip.file(`${folderName}/${filename}`, blob);
@ -354,6 +358,9 @@ export async function downloadPlaylistAsZip(playlist, tracks, api, quality, lyri
console.log('Could not add lyrics for:', trackTitle); console.log('Could not add lyrics for:', trackTitle);
} }
} }
} catch (err) {
console.error(`Failed to download track ${trackTitle}:`, err);
}
} }
updateBulkDownloadProgress(notification, tracks.length, tracks.length, 'Creating ZIP...'); updateBulkDownloadProgress(notification, tracks.length, tracks.length, 'Creating ZIP...');
@ -410,6 +417,8 @@ export async function downloadDiscography(artist, api, quality, lyricsManager =
for (const track of tracks) { for (const track of tracks) {
const filename = buildTrackFilename(track, quality); const filename = buildTrackFilename(track, quality);
try {
const blob = await downloadTrackBlob(track, quality, api); const blob = await downloadTrackBlob(track, quality, api);
zip.file(`${rootFolder}/${albumFolder}/${filename}`, blob); zip.file(`${rootFolder}/${albumFolder}/${filename}`, blob);
@ -439,6 +448,9 @@ export async function downloadDiscography(artist, api, quality, lyricsManager =
console.log('Could not add lyrics for:', track.title); console.log('Could not add lyrics for:', track.title);
} }
} }
} catch (err) {
console.error(`Failed to download track ${track.title} in album ${album.title}:`, err);
}
} }
} catch (error) { } catch (error) {
console.error(`Failed to download album ${album.title}:`, error); console.error(`Failed to download album ${album.title}:`, error);