Backend/e-suite.API/eSuite.API.UnitTests/Controllers/AuthenticationControllerUnitTests/AuthenticationControllerTestBase.cs
2026-01-20 21:50:10 +00:00

45 lines
1.5 KiB
C#

using System.Security.Claims;
using e_suite.API.Common;
using e_suite.Service.Sentinel;
using e_suite.UnitTestCore;
using eSuite.API.Controllers;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using Moq;
namespace eSuite.API.UnitTests.Controllers.AuthenticationControllerUnitTests;
public abstract class AuthenticationControllerTestBase : TestBase
{
protected AuthenticationController _authenticationController = null!;
protected Mock<IUserManager> _userManagerMock = null!;
protected Mock<ISentinel> _sentinelMock = null!;
protected const string AccessDeniedText = "Access denied";
protected const string LoginAcceptedText = "Login accepted";
public override async Task Setup()
{
await base.Setup();
_userManagerMock = new Mock<IUserManager>();
_sentinelMock = new Mock<ISentinel>();
_authenticationController = new AuthenticationController(_userManagerMock.Object, _sentinelMock.Object);
}
protected void AddAuthorisedUserToController(long id, string email, string displayName)
{
var user = new ClaimsPrincipal(new ClaimsIdentity([
new(ClaimTypes.PrimarySid, id.ToString()),
new(ClaimTypes.Email, email),
new(ClaimTypes.Name, displayName)
// other required and custom claims
], "TestAuthentication"));
_authenticationController.ControllerContext = new ControllerContext
{
HttpContext = new DefaultHttpContext { User = user }
};
}
}