-
Notifications
You must be signed in to change notification settings - Fork 46
Expand file tree
/
Copy pathAccessTokenHandlerTests.cs
More file actions
72 lines (55 loc) · 2.56 KB
/
AccessTokenHandlerTests.cs
File metadata and controls
72 lines (55 loc) · 2.56 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
// Copyright (c) Duende Software. All rights reserved.
// Licensed under the Apache License, Version 2.0. See LICENSE in the project root for license information.
using Microsoft.Extensions.Logging;
namespace Duende.AccessTokenManagement.Tests;
public class AccessTokenHandlerTests
{
TestDPoPProofService _testDPoPProofService = new TestDPoPProofService();
TestHttpMessageHandler _testHttpMessageHandler = new TestHttpMessageHandler();
AccessTokenHandlerSubject _subject;
public AccessTokenHandlerTests(ITestOutputHelper output)
{
_subject = new AccessTokenHandlerSubject(_testDPoPProofService, new TestDPoPNonceStore(), new TestLoggerProvider(output.WriteLine, "AccessTokenHandler").CreateLogger("AccessTokenHandlerSubject"));
_subject.InnerHandler = _testHttpMessageHandler;
}
[Fact]
public async Task lower_case_token_type_should_be_converted_to_case_sensitive()
{
var client = new HttpClient(_subject);
{
_subject.AccessToken.AccessTokenType = "bearer";
var response = await client.GetAsync("https://test/api");
_testHttpMessageHandler.Request!.Headers.Authorization!.Scheme.ShouldBe("Bearer");
}
{
_subject.AccessToken.AccessTokenType = "dpop";
var response = await client.GetAsync("https://test/api");
_testHttpMessageHandler.Request!.Headers.Authorization!.Scheme.ShouldBe("DPoP");
}
}
public class TestHttpMessageHandler : HttpMessageHandler
{
public HttpRequestMessage? Request { get; set; }
public HttpResponseMessage Response { get; set; } = new HttpResponseMessage(System.Net.HttpStatusCode.NoContent);
protected override Task<HttpResponseMessage> SendAsync(HttpRequestMessage request, CancellationToken cancellationToken)
{
Request = request;
return Task.FromResult(Response);
}
}
public class AccessTokenHandlerSubject : AccessTokenHandler
{
public ClientCredentialsToken AccessToken { get; set; } = new ClientCredentialsToken
{
AccessToken = "at",
AccessTokenType = "bearer",
};
public AccessTokenHandlerSubject(IDPoPProofService dPoPProofService, IDPoPNonceStore dPoPNonceStore, ILogger logger) : base(dPoPProofService, dPoPNonceStore, logger)
{
}
protected override Task<ClientCredentialsToken> GetAccessTokenAsync(bool forceRenewal, CancellationToken cancellationToken)
{
return Task.FromResult(AccessToken);
}
}
}