blob: 2e2a9601fa950a7456a487f655ba22793b223c13 (
plain)
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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
|
//-----------------------------------------------------------------------
// <copyright file="NonIdentityTests.cs" company="Outercurve Foundation">
// Copyright (c) Outercurve Foundation. All rights reserved.
// </copyright>
//-----------------------------------------------------------------------
namespace DotNetOpenAuth.Test.OpenId {
using System;
using System.Net;
using System.Net.Http;
using System.Threading;
using System.Threading.Tasks;
using DotNetOpenAuth.Messaging;
using DotNetOpenAuth.OpenId;
using DotNetOpenAuth.OpenId.Messages;
using DotNetOpenAuth.OpenId.Provider;
using DotNetOpenAuth.OpenId.RelyingParty;
using NUnit.Framework;
[TestFixture]
public class NonIdentityTests : OpenIdTestBase {
[Test]
public async Task ExtensionOnlyChannelLevel() {
Protocol protocol = Protocol.V20;
var mode = AuthenticationRequestMode.Setup;
HandleProvider(
async (op, req) => {
var request = await op.Channel.ReadFromRequestAsync<SignedResponseRequest>(req, CancellationToken.None);
Assert.IsNotInstanceOf<CheckIdRequest>(request);
return new HttpResponseMessage();
});
{
var rp = this.CreateRelyingParty();
var request = new SignedResponseRequest(protocol.Version, OPUri, mode);
var authRequest = await rp.Channel.PrepareResponseAsync(request);
using (var httpClient = rp.Channel.HostFactories.CreateHttpClient()) {
using (var response = await httpClient.GetAsync(authRequest.Headers.Location)) {
response.EnsureSuccessStatusCode();
}
}
}
}
[Test]
public async Task ExtensionOnlyFacadeLevel() {
Protocol protocol = Protocol.V20;
int opStep = 0;
HandleProvider(
async (op, req) => {
switch (++opStep) {
case 1:
var assocRequest = await op.GetRequestAsync(req);
return await op.PrepareResponseAsync(assocRequest);
case 2:
var request = (IAnonymousRequest)await op.GetRequestAsync(req);
request.IsApproved = true;
Assert.IsNotInstanceOf<CheckIdRequest>(request);
return await op.PrepareResponseAsync(request);
default:
throw Assumes.NotReachable();
}
});
{
var rp = this.CreateRelyingParty();
var request = await rp.CreateRequestAsync(GetMockIdentifier(protocol.ProtocolVersion), RPRealmUri, RPUri);
request.IsExtensionOnly = true;
var redirectRequest = await request.GetRedirectingResponseAsync();
Uri redirectResponseUrl;
this.HostFactories.AllowAutoRedirects = false;
using (var httpClient = this.HostFactories.CreateHttpClient()) {
using (var redirectResponse = await httpClient.GetAsync(redirectRequest.Headers.Location)) {
Assert.That(redirectResponse.StatusCode, Is.EqualTo(HttpStatusCode.Redirect));
redirectResponseUrl = redirectResponse.Headers.Location;
}
}
IAuthenticationResponse response =
await rp.GetResponseAsync(new HttpRequestMessage(HttpMethod.Get, redirectResponseUrl));
Assert.AreEqual(AuthenticationStatus.ExtensionsOnly, response.Status);
}
}
}
}
|