thalos-bff/tests/Thalos.Bff.Application.UnitTests/IssueTokenHandlerTests.cs
2026-02-22 04:10:17 -06:00

77 lines
2.9 KiB
C#

using Thalos.Bff.Application.Contracts;
using Thalos.Bff.Application.Adapters;
using Thalos.Bff.Application.Handlers;
using Thalos.Bff.Application.Security;
using Thalos.Bff.Contracts.Api;
using Thalos.Service.Identity.Abstractions.Contracts;
namespace Thalos.Bff.Application.UnitTests;
public class IssueTokenHandlerTests
{
[Fact]
public async Task HandleAsync_WhenPermissionAllowed_DelegatesToServiceClient()
{
var handler = new IssueTokenHandler(
new FakeThalosServiceClient(),
new FakeIdentityEdgeContractAdapter(),
new AllowPermissionGuard());
var response = await handler.HandleAsync(new IssueTokenApiRequest("user-1", "tenant-1", "corr-123"));
Assert.Equal("token-xyz", response.AccessToken);
Assert.Equal(1800, response.ExpiresInSeconds);
}
private sealed class FakeThalosServiceClient : IThalosServiceClient
{
public Task<IssueIdentityTokenResponse> IssueTokenAsync(IssueIdentityTokenRequest request)
{
return Task.FromResult(new IssueIdentityTokenResponse("token-xyz", 1800));
}
public Task<EvaluateIdentityPolicyResponse> EvaluatePolicyAsync(EvaluateIdentityPolicyRequest request)
{
return Task.FromResult(new EvaluateIdentityPolicyResponse(request.SubjectId, request.PermissionCode, true));
}
public Task<RefreshIdentitySessionResponse> RefreshSessionAsync(RefreshIdentitySessionRequest request)
{
return Task.FromResult(new RefreshIdentitySessionResponse("token-refreshed", 1800));
}
}
private sealed class FakeIdentityEdgeContractAdapter : IIdentityEdgeContractAdapter
{
public EvaluateIdentityPolicyRequest ToPolicyRequest(IssueTokenApiRequest request, string permissionCode)
{
return new EvaluateIdentityPolicyRequest(request.SubjectId, request.TenantId, permissionCode);
}
public IssueIdentityTokenRequest ToIssueTokenRequest(IssueTokenApiRequest request)
{
return new IssueIdentityTokenRequest(request.SubjectId, request.TenantId);
}
public IssueTokenApiResponse ToIssueTokenApiResponse(IssueIdentityTokenResponse response)
{
return new IssueTokenApiResponse(response.Token, response.ExpiresInSeconds);
}
public RefreshIdentitySessionRequest ToRefreshSessionRequest(RefreshSessionApiRequest request)
{
return new RefreshIdentitySessionRequest(request.RefreshToken, request.CorrelationId);
}
public RefreshSessionApiResponse ToRefreshSessionApiResponse(RefreshIdentitySessionResponse response)
{
return new RefreshSessionApiResponse(response.Token, response.ExpiresInSeconds);
}
}
private sealed class AllowPermissionGuard : IPermissionGuard
{
public bool CanAccess(EvaluateIdentityPolicyResponse policyResponse) => policyResponse.IsAllowed;
}
}