2
0

UserControllerTests.cs 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  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").ConfigureAwait(false);
  38. Assert.Equal(HttpStatusCode.OK, response.StatusCode);
  39. var users = await JsonSerializer.DeserializeAsync<UserDto[]>(
  40. await response.Content.ReadAsStreamAsync().ConfigureAwait(false), _jsonOpions).ConfigureAwait(false);
  41. // User are hidden by default
  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).ConfigureAwait(false));
  50. using var response = await client.GetAsync("Users").ConfigureAwait(false);
  51. Assert.Equal(HttpStatusCode.OK, response.StatusCode);
  52. var users = await JsonSerializer.DeserializeAsync<UserDto[]>(
  53. await response.Content.ReadAsStreamAsync().ConfigureAwait(false), _jsonOpions).ConfigureAwait(false);
  54. Assert.Single(users);
  55. Assert.False(users![0].HasConfiguredPassword);
  56. }
  57. [Fact]
  58. [Priority(0)]
  59. public async Task New_Valid_Success()
  60. {
  61. var client = _factory.CreateClient();
  62. // access token can't be null here as the previous test populated it
  63. client.DefaultRequestHeaders.AddAuthHeader(_accessToken!);
  64. var createRequest = new CreateUserByName()
  65. {
  66. Name = TestUsername
  67. };
  68. using var response = await CreateUserByName(client, createRequest).ConfigureAwait(false);
  69. Assert.Equal(HttpStatusCode.OK, response.StatusCode);
  70. var user = await JsonSerializer.DeserializeAsync<UserDto>(
  71. await response.Content.ReadAsStreamAsync().ConfigureAwait(false), _jsonOpions).ConfigureAwait(false);
  72. Assert.Equal(TestUsername, user!.Name);
  73. Assert.False(user.HasPassword);
  74. Assert.False(user.HasConfiguredPassword);
  75. _testUserId = user.Id;
  76. Console.WriteLine(user.Id.ToString("N", CultureInfo.InvariantCulture));
  77. }
  78. [Theory]
  79. [InlineData(null)]
  80. [InlineData("")]
  81. [InlineData(" ")]
  82. [InlineData("‼️")]
  83. [Priority(0)]
  84. public async Task New_Invalid_Fail(string? username)
  85. {
  86. var client = _factory.CreateClient();
  87. // access token can't be null here as the previous test populated it
  88. client.DefaultRequestHeaders.AddAuthHeader(_accessToken!);
  89. var createRequest = new CreateUserByName()
  90. {
  91. Name = username
  92. };
  93. using var response = await CreateUserByName(client, createRequest).ConfigureAwait(false);
  94. Assert.Equal(HttpStatusCode.BadRequest, response.StatusCode);
  95. }
  96. [Fact]
  97. [Priority(1)]
  98. public async Task UpdateUserPassword_Valid_Success()
  99. {
  100. var client = _factory.CreateClient();
  101. client.DefaultRequestHeaders.AddAuthHeader(_accessToken!);
  102. var createRequest = new UpdateUserPassword()
  103. {
  104. NewPw = "4randomPa$$word"
  105. };
  106. using var response = await UpdateUserPassword(client, _testUserId, createRequest).ConfigureAwait(false);
  107. Assert.Equal(HttpStatusCode.NoContent, response.StatusCode);
  108. var users = await JsonSerializer.DeserializeAsync<UserDto[]>(
  109. await client.GetStreamAsync("Users").ConfigureAwait(false), _jsonOpions).ConfigureAwait(false);
  110. var user = users!.First(x => x.Id.Equals(_testUserId));
  111. Assert.True(user.HasPassword);
  112. Assert.True(user.HasConfiguredPassword);
  113. }
  114. [Fact]
  115. [Priority(2)]
  116. public async Task UpdateUserPassword_Empty_RemoveSetPassword()
  117. {
  118. var client = _factory.CreateClient();
  119. client.DefaultRequestHeaders.AddAuthHeader(_accessToken!);
  120. var createRequest = new UpdateUserPassword()
  121. {
  122. CurrentPw = "4randomPa$$word",
  123. };
  124. using var response = await UpdateUserPassword(client, _testUserId, createRequest).ConfigureAwait(false);
  125. Assert.Equal(HttpStatusCode.NoContent, response.StatusCode);
  126. var users = await JsonSerializer.DeserializeAsync<UserDto[]>(
  127. await client.GetStreamAsync("Users").ConfigureAwait(false), _jsonOpions).ConfigureAwait(false);
  128. var user = users!.First(x => x.Id.Equals(_testUserId));
  129. Assert.False(user.HasPassword);
  130. Assert.False(user.HasConfiguredPassword);
  131. }
  132. }
  133. }