mirror of
				https://github.com/jellyfin/jellyfin.git
				synced 2025-11-04 03:27:21 -05: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>
		
			
				
	
	
		
			184 lines
		
	
	
		
			6.6 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			184 lines
		
	
	
		
			6.6 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
using System;
 | 
						|
using System.Globalization;
 | 
						|
using System.Linq;
 | 
						|
using System.Net;
 | 
						|
using System.Net.Http;
 | 
						|
using System.Net.Http.Json;
 | 
						|
using System.Text.Json;
 | 
						|
using System.Threading.Tasks;
 | 
						|
using Jellyfin.Api.Models.UserDtos;
 | 
						|
using Jellyfin.Extensions.Json;
 | 
						|
using MediaBrowser.Model.Dto;
 | 
						|
using Xunit;
 | 
						|
using Xunit.Priority;
 | 
						|
 | 
						|
namespace Jellyfin.Server.Integration.Tests.Controllers
 | 
						|
{
 | 
						|
    [TestCaseOrderer(PriorityOrderer.Name, PriorityOrderer.Assembly)]
 | 
						|
    public sealed class UserControllerTests : IClassFixture<JellyfinApplicationFactory>
 | 
						|
    {
 | 
						|
        private const string TestUsername = "testUser01";
 | 
						|
 | 
						|
        private readonly JellyfinApplicationFactory _factory;
 | 
						|
        private readonly JsonSerializerOptions _jsonOptions = JsonDefaults.Options;
 | 
						|
        private static string? _accessToken;
 | 
						|
        private static Guid _testUserId = Guid.Empty;
 | 
						|
 | 
						|
        public UserControllerTests(JellyfinApplicationFactory factory)
 | 
						|
        {
 | 
						|
            _factory = factory;
 | 
						|
        }
 | 
						|
 | 
						|
        private Task<HttpResponseMessage> CreateUserByName(HttpClient httpClient, CreateUserByName request)
 | 
						|
            => httpClient.PostAsJsonAsync("Users/New", request, _jsonOptions);
 | 
						|
 | 
						|
        private Task<HttpResponseMessage> UpdateUserPassword(HttpClient httpClient, Guid userId, UpdateUserPassword request)
 | 
						|
            => httpClient.PostAsJsonAsync("Users/" + userId.ToString("N", CultureInfo.InvariantCulture) + "/Password", request, _jsonOptions);
 | 
						|
 | 
						|
        [Fact]
 | 
						|
        [Priority(-1)]
 | 
						|
        public async Task GetPublicUsers_Valid_Success()
 | 
						|
        {
 | 
						|
            var client = _factory.CreateClient();
 | 
						|
 | 
						|
            using var response = await client.GetAsync("Users/Public");
 | 
						|
            Assert.Equal(HttpStatusCode.OK, response.StatusCode);
 | 
						|
            var users = await response.Content.ReadFromJsonAsync<UserDto[]>(_jsonOptions);
 | 
						|
            // User are hidden by default
 | 
						|
            Assert.NotNull(users);
 | 
						|
            Assert.Empty(users);
 | 
						|
        }
 | 
						|
 | 
						|
        [Fact]
 | 
						|
        [Priority(-1)]
 | 
						|
        public async Task GetUsers_Valid_Success()
 | 
						|
        {
 | 
						|
            var client = _factory.CreateClient();
 | 
						|
            client.DefaultRequestHeaders.AddAuthHeader(_accessToken ??= await AuthHelper.CompleteStartupAsync(client));
 | 
						|
 | 
						|
            using var response = await client.GetAsync("Users");
 | 
						|
            Assert.Equal(HttpStatusCode.OK, response.StatusCode);
 | 
						|
            var users = await response.Content.ReadFromJsonAsync<UserDto[]>(_jsonOptions);
 | 
						|
            Assert.NotNull(users);
 | 
						|
            Assert.Single(users);
 | 
						|
            Assert.False(users![0].HasConfiguredPassword);
 | 
						|
        }
 | 
						|
 | 
						|
        [Fact]
 | 
						|
        [Priority(-1)]
 | 
						|
        public async Task Me_Valid_Success()
 | 
						|
        {
 | 
						|
            var client = _factory.CreateClient();
 | 
						|
            client.DefaultRequestHeaders.AddAuthHeader(_accessToken ??= await AuthHelper.CompleteStartupAsync(client));
 | 
						|
 | 
						|
            _ = await AuthHelper.GetUserDtoAsync(client);
 | 
						|
        }
 | 
						|
 | 
						|
        [Fact]
 | 
						|
        [Priority(0)]
 | 
						|
        public async Task New_Valid_Success()
 | 
						|
        {
 | 
						|
            var client = _factory.CreateClient();
 | 
						|
 | 
						|
            // access token can't be null here as the previous test populated it
 | 
						|
            client.DefaultRequestHeaders.AddAuthHeader(_accessToken!);
 | 
						|
 | 
						|
            var createRequest = new CreateUserByName()
 | 
						|
            {
 | 
						|
                Name = TestUsername
 | 
						|
            };
 | 
						|
 | 
						|
            using var response = await CreateUserByName(client, createRequest);
 | 
						|
            Assert.Equal(HttpStatusCode.OK, response.StatusCode);
 | 
						|
            var user = await response.Content.ReadFromJsonAsync<UserDto>(_jsonOptions);
 | 
						|
            Assert.Equal(TestUsername, user!.Name);
 | 
						|
            Assert.False(user.HasPassword);
 | 
						|
            Assert.False(user.HasConfiguredPassword);
 | 
						|
 | 
						|
            _testUserId = user.Id;
 | 
						|
 | 
						|
            Console.WriteLine(user.Id.ToString("N", CultureInfo.InvariantCulture));
 | 
						|
        }
 | 
						|
 | 
						|
        [Theory]
 | 
						|
        [InlineData(null)]
 | 
						|
        [InlineData("")]
 | 
						|
        [InlineData("   ")]
 | 
						|
        [InlineData("‼️")]
 | 
						|
        [Priority(0)]
 | 
						|
        public async Task New_Invalid_Fail(string? username)
 | 
						|
        {
 | 
						|
            var client = _factory.CreateClient();
 | 
						|
 | 
						|
            // access token can't be null here as the previous test populated it
 | 
						|
            client.DefaultRequestHeaders.AddAuthHeader(_accessToken!);
 | 
						|
 | 
						|
            var createRequest = new CreateUserByName()
 | 
						|
            {
 | 
						|
                Name = username!
 | 
						|
            };
 | 
						|
 | 
						|
            using var response = await CreateUserByName(client, createRequest);
 | 
						|
            Assert.Equal(HttpStatusCode.BadRequest, response.StatusCode);
 | 
						|
        }
 | 
						|
 | 
						|
        [Fact]
 | 
						|
        [Priority(0)]
 | 
						|
        public async Task Delete_DoesntExist_NotFound()
 | 
						|
        {
 | 
						|
            var client = _factory.CreateClient();
 | 
						|
 | 
						|
            // access token can't be null here as the previous test populated it
 | 
						|
            client.DefaultRequestHeaders.AddAuthHeader(_accessToken!);
 | 
						|
 | 
						|
            using var response = await client.DeleteAsync($"User/{Guid.NewGuid()}");
 | 
						|
            Assert.Equal(HttpStatusCode.NotFound, response.StatusCode);
 | 
						|
        }
 | 
						|
 | 
						|
        [Fact]
 | 
						|
        [Priority(1)]
 | 
						|
        public async Task UpdateUserPassword_Valid_Success()
 | 
						|
        {
 | 
						|
            var client = _factory.CreateClient();
 | 
						|
            client.DefaultRequestHeaders.AddAuthHeader(_accessToken!);
 | 
						|
 | 
						|
            var createRequest = new UpdateUserPassword()
 | 
						|
            {
 | 
						|
                NewPw = "4randomPa$$word"
 | 
						|
            };
 | 
						|
 | 
						|
            using var response = await UpdateUserPassword(client, _testUserId, createRequest);
 | 
						|
            Assert.Equal(HttpStatusCode.NoContent, response.StatusCode);
 | 
						|
 | 
						|
            var users = await JsonSerializer.DeserializeAsync<UserDto[]>(
 | 
						|
                await client.GetStreamAsync("Users"), _jsonOptions);
 | 
						|
            var user = users!.First(x => x.Id.Equals(_testUserId));
 | 
						|
            Assert.True(user.HasPassword);
 | 
						|
            Assert.True(user.HasConfiguredPassword);
 | 
						|
        }
 | 
						|
 | 
						|
        [Fact]
 | 
						|
        [Priority(2)]
 | 
						|
        public async Task UpdateUserPassword_Empty_RemoveSetPassword()
 | 
						|
        {
 | 
						|
            var client = _factory.CreateClient();
 | 
						|
 | 
						|
            client.DefaultRequestHeaders.AddAuthHeader(_accessToken!);
 | 
						|
 | 
						|
            var createRequest = new UpdateUserPassword()
 | 
						|
            {
 | 
						|
                CurrentPw = "4randomPa$$word",
 | 
						|
            };
 | 
						|
 | 
						|
            using var response = await UpdateUserPassword(client, _testUserId, createRequest);
 | 
						|
            Assert.Equal(HttpStatusCode.NoContent, response.StatusCode);
 | 
						|
 | 
						|
            var users = await JsonSerializer.DeserializeAsync<UserDto[]>(
 | 
						|
                await client.GetStreamAsync("Users"), _jsonOptions);
 | 
						|
            var user = users!.First(x => x.Id.Equals(_testUserId));
 | 
						|
            Assert.False(user.HasPassword);
 | 
						|
            Assert.False(user.HasConfiguredPassword);
 | 
						|
        }
 | 
						|
    }
 | 
						|
}
 |