mirror of
https://github.com/jellyfin/jellyfin.git
synced 2025-05-24 02:02:29 -04:00
* a * acceleration * addition * altogether * api clients * artist * associated * bandwidth * cannot * capabilities * case-insensitive * case-sensitive * configuration * delimiter * dependent * diacritics * directors * enable * explicitly * filters * finish * have * hierarchy * implicit * include * information * into * its * keepalive * localization * macos * manual * matching * metadata * nonexistent * options * overridden * parsed * parser * playback * preferring * processes * processing * provider * ratings * retrieval * running * segments * separate * should * station * subdirectories * superseded * supported * system * than * the * throws * transpose * valid * was link: forum or chat rooms Signed-off-by: Josh Soref <2119212+jsoref@users.noreply.github.com>
64 lines
2.2 KiB
C#
64 lines
2.2 KiB
C#
using System;
|
|
using System.Globalization;
|
|
using System.Net;
|
|
using System.Threading.Tasks;
|
|
using Xunit;
|
|
|
|
namespace Jellyfin.Server.Integration.Tests.Controllers;
|
|
|
|
public sealed class LibraryControllerTests : IClassFixture<JellyfinApplicationFactory>
|
|
{
|
|
private readonly JellyfinApplicationFactory _factory;
|
|
private static string? _accessToken;
|
|
|
|
public LibraryControllerTests(JellyfinApplicationFactory factory)
|
|
{
|
|
_factory = factory;
|
|
}
|
|
|
|
[Theory]
|
|
[InlineData("Items/{0}/File")]
|
|
[InlineData("Items/{0}/ThemeSongs")]
|
|
[InlineData("Items/{0}/ThemeVideos")]
|
|
[InlineData("Items/{0}/ThemeMedia")]
|
|
[InlineData("Items/{0}/Ancestors")]
|
|
[InlineData("Items/{0}/Download")]
|
|
[InlineData("Artists/{0}/Similar")]
|
|
[InlineData("Items/{0}/Similar")]
|
|
[InlineData("Albums/{0}/Similar")]
|
|
[InlineData("Shows/{0}/Similar")]
|
|
[InlineData("Movies/{0}/Similar")]
|
|
[InlineData("Trailers/{0}/Similar")]
|
|
public async Task Get_NonexistentItemId_NotFound(string format)
|
|
{
|
|
var client = _factory.CreateClient();
|
|
client.DefaultRequestHeaders.AddAuthHeader(_accessToken ??= await AuthHelper.CompleteStartupAsync(client));
|
|
|
|
var response = await client.GetAsync(string.Format(CultureInfo.InvariantCulture, format, Guid.NewGuid()));
|
|
Assert.Equal(HttpStatusCode.NotFound, response.StatusCode);
|
|
}
|
|
|
|
[Theory]
|
|
[InlineData("Items/{0}")]
|
|
[InlineData("Items?ids={0}")]
|
|
public async Task Delete_NonexistentItemId_Unauthorised(string format)
|
|
{
|
|
var client = _factory.CreateClient();
|
|
|
|
var response = await client.DeleteAsync(string.Format(CultureInfo.InvariantCulture, format, Guid.NewGuid()));
|
|
Assert.Equal(HttpStatusCode.Unauthorized, response.StatusCode);
|
|
}
|
|
|
|
[Theory]
|
|
[InlineData("Items/{0}")]
|
|
[InlineData("Items?ids={0}")]
|
|
public async Task Delete_NonexistentItemId_NotFound(string format)
|
|
{
|
|
var client = _factory.CreateClient();
|
|
client.DefaultRequestHeaders.AddAuthHeader(_accessToken ??= await AuthHelper.CompleteStartupAsync(client));
|
|
|
|
var response = await client.DeleteAsync(string.Format(CultureInfo.InvariantCulture, format, Guid.NewGuid()));
|
|
Assert.Equal(HttpStatusCode.NotFound, response.StatusCode);
|
|
}
|
|
}
|