UserControllerTests.cs 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  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. }
  56. [Fact]
  57. [Priority(-1)]
  58. public async Task Me_Valid_Success()
  59. {
  60. var client = _factory.CreateClient();
  61. client.DefaultRequestHeaders.AddAuthHeader(_accessToken ??= await AuthHelper.CompleteStartupAsync(client));
  62. _ = await AuthHelper.GetUserDtoAsync(client);
  63. }
  64. [Fact]
  65. [Priority(0)]
  66. public async Task New_Valid_Success()
  67. {
  68. var client = _factory.CreateClient();
  69. // access token can't be null here as the previous test populated it
  70. client.DefaultRequestHeaders.AddAuthHeader(_accessToken!);
  71. var createRequest = new CreateUserByName()
  72. {
  73. Name = TestUsername
  74. };
  75. using var response = await CreateUserByName(client, createRequest);
  76. Assert.Equal(HttpStatusCode.OK, response.StatusCode);
  77. var user = await response.Content.ReadFromJsonAsync<UserDto>(_jsonOptions);
  78. Assert.Equal(TestUsername, user!.Name);
  79. _testUserId = user.Id;
  80. Console.WriteLine(user.Id.ToString("N", CultureInfo.InvariantCulture));
  81. }
  82. [Theory]
  83. [InlineData(null)]
  84. [InlineData("")]
  85. [InlineData(" ")]
  86. [InlineData("‼️")]
  87. [Priority(0)]
  88. public async Task New_Invalid_Fail(string? username)
  89. {
  90. var client = _factory.CreateClient();
  91. // access token can't be null here as the previous test populated it
  92. client.DefaultRequestHeaders.AddAuthHeader(_accessToken!);
  93. var createRequest = new CreateUserByName()
  94. {
  95. Name = username!
  96. };
  97. using var response = await CreateUserByName(client, createRequest);
  98. Assert.Equal(HttpStatusCode.BadRequest, response.StatusCode);
  99. }
  100. [Fact]
  101. [Priority(0)]
  102. public async Task Delete_DoesntExist_NotFound()
  103. {
  104. var client = _factory.CreateClient();
  105. // access token can't be null here as the previous test populated it
  106. client.DefaultRequestHeaders.AddAuthHeader(_accessToken!);
  107. using var response = await client.DeleteAsync($"User/{Guid.NewGuid()}");
  108. Assert.Equal(HttpStatusCode.NotFound, response.StatusCode);
  109. }
  110. [Fact]
  111. [Priority(1)]
  112. public async Task UpdateUserPassword_Valid_Success()
  113. {
  114. var client = _factory.CreateClient();
  115. client.DefaultRequestHeaders.AddAuthHeader(_accessToken!);
  116. var createRequest = new UpdateUserPassword()
  117. {
  118. NewPw = "4randomPa$$word"
  119. };
  120. using var response = await UpdateUserPassword(client, _testUserId, createRequest);
  121. Assert.Equal(HttpStatusCode.NoContent, response.StatusCode);
  122. }
  123. [Fact]
  124. [Priority(2)]
  125. public async Task UpdateUserPassword_Empty_RemoveSetPassword()
  126. {
  127. var client = _factory.CreateClient();
  128. client.DefaultRequestHeaders.AddAuthHeader(_accessToken!);
  129. var createRequest = new UpdateUserPassword()
  130. {
  131. CurrentPw = "4randomPa$$word",
  132. };
  133. using var response = await UpdateUserPassword(client, _testUserId, createRequest);
  134. Assert.Equal(HttpStatusCode.NoContent, response.StatusCode);
  135. }
  136. }
  137. }