thalos-bff/tests/Thalos.Bff.Application.UnitTests/RefreshSessionHandlerTests.cs
2026-02-24 05:26:54 -06:00

68 lines
2.6 KiB
C#

using Thalos.Bff.Application.Adapters;
using Thalos.Bff.Application.Handlers;
using Thalos.Bff.Contracts.Api;
using BuildingBlock.Identity.Contracts.Requests;
using BuildingBlock.Identity.Contracts.Responses;
namespace Thalos.Bff.Application.UnitTests;
public class RefreshSessionHandlerTests
{
[Fact]
public async Task HandleAsync_WhenCalled_MapsThroughContractAdapter()
{
var handler = new RefreshSessionHandler(new FakeThalosServiceClient(), new FakeIdentityEdgeContractAdapter());
var response = await handler.HandleAsync(new RefreshSessionApiRequest("refresh-123", "corr-123"));
Assert.Equal("token-refreshed", 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);
}
}
}