UserControllerTests.cs 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. using System;
  2. using System.Globalization;
  3. using System.Linq;
  4. using System.Net;
  5. using System.Net.Http;
  6. using System.Net.Http.Json;
  7. using System.Text.Json;
  8. using System.Threading.Tasks;
  9. using Jellyfin.Api.Models.UserDtos;
  10. using Jellyfin.Extensions.Json;
  11. using MediaBrowser.Model.Dto;
  12. using Xunit;
  13. using Xunit.Priority;
  14. namespace Jellyfin.Server.Integration.Tests.Controllers
  15. {
  16. [TestCaseOrderer(PriorityOrderer.Name, PriorityOrderer.Assembly)]
  17. public sealed class UserControllerTests : IClassFixture<JellyfinApplicationFactory>
  18. {
  19. private const string TestUsername = "testUser01";
  20. private readonly JellyfinApplicationFactory _factory;
  21. private readonly JsonSerializerOptions _jsonOptions = JsonDefaults.Options;
  22. private static string? _accessToken;
  23. private static Guid _testUserId = Guid.Empty;
  24. public UserControllerTests(JellyfinApplicationFactory factory)
  25. {
  26. _factory = factory;
  27. }
  28. private Task<HttpResponseMessage> CreateUserByName(HttpClient httpClient, CreateUserByName request)
  29. => httpClient.PostAsJsonAsync("Users/New", request, _jsonOptions);
  30. private Task<HttpResponseMessage> UpdateUserPassword(HttpClient httpClient, Guid userId, UpdateUserPassword request)
  31. => httpClient.PostAsJsonAsync("Users/" + userId.ToString("N", CultureInfo.InvariantCulture) + "/Password", request, _jsonOptions);
  32. [Fact]
  33. [Priority(-1)]
  34. public async Task GetPublicUsers_Valid_Success()
  35. {
  36. var client = _factory.CreateClient();
  37. using var response = await client.GetAsync("Users/Public");
  38. Assert.Equal(HttpStatusCode.OK, response.StatusCode);
  39. var users = await response.Content.ReadFromJsonAsync<UserDto[]>(_jsonOptions);
  40. // User are hidden by default
  41. Assert.NotNull(users);
  42. Assert.Empty(users);
  43. }
  44. [Fact]
  45. [Priority(-1)]
  46. public async Task GetUsers_Valid_Success()
  47. {
  48. var client = _factory.CreateClient();
  49. client.DefaultRequestHeaders.AddAuthHeader(_accessToken ??= await AuthHelper.CompleteStartupAsync(client));
  50. using var response = await client.GetAsync("Users");
  51. Assert.Equal(HttpStatusCode.OK, response.StatusCode);
  52. var users = await response.Content.ReadFromJsonAsync<UserDto[]>(_jsonOptions);
  53. Assert.NotNull(users);
  54. Assert.Single(users);
  55. Assert.False(users![0].HasConfiguredPassword);
  56. }
  57. [Fact]
  58. [Priority(-1)]
  59. public async Task Me_Valid_Success()
  60. {
  61. var client = _factory.CreateClient();
  62. client.DefaultRequestHeaders.AddAuthHeader(_accessToken ??= await AuthHelper.CompleteStartupAsync(client));
  63. _ = await AuthHelper.GetUserDtoAsync(client);
  64. }
  65. [Fact]
  66. [Priority(0)]
  67. public async Task New_Valid_Success()
  68. {
  69. var client = _factory.CreateClient();
  70. // access token can't be null here as the previous test populated it
  71. client.DefaultRequestHeaders.AddAuthHeader(_accessToken!);
  72. var createRequest = new CreateUserByName()
  73. {
  74. Name = TestUsername
  75. };
  76. using var response = await CreateUserByName(client, createRequest);
  77. Assert.Equal(HttpStatusCode.OK, response.StatusCode);
  78. var user = await response.Content.ReadFromJsonAsync<UserDto>(_jsonOptions);
  79. Assert.Equal(TestUsername, user!.Name);
  80. Assert.False(user.HasPassword);
  81. Assert.False(user.HasConfiguredPassword);
  82. _testUserId = user.Id;
  83. Console.WriteLine(user.Id.ToString("N", CultureInfo.InvariantCulture));
  84. }
  85. [Theory]
  86. [InlineData(null)]
  87. [InlineData("")]
  88. [InlineData(" ")]
  89. [InlineData("‼️")]
  90. [Priority(0)]
  91. public async Task New_Invalid_Fail(string? username)
  92. {
  93. var client = _factory.CreateClient();
  94. // access token can't be null here as the previous test populated it
  95. client.DefaultRequestHeaders.AddAuthHeader(_accessToken!);
  96. var createRequest = new CreateUserByName()
  97. {
  98. Name = username!
  99. };
  100. using var response = await CreateUserByName(client, createRequest);
  101. Assert.Equal(HttpStatusCode.BadRequest, response.StatusCode);
  102. }
  103. [Fact]
  104. [Priority(0)]
  105. public async Task Delete_DoesntExist_NotFound()
  106. {
  107. var client = _factory.CreateClient();
  108. // access token can't be null here as the previous test populated it
  109. client.DefaultRequestHeaders.AddAuthHeader(_accessToken!);
  110. using var response = await client.DeleteAsync($"User/{Guid.NewGuid()}");
  111. Assert.Equal(HttpStatusCode.NotFound, response.StatusCode);
  112. }
  113. [Fact]
  114. [Priority(1)]
  115. public async Task UpdateUserPassword_Valid_Success()
  116. {
  117. var client = _factory.CreateClient();
  118. client.DefaultRequestHeaders.AddAuthHeader(_accessToken!);
  119. var createRequest = new UpdateUserPassword()
  120. {
  121. NewPw = "4randomPa$$word"
  122. };
  123. using var response = await UpdateUserPassword(client, _testUserId, createRequest);
  124. Assert.Equal(HttpStatusCode.NoContent, response.StatusCode);
  125. var users = await JsonSerializer.DeserializeAsync<UserDto[]>(
  126. await client.GetStreamAsync("Users"), _jsonOptions);
  127. var user = users!.First(x => x.Id.Equals(_testUserId));
  128. Assert.True(user.HasPassword);
  129. Assert.True(user.HasConfiguredPassword);
  130. }
  131. [Fact]
  132. [Priority(2)]
  133. public async Task UpdateUserPassword_Empty_RemoveSetPassword()
  134. {
  135. var client = _factory.CreateClient();
  136. client.DefaultRequestHeaders.AddAuthHeader(_accessToken!);
  137. var createRequest = new UpdateUserPassword()
  138. {
  139. CurrentPw = "4randomPa$$word",
  140. };
  141. using var response = await UpdateUserPassword(client, _testUserId, createRequest);
  142. Assert.Equal(HttpStatusCode.NoContent, response.StatusCode);
  143. var users = await JsonSerializer.DeserializeAsync<UserDto[]>(
  144. await client.GetStreamAsync("Users"), _jsonOptions);
  145. var user = users!.First(x => x.Id.Equals(_testUserId));
  146. Assert.False(user.HasPassword);
  147. Assert.False(user.HasConfiguredPassword);
  148. }
  149. }
  150. }