mirror of
				https://github.com/jellyfin/jellyfin.git
				synced 2025-10-31 10:37:22 -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);
 | |
|     }
 | |
| }
 |