Validate AuthenticationProviderId and PasswordResetProviderId (#10553)
This commit is contained in:
parent
b1acde54fb
commit
3fd505a454
|
@ -171,6 +171,7 @@
|
|||
- [tallbl0nde](https://github.com/tallbl0nde)
|
||||
- [sleepycatcoding](https://github.com/sleepycatcoding)
|
||||
- [scampower3](https://github.com/scampower3)
|
||||
- [Chris-Codes-It] (https://github.com/Chris-Codes-It)
|
||||
|
||||
# Emby Contributors
|
||||
|
||||
|
@ -241,4 +242,4 @@
|
|||
- [Jakob Kukla](https://github.com/jakobkukla)
|
||||
- [Utku Özdemir](https://github.com/utkuozdemir)
|
||||
- [JPUC1143](https://github.com/Jpuc1143/)
|
||||
- [0x25CBFC4F](https://github.com/0x25CBFC4F)
|
||||
- [0x25CBFC4F](https://github.com/0x25CBFC4F)
|
|
@ -3,6 +3,7 @@
|
|||
|
||||
using System;
|
||||
using System.ComponentModel;
|
||||
using System.ComponentModel.DataAnnotations;
|
||||
using System.Xml.Serialization;
|
||||
using Jellyfin.Data.Enums;
|
||||
using AccessSchedule = Jellyfin.Data.Entities.AccessSchedule;
|
||||
|
@ -174,8 +175,10 @@ namespace MediaBrowser.Model.Users
|
|||
public int RemoteClientBitrateLimit { get; set; }
|
||||
|
||||
[XmlElement(ElementName = "AuthenticationProviderId")]
|
||||
[Required(AllowEmptyStrings = false)]
|
||||
public string AuthenticationProviderId { get; set; }
|
||||
|
||||
[Required(AllowEmptyStrings= false)]
|
||||
public string PasswordResetProviderId { get; set; }
|
||||
|
||||
/// <summary>
|
||||
|
|
120
tests/Jellyfin.Api.Tests/Controllers/UserControllerTests.cs
Normal file
120
tests/Jellyfin.Api.Tests/Controllers/UserControllerTests.cs
Normal file
|
@ -0,0 +1,120 @@
|
|||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.ComponentModel.DataAnnotations;
|
||||
using System.Linq;
|
||||
using System.Threading.Tasks;
|
||||
using AutoFixture.Xunit2;
|
||||
using Jellyfin.Api.Controllers;
|
||||
using Jellyfin.Data.Entities;
|
||||
using MediaBrowser.Common.Net;
|
||||
using MediaBrowser.Controller.Configuration;
|
||||
using MediaBrowser.Controller.Devices;
|
||||
using MediaBrowser.Controller.Library;
|
||||
using MediaBrowser.Controller.Net;
|
||||
using MediaBrowser.Controller.Playlists;
|
||||
using MediaBrowser.Controller.QuickConnect;
|
||||
using MediaBrowser.Controller.Session;
|
||||
using MediaBrowser.Model.Users;
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
using Microsoft.Extensions.Logging;
|
||||
using Moq;
|
||||
using Nikse.SubtitleEdit.Core.Common;
|
||||
using Xunit;
|
||||
|
||||
namespace Jellyfin.Api.Tests.Controllers;
|
||||
|
||||
public class UserControllerTests
|
||||
{
|
||||
private readonly UserController _subject;
|
||||
private readonly Mock<IUserManager> _mockUserManager;
|
||||
private readonly Mock<ISessionManager> _mockSessionManager;
|
||||
private readonly Mock<INetworkManager> _mockNetworkManager;
|
||||
private readonly Mock<IDeviceManager> _mockDeviceManager;
|
||||
private readonly Mock<IAuthorizationContext> _mockAuthorizationContext;
|
||||
private readonly Mock<IServerConfigurationManager> _mockServerConfigurationManager;
|
||||
private readonly Mock<ILogger<UserController>> _mockLogger;
|
||||
private readonly Mock<IQuickConnect> _mockQuickConnect;
|
||||
private readonly Mock<IPlaylistManager> _mockPlaylistManager;
|
||||
|
||||
public UserControllerTests()
|
||||
{
|
||||
_mockUserManager = new Mock<IUserManager>();
|
||||
_mockSessionManager = new Mock<ISessionManager>();
|
||||
_mockNetworkManager = new Mock<INetworkManager>();
|
||||
_mockDeviceManager = new Mock<IDeviceManager>();
|
||||
_mockAuthorizationContext = new Mock<IAuthorizationContext>();
|
||||
_mockServerConfigurationManager = new Mock<IServerConfigurationManager>();
|
||||
_mockLogger = new Mock<ILogger<UserController>>();
|
||||
_mockQuickConnect = new Mock<IQuickConnect>();
|
||||
_mockPlaylistManager = new Mock<IPlaylistManager>();
|
||||
|
||||
_subject = new UserController(
|
||||
_mockUserManager.Object,
|
||||
_mockSessionManager.Object,
|
||||
_mockNetworkManager.Object,
|
||||
_mockDeviceManager.Object,
|
||||
_mockAuthorizationContext.Object,
|
||||
_mockServerConfigurationManager.Object,
|
||||
_mockLogger.Object,
|
||||
_mockQuickConnect.Object,
|
||||
_mockPlaylistManager.Object);
|
||||
}
|
||||
|
||||
[Theory]
|
||||
[AutoData]
|
||||
public async Task UpdateUserPolicy_WhenUserNotFound_ReturnsNotFound(Guid userId, UserPolicy userPolicy)
|
||||
{
|
||||
User? nullUser = null;
|
||||
_mockUserManager.
|
||||
Setup(m => m.GetUserById(userId))
|
||||
.Returns(nullUser);
|
||||
|
||||
Assert.IsType<NotFoundResult>(await _subject.UpdateUserPolicy(userId, userPolicy));
|
||||
}
|
||||
|
||||
[Theory]
|
||||
[InlineAutoData(null)]
|
||||
[InlineAutoData("")]
|
||||
[InlineAutoData(" ")]
|
||||
public void UpdateUserPolicy_WhenPasswordResetProviderIdNotSupplied_ReturnsBadRequest(string? passwordResetProviderId)
|
||||
{
|
||||
var userPolicy = new UserPolicy
|
||||
{
|
||||
PasswordResetProviderId = passwordResetProviderId,
|
||||
AuthenticationProviderId = "AuthenticationProviderId"
|
||||
};
|
||||
|
||||
Assert.Contains(
|
||||
Validate(userPolicy), v =>
|
||||
v.MemberNames.Contains("PasswordResetProviderId") &&
|
||||
v.ErrorMessage != null &&
|
||||
v.ErrorMessage.Contains("required", StringComparison.CurrentCultureIgnoreCase));
|
||||
}
|
||||
|
||||
[Theory]
|
||||
[InlineAutoData(null)]
|
||||
[InlineAutoData("")]
|
||||
[InlineAutoData(" ")]
|
||||
public void UpdateUserPolicy_WhenAuthenticationProviderIdNotSupplied_ReturnsBadRequest(string? authenticationProviderId)
|
||||
{
|
||||
var userPolicy = new UserPolicy
|
||||
{
|
||||
AuthenticationProviderId = authenticationProviderId,
|
||||
PasswordResetProviderId = "PasswordResetProviderId"
|
||||
};
|
||||
|
||||
Assert.Contains(Validate(userPolicy), v =>
|
||||
v.MemberNames.Contains("AuthenticationProviderId") &&
|
||||
v.ErrorMessage != null &&
|
||||
v.ErrorMessage.Contains("required", StringComparison.CurrentCultureIgnoreCase));
|
||||
}
|
||||
|
||||
private IList<ValidationResult> Validate(object model)
|
||||
{
|
||||
var result = new List<ValidationResult>();
|
||||
var context = new ValidationContext(model, null, null);
|
||||
Validator.TryValidateObject(model, context, result, true);
|
||||
|
||||
return result;
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user