UserControllerTests.cs 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  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 _jsonOpions = 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, _jsonOpions);
  30. private Task<HttpResponseMessage> UpdateUserPassword(HttpClient httpClient, Guid userId, UpdateUserPassword request)
  31. => httpClient.PostAsJsonAsync("Users/" + userId.ToString("N", CultureInfo.InvariantCulture) + "/Password", request, _jsonOpions);
  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 JsonSerializer.DeserializeAsync<UserDto[]>(
  40. await response.Content.ReadAsStreamAsync(), _jsonOpions);
  41. // User are hidden by default
  42. Assert.NotNull(users);
  43. Assert.Empty(users);
  44. }
  45. [Fact]
  46. [Priority(-1)]
  47. public async Task GetUsers_Valid_Success()
  48. {
  49. var client = _factory.CreateClient();
  50. client.DefaultRequestHeaders.AddAuthHeader(_accessToken ??= await AuthHelper.CompleteStartupAsync(client));
  51. using var response = await client.GetAsync("Users");
  52. Assert.Equal(HttpStatusCode.OK, response.StatusCode);
  53. var users = await JsonSerializer.DeserializeAsync<UserDto[]>(
  54. await response.Content.ReadAsStreamAsync(), _jsonOpions);
  55. Assert.NotNull(users);
  56. Assert.Single(users);
  57. Assert.False(users![0].HasConfiguredPassword);
  58. }
  59. [Fact]
  60. [Priority(-1)]
  61. public async Task Me_Valid_Success()
  62. {
  63. var client = _factory.CreateClient();
  64. client.DefaultRequestHeaders.AddAuthHeader(_accessToken ??= await AuthHelper.CompleteStartupAsync(client));
  65. _ = await AuthHelper.GetUserDtoAsync(client);
  66. }
  67. [Fact]
  68. [Priority(0)]
  69. public async Task New_Valid_Success()
  70. {
  71. var client = _factory.CreateClient();
  72. // access token can't be null here as the previous test populated it
  73. client.DefaultRequestHeaders.AddAuthHeader(_accessToken!);
  74. var createRequest = new CreateUserByName()
  75. {
  76. Name = TestUsername
  77. };
  78. using var response = await CreateUserByName(client, createRequest);
  79. Assert.Equal(HttpStatusCode.OK, response.StatusCode);
  80. var user = await JsonSerializer.DeserializeAsync<UserDto>(
  81. await response.Content.ReadAsStreamAsync(), _jsonOpions);
  82. Assert.Equal(TestUsername, user!.Name);
  83. Assert.False(user.HasPassword);
  84. Assert.False(user.HasConfiguredPassword);
  85. _testUserId = user.Id;
  86. Console.WriteLine(user.Id.ToString("N", CultureInfo.InvariantCulture));
  87. }
  88. [Theory]
  89. [InlineData(null)]
  90. [InlineData("")]
  91. [InlineData(" ")]
  92. [InlineData("‼️")]
  93. [Priority(0)]
  94. public async Task New_Invalid_Fail(string? username)
  95. {
  96. var client = _factory.CreateClient();
  97. // access token can't be null here as the previous test populated it
  98. client.DefaultRequestHeaders.AddAuthHeader(_accessToken!);
  99. var createRequest = new CreateUserByName()
  100. {
  101. Name = username!
  102. };
  103. using var response = await CreateUserByName(client, createRequest);
  104. Assert.Equal(HttpStatusCode.BadRequest, response.StatusCode);
  105. }
  106. [Fact]
  107. [Priority(0)]
  108. public async Task Delete_DoesntExist_NotFound()
  109. {
  110. var client = _factory.CreateClient();
  111. // access token can't be null here as the previous test populated it
  112. client.DefaultRequestHeaders.AddAuthHeader(_accessToken!);
  113. using var response = await client.DeleteAsync($"User/{Guid.NewGuid()}");
  114. Assert.Equal(HttpStatusCode.NotFound, response.StatusCode);
  115. }
  116. [Fact]
  117. [Priority(1)]
  118. public async Task UpdateUserPassword_Valid_Success()
  119. {
  120. var client = _factory.CreateClient();
  121. client.DefaultRequestHeaders.AddAuthHeader(_accessToken!);
  122. var createRequest = new UpdateUserPassword()
  123. {
  124. NewPw = "4randomPa$$word"
  125. };
  126. using var response = await UpdateUserPassword(client, _testUserId, createRequest);
  127. Assert.Equal(HttpStatusCode.NoContent, response.StatusCode);
  128. var users = await JsonSerializer.DeserializeAsync<UserDto[]>(
  129. await client.GetStreamAsync("Users"), _jsonOpions);
  130. var user = users!.First(x => x.Id.Equals(_testUserId));
  131. Assert.True(user.HasPassword);
  132. Assert.True(user.HasConfiguredPassword);
  133. }
  134. [Fact]
  135. [Priority(2)]
  136. public async Task UpdateUserPassword_Empty_RemoveSetPassword()
  137. {
  138. var client = _factory.CreateClient();
  139. client.DefaultRequestHeaders.AddAuthHeader(_accessToken!);
  140. var createRequest = new UpdateUserPassword()
  141. {
  142. CurrentPw = "4randomPa$$word",
  143. };
  144. using var response = await UpdateUserPassword(client, _testUserId, createRequest);
  145. Assert.Equal(HttpStatusCode.NoContent, response.StatusCode);
  146. var users = await JsonSerializer.DeserializeAsync<UserDto[]>(
  147. await client.GetStreamAsync("Users"), _jsonOpions);
  148. var user = users!.First(x => x.Id.Equals(_testUserId));
  149. Assert.False(user.HasPassword);
  150. Assert.False(user.HasConfiguredPassword);
  151. }
  152. }
  153. }