mirror of
https://github.com/Radarr/Radarr.git
synced 2024-10-02 06:07:19 +02:00
Fixed: Cleanup orphaned import list movies by movie metadata
This commit is contained in:
parent
c8d30fd214
commit
119cdf6f09
@ -4,6 +4,7 @@
|
||||
using NzbDrone.Core.Housekeeping.Housekeepers;
|
||||
using NzbDrone.Core.ImportLists;
|
||||
using NzbDrone.Core.ImportLists.ImportListMovies;
|
||||
using NzbDrone.Core.Movies;
|
||||
using NzbDrone.Core.Test.Framework;
|
||||
|
||||
namespace NzbDrone.Core.Test.Housekeeping.Housekeepers
|
||||
@ -42,8 +43,13 @@ public void should_not_delete_unorphaned_importlistmovies()
|
||||
{
|
||||
GivenImportList();
|
||||
|
||||
var movieMetadata = Builder<MovieMetadata>.CreateNew().BuildNew();
|
||||
|
||||
Db.Insert(movieMetadata);
|
||||
|
||||
var status = Builder<ImportListMovie>.CreateNew()
|
||||
.With(h => h.ListId = _importList.Id)
|
||||
.With(b => b.MovieMetadataId = movieMetadata.Id)
|
||||
.BuildNew();
|
||||
Db.Insert(status);
|
||||
|
||||
|
@ -13,15 +13,33 @@ public CleanupOrphanedImportListMovies(IMainDatabase database)
|
||||
}
|
||||
|
||||
public void Clean()
|
||||
{
|
||||
CleanupOrphanedByImportLists();
|
||||
CleanupOrphanedByMovieMetadata();
|
||||
}
|
||||
|
||||
private void CleanupOrphanedByImportLists()
|
||||
{
|
||||
using var mapper = _database.OpenConnection();
|
||||
|
||||
mapper.Execute(@"DELETE FROM ""ImportListMovies""
|
||||
WHERE ""Id"" IN (
|
||||
SELECT ""ImportListMovies"".""Id"" FROM ""ImportListMovies""
|
||||
LEFT OUTER JOIN ""ImportLists""
|
||||
ON ""ImportListMovies"".""ListId"" = ""ImportLists"".""Id""
|
||||
SELECT ""ImportListMovies"".""Id""
|
||||
FROM ""ImportListMovies""
|
||||
LEFT OUTER JOIN ""ImportLists"" ON ""ImportListMovies"".""ListId"" = ""ImportLists"".""Id""
|
||||
WHERE ""ImportLists"".""Id"" IS NULL)");
|
||||
}
|
||||
|
||||
private void CleanupOrphanedByMovieMetadata()
|
||||
{
|
||||
using var mapper = _database.OpenConnection();
|
||||
|
||||
mapper.Execute(@"DELETE FROM ""ImportListMovies""
|
||||
WHERE ""Id"" IN (
|
||||
SELECT ""ImportListMovies"".""Id""
|
||||
FROM ""ImportListMovies""
|
||||
LEFT OUTER JOIN ""MovieMetadata"" ON ""ImportListMovies"".""MovieMetadataId"" = ""MovieMetadata"".""Id""
|
||||
WHERE ""MovieMetadata"".""Id"" IS NULL)");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user