123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334 |
- using System;
- using System.Collections.Generic;
- using System.IO;
- using System.Linq;
- using AutoFixture;
- using AutoFixture.AutoMoq;
- using Emby.Naming.Common;
- using Emby.Server.Implementations.Library.Resolvers.Audio;
- using MediaBrowser.Controller.Configuration;
- using MediaBrowser.Controller.Entities;
- using MediaBrowser.Controller.Entities.Audio;
- using MediaBrowser.Controller.Entities.Movies;
- using MediaBrowser.Controller.Entities.TV;
- using MediaBrowser.Controller.Library;
- using MediaBrowser.Controller.Persistence;
- using MediaBrowser.Controller.Providers;
- using MediaBrowser.Controller.Resolvers;
- using MediaBrowser.Controller.Sorting;
- using MediaBrowser.Model.Entities;
- using MediaBrowser.Model.IO;
- using Moq;
- using Xunit;
- namespace Jellyfin.Server.Implementations.Tests.Library.LibraryManager;
- public class FindExtrasTests
- {
- private readonly Emby.Server.Implementations.Library.LibraryManager _libraryManager;
- private readonly Mock<IFileSystem> _fileSystemMock;
- public FindExtrasTests()
- {
- var fixture = new Fixture().Customize(new AutoMoqCustomization());
- fixture.Register(() => new NamingOptions());
- var configMock = fixture.Freeze<Mock<IServerConfigurationManager>>();
- configMock.Setup(c => c.ApplicationPaths.ProgramDataPath).Returns("/data");
- var itemRepository = fixture.Freeze<Mock<IItemRepository>>();
- itemRepository.Setup(i => i.RetrieveItem(It.IsAny<Guid>())).Returns<BaseItem>(null);
- _fileSystemMock = fixture.Freeze<Mock<IFileSystem>>();
- _fileSystemMock.Setup(f => f.GetFileInfo(It.IsAny<string>())).Returns<string>(path => new FileSystemMetadata { FullName = path });
- _libraryManager = fixture.Build<Emby.Server.Implementations.Library.LibraryManager>().Do(s => s.AddParts(
- fixture.Create<IEnumerable<IResolverIgnoreRule>>(),
- new List<IItemResolver> { new AudioResolver(fixture.Create<NamingOptions>()) },
- fixture.Create<IEnumerable<IIntroProvider>>(),
- fixture.Create<IEnumerable<IBaseItemComparer>>(),
- fixture.Create<IEnumerable<ILibraryPostScanTask>>()))
- .Create();
- // This is pretty terrible but unavoidable
- BaseItem.FileSystem ??= fixture.Create<IFileSystem>();
- BaseItem.MediaSourceManager ??= fixture.Create<IMediaSourceManager>();
- }
- [Fact]
- public void FindExtras_SeparateMovieFolder_FindsCorrectExtras()
- {
- var owner = new Movie { Name = "Up", Path = "/movies/Up/Up.mkv" };
- var paths = new List<string>
- {
- "/movies/Up/Up.mkv",
- "/movies/Up/Up - trailer.mkv",
- "/movies/Up/Up - sample.mkv",
- "/movies/Up/Up something else.mkv",
- "/movies/Up/Up-extra.mkv"
- };
- var files = paths.Select(p => new FileSystemMetadata
- {
- FullName = p,
- IsDirectory = false
- }).ToList();
- var extras = _libraryManager.FindExtras(owner, files, new DirectoryService(_fileSystemMock.Object)).OrderBy(e => e.ExtraType).ToList();
- Assert.Equal(3, extras.Count);
- Assert.Equal(ExtraType.Unknown, extras[0].ExtraType);
- Assert.Equal(ExtraType.Trailer, extras[1].ExtraType);
- Assert.Equal(typeof(Trailer), extras[1].GetType());
- Assert.Equal(ExtraType.Sample, extras[2].ExtraType);
- }
- [Fact]
- public void FindExtras_SeparateMovieFolder_CleanExtraNames()
- {
- var owner = new Movie { Name = "Up", Path = "/movies/Up/Up.mkv" };
- var paths = new List<string>
- {
- "/movies/Up/Up.mkv",
- "/movies/Up/Recording the audio[Bluray]-behindthescenes.mkv",
- "/movies/Up/Interview with the dog-interview.mkv",
- "/movies/Up/shorts/Balloons[1080p].mkv"
- };
- var files = paths.Select(p => new FileSystemMetadata
- {
- FullName = p,
- IsDirectory = false
- }).ToList();
- var extras = _libraryManager.FindExtras(owner, files, new DirectoryService(_fileSystemMock.Object)).OrderBy(e => e.ExtraType).ToList();
- Assert.Equal(3, extras.Count);
- Assert.Equal(ExtraType.BehindTheScenes, extras[0].ExtraType);
- Assert.Equal("Recording the audio", extras[0].Name);
- Assert.Equal(ExtraType.Interview, extras[1].ExtraType);
- Assert.Equal("Interview with the dog", extras[1].Name);
- Assert.Equal(ExtraType.Short, extras[2].ExtraType);
- Assert.Equal("Balloons", extras[2].Name);
- }
- [Fact]
- public void FindExtras_SeparateMovieFolderWithMixedExtras_FindsCorrectExtras()
- {
- var owner = new Movie { Name = "Up", Path = "/movies/Up/Up.mkv" };
- var paths = new List<string>
- {
- "/movies/Up/Up.mkv",
- "/movies/Up/Up - trailer.mkv",
- "/movies/Up/trailers",
- "/movies/Up/theme-music",
- "/movies/Up/theme.mp3",
- "/movies/Up/not a theme.mp3",
- "/movies/Up/behind the scenes",
- "/movies/Up/behind the scenes.mkv",
- "/movies/Up/Up - sample.mkv",
- "/movies/Up/Up something else.mkv",
- "/movies/Up/extras"
- };
- _fileSystemMock.Setup(f => f.GetFiles(
- "/movies/Up/trailers",
- It.IsAny<string[]>(),
- false,
- false))
- .Returns(new List<FileSystemMetadata>
- {
- new()
- {
- FullName = "/movies/Up/trailers/some trailer.mkv",
- Name = "some trailer.mkv",
- IsDirectory = false
- }
- }).Verifiable();
- _fileSystemMock.Setup(f => f.GetFiles(
- "/movies/Up/behind the scenes",
- It.IsAny<string[]>(),
- false,
- false))
- .Returns(new List<FileSystemMetadata>
- {
- new()
- {
- FullName = "/movies/Up/behind the scenes/the making of Up.mkv",
- Name = "the making of Up.mkv",
- IsDirectory = false
- }
- }).Verifiable();
- _fileSystemMock.Setup(f => f.GetFiles(
- "/movies/Up/theme-music",
- It.IsAny<string[]>(),
- false,
- false))
- .Returns(new List<FileSystemMetadata>
- {
- new()
- {
- FullName = "/movies/Up/theme-music/theme2.mp3",
- Name = "theme2.mp3",
- IsDirectory = false
- }
- }).Verifiable();
- _fileSystemMock.Setup(f => f.GetFiles(
- "/movies/Up/extras",
- It.IsAny<string[]>(),
- false,
- false))
- .Returns(new List<FileSystemMetadata>
- {
- new()
- {
- FullName = "/movies/Up/extras/Honest Trailer.mkv",
- Name = "Honest Trailer.mkv",
- IsDirectory = false
- }
- }).Verifiable();
- var files = paths.Select(p => new FileSystemMetadata
- {
- FullName = p,
- Name = Path.GetFileName(p),
- IsDirectory = !Path.HasExtension(p)
- }).ToList();
- var extras = _libraryManager.FindExtras(owner, files, new DirectoryService(_fileSystemMock.Object)).OrderBy(e => e.ExtraType).ToList();
- _fileSystemMock.Verify();
- Assert.Equal(7, extras.Count);
- Assert.Equal(ExtraType.Unknown, extras[0].ExtraType);
- Assert.Equal(typeof(Video), extras[0].GetType());
- Assert.Equal(ExtraType.Trailer, extras[1].ExtraType);
- Assert.Equal(typeof(Trailer), extras[1].GetType());
- Assert.Equal(ExtraType.Trailer, extras[2].ExtraType);
- Assert.Equal(typeof(Trailer), extras[2].GetType());
- Assert.Equal(ExtraType.BehindTheScenes, extras[3].ExtraType);
- Assert.Equal(ExtraType.Sample, extras[4].ExtraType);
- Assert.Equal(ExtraType.ThemeSong, extras[5].ExtraType);
- Assert.Equal(typeof(Audio), extras[5].GetType());
- Assert.Equal(ExtraType.ThemeSong, extras[6].ExtraType);
- Assert.Equal(typeof(Audio), extras[6].GetType());
- }
- [Fact]
- public void FindExtras_SeparateMovieFolderWithMixedExtras_FindsOnlyExtrasInMovieFolder()
- {
- var owner = new Movie { Name = "Up", Path = "/movies/Up/Up.mkv" };
- var paths = new List<string>
- {
- "/movies/Up/Up.mkv",
- "/movies/Up/trailer.mkv",
- "/movies/Another Movie/trailer.mkv"
- };
- var files = paths.Select(p => new FileSystemMetadata
- {
- FullName = p,
- IsDirectory = false
- }).ToList();
- var extras = _libraryManager.FindExtras(owner, files, new DirectoryService(_fileSystemMock.Object)).OrderBy(e => e.ExtraType).ToList();
- Assert.Single(extras);
- Assert.Equal(ExtraType.Trailer, extras[0].ExtraType);
- Assert.Equal(typeof(Trailer), extras[0].GetType());
- Assert.Equal("trailer", extras[0].FileNameWithoutExtension);
- Assert.Equal("/movies/Up/trailer.mkv", extras[0].Path);
- }
- [Fact]
- public void FindExtras_SeparateMovieFolderWithParts_FindsCorrectExtras()
- {
- var owner = new Movie { Name = "Up", Path = "/movies/Up/Up - part1.mkv" };
- var paths = new List<string>
- {
- "/movies/Up/Up - part1.mkv",
- "/movies/Up/Up - part2.mkv",
- "/movies/Up/trailer.mkv",
- "/movies/Another Movie/trailer.mkv"
- };
- var files = paths.Select(p => new FileSystemMetadata
- {
- FullName = p,
- IsDirectory = false
- }).ToList();
- var extras = _libraryManager.FindExtras(owner, files, new DirectoryService(_fileSystemMock.Object)).OrderBy(e => e.ExtraType).ToList();
- Assert.Single(extras);
- Assert.Equal(ExtraType.Trailer, extras[0].ExtraType);
- Assert.Equal(typeof(Trailer), extras[0].GetType());
- Assert.Equal("trailer", extras[0].FileNameWithoutExtension);
- Assert.Equal("/movies/Up/trailer.mkv", extras[0].Path);
- }
- [Fact]
- public void FindExtras_WrongExtensions_FindsNoExtras()
- {
- var owner = new Movie { Name = "Up", Path = "/movies/Up/Up.mkv" };
- var paths = new List<string>
- {
- "/movies/Up/Up.mkv",
- "/movies/Up/trailer.noext",
- "/movies/Up/theme.png",
- "/movies/Up/trailers"
- };
- var files = paths.Select(p => new FileSystemMetadata
- {
- FullName = p,
- Name = Path.GetFileName(p),
- IsDirectory = !Path.HasExtension(p)
- }).ToList();
- _fileSystemMock.Setup(f => f.GetFiles(
- "/movies/Up/trailers",
- It.IsAny<string[]>(),
- false,
- false))
- .Returns(new List<FileSystemMetadata>
- {
- new()
- {
- FullName = "/movies/Up/trailers/trailer.jpg",
- Name = "trailer.jpg",
- IsDirectory = false
- }
- }).Verifiable();
- var extras = _libraryManager.FindExtras(owner, files, new DirectoryService(_fileSystemMock.Object)).OrderBy(e => e.ExtraType).ToList();
- _fileSystemMock.Verify();
- Assert.Empty(extras);
- }
- [Fact]
- public void FindExtras_SeriesWithTrailers_FindsCorrectExtras()
- {
- var owner = new Series { Name = "Dexter", Path = "/series/Dexter" };
- var paths = new List<string>
- {
- "/series/Dexter/Season 1/S01E01.mkv",
- "/series/Dexter/trailer.mkv",
- "/series/Dexter/trailers/trailer2.mkv",
- };
- var files = paths.Select(p => new FileSystemMetadata
- {
- FullName = p,
- IsDirectory = string.IsNullOrEmpty(Path.GetExtension(p))
- }).ToList();
- var extras = _libraryManager.FindExtras(owner, files, new DirectoryService(_fileSystemMock.Object)).OrderBy(e => e.ExtraType).ToList();
- Assert.Equal(2, extras.Count);
- Assert.Equal(ExtraType.Trailer, extras[0].ExtraType);
- Assert.Equal(typeof(Trailer), extras[0].GetType());
- Assert.Equal("trailer", extras[0].FileNameWithoutExtension);
- Assert.Equal("/series/Dexter/trailer.mkv", extras[0].Path);
- Assert.Equal("/series/Dexter/trailers/trailer2.mkv", extras[1].Path);
- }
- }
|