summaryrefslogtreecommitdiffstats
path: root/src/DotNetOpenAuth.Test/OAuth2/WebServerClientAuthorizeTests.cs
diff options
context:
space:
mode:
authorAndrew Arnott <andrewarnott@gmail.com>2012-09-26 17:30:39 -0700
committerAndrew Arnott <andrewarnott@gmail.com>2012-09-26 17:30:39 -0700
commit6989c1b54778cc93edf9b305ffb827c389769c07 (patch)
tree46b7c453c7901dd733f9ccfcb1377fbab5006c9b /src/DotNetOpenAuth.Test/OAuth2/WebServerClientAuthorizeTests.cs
parenta657a72b7f6fb89d1a8adb82d2888a8d3f7f9bab (diff)
downloadDotNetOpenAuth-6989c1b54778cc93edf9b305ffb827c389769c07.zip
DotNetOpenAuth-6989c1b54778cc93edf9b305ffb827c389769c07.tar.gz
DotNetOpenAuth-6989c1b54778cc93edf9b305ffb827c389769c07.tar.bz2
Adds ClientBase.CreateAuthorizingHandler
This method creates an HttpMessageHandler that automatically applies the OAuth 2 access token (bearer) to all outbound HTTP requests. Fixes #205
Diffstat (limited to 'src/DotNetOpenAuth.Test/OAuth2/WebServerClientAuthorizeTests.cs')
-rw-r--r--src/DotNetOpenAuth.Test/OAuth2/WebServerClientAuthorizeTests.cs42
1 files changed, 42 insertions, 0 deletions
diff --git a/src/DotNetOpenAuth.Test/OAuth2/WebServerClientAuthorizeTests.cs b/src/DotNetOpenAuth.Test/OAuth2/WebServerClientAuthorizeTests.cs
index f5d9b8c..9a9c078 100644
--- a/src/DotNetOpenAuth.Test/OAuth2/WebServerClientAuthorizeTests.cs
+++ b/src/DotNetOpenAuth.Test/OAuth2/WebServerClientAuthorizeTests.cs
@@ -9,7 +9,9 @@ namespace DotNetOpenAuth.Test.OAuth2 {
using System.Collections.Generic;
using System.Linq;
using System.Net;
+ using System.Net.Http;
using System.Text;
+ using System.Threading.Tasks;
using DotNetOpenAuth.Messaging;
using DotNetOpenAuth.OAuth2;
using DotNetOpenAuth.OAuth2.ChannelElements;
@@ -98,5 +100,45 @@ namespace DotNetOpenAuth.Test.OAuth2 {
});
coordinator.Run();
}
+
+ [Test]
+ public void CreateAuthorizingHandlerBearer() {
+ var client = new WebServerClient(AuthorizationServerDescription);
+ string bearerToken = "mytoken";
+ var tcs = new TaskCompletionSource<HttpResponseMessage>();
+ var expectedResponse = new HttpResponseMessage();
+
+ var mockHandler = new Mocks.MockHttpMessageHandler((req, ct) => {
+ Assert.That(req.Headers.Authorization.Scheme, Is.EqualTo(Protocol.BearerHttpAuthorizationScheme));
+ Assert.That(req.Headers.Authorization.Parameter, Is.EqualTo(bearerToken));
+ tcs.SetResult(expectedResponse);
+ return tcs.Task;
+ });
+ var applicator = client.CreateAuthorizingHandler("mytoken", mockHandler);
+ var httpClient = new HttpClient(applicator);
+ var actualResponse = httpClient.GetAsync("http://localhost/someMessage").Result;
+ Assert.That(actualResponse, Is.SameAs(expectedResponse));
+ }
+
+ [Test]
+ public void CreateAuthorizingHandlerAuthorization() {
+ var client = new WebServerClient(AuthorizationServerDescription);
+ string bearerToken = "mytoken";
+ var authorization = new Mock<IAuthorizationState>();
+ authorization.SetupGet(a => a.AccessToken).Returns(bearerToken);
+ var tcs = new TaskCompletionSource<HttpResponseMessage>();
+ var expectedResponse = new HttpResponseMessage();
+
+ var mockHandler = new Mocks.MockHttpMessageHandler((req, ct) => {
+ Assert.That(req.Headers.Authorization.Scheme, Is.EqualTo(Protocol.BearerHttpAuthorizationScheme));
+ Assert.That(req.Headers.Authorization.Parameter, Is.EqualTo(bearerToken));
+ tcs.SetResult(expectedResponse);
+ return tcs.Task;
+ });
+ var applicator = client.CreateAuthorizingHandler(authorization.Object, mockHandler);
+ var httpClient = new HttpClient(applicator);
+ var actualResponse = httpClient.GetAsync("http://localhost/someMessage").Result;
+ Assert.That(actualResponse, Is.SameAs(expectedResponse));
+ }
}
}