Assert.AreEqual (response, client.SendAsync (request).Result, "#1");
}
+ [Test]
+ public void Send_BaseAddress ()
+ {
+ var mh = new HttpMessageHandlerMock ();
+
+ var client = new HttpClient (mh);
+ client.BaseAddress = new Uri ("http://localhost/");
+ var response = new HttpResponseMessage ();
+
+ mh.OnSend = l => {
+ Assert.AreEqual ("http://localhost/relative", l.RequestUri.ToString (), "#2");
+ return Task.FromResult (response);
+ };
+
+ Assert.AreEqual (response, client.GetAsync ("relative").Result, "#1");
+ Assert.AreEqual (response, client.GetAsync ("/relative").Result, "#2");
+ }
+
[Test]
public void Send_DefaultRequestHeaders ()
{
}
}
+ [Test]
+ public void Send_Complete_CustomHeaders_SpecialSeparators ()
+ {
+ bool? failed = null;
+
+ var listener = CreateListener (l => {
+ var request = l.Request;
+
+ try {
+ Assert.AreEqual ("MLK Android Phone 1.1.9", request.UserAgent, "#1");
+ failed = false;
+ } catch {
+ failed = true;
+ }
+ });
+
+ try {
+ var client = new HttpClient ();
+
+ client.DefaultRequestHeaders.Add("User-Agent", "MLK Android Phone 1.1.9");
+
+ var request = new HttpRequestMessage (HttpMethod.Get, LocalServer);
+
+ var response = client.SendAsync (request, HttpCompletionOption.ResponseHeadersRead).Result;
+
+ Assert.AreEqual ("", response.Content.ReadAsStringAsync ().Result, "#100");
+ Assert.AreEqual (HttpStatusCode.OK, response.StatusCode, "#101");
+ Assert.AreEqual (false, failed, "#102");
+ } finally {
+ listener.Abort ();
+ listener.Close ();
+ }
+ }
+
+ [Test]
+ public void Send_Complete_CustomHeaders_Host ()
+ {
+ bool? failed = null;
+ var listener = CreateListener (l => {
+ var request = l.Request;
+
+ try {
+ Assert.AreEqual ("customhost", request.Headers["Host"], "#1");
+ failed = false;
+ } catch {
+ failed = true;
+ }
+ });
+
+ try {
+ var client = new HttpClient ();
+
+ client.DefaultRequestHeaders.Add("Host", "customhost");
+
+ var request = new HttpRequestMessage (HttpMethod.Get, LocalServer);
+
+ var response = client.SendAsync (request, HttpCompletionOption.ResponseHeadersRead).Result;
+
+ Assert.AreEqual ("", response.Content.ReadAsStringAsync ().Result, "#100");
+ Assert.AreEqual (HttpStatusCode.OK, response.StatusCode, "#101");
+ Assert.AreEqual (false, failed, "#102");
+ } finally {
+ listener.Abort ();
+ listener.Close ();
+ }
+ }
+
+ [Test]
+ public void Send_Transfer_Encoding_Chunked ()
+ {
+ bool? failed = null;
+
+ var listener = CreateListener (l => {
+ var request = l.Request;
+
+ try {
+ Assert.AreEqual (1, request.Headers.Count, "#1");
+ failed = false;
+ } catch {
+ failed = true;
+ }
+ });
+
+ try {
+ var client = new HttpClient ();
+ client.DefaultRequestHeaders.TransferEncodingChunked = true;
+
+ client.GetAsync (LocalServer).Wait ();
+
+ Assert.AreEqual (false, failed, "#102");
+ } finally {
+ listener.Abort ();
+ listener.Close ();
+ }
+ }
+
+ [Test]
+ public void Send_Transfer_Encoding_Custom ()
+ {
+ bool? failed = null;
+
+ var listener = CreateListener (l => {
+ failed = true;
+ });
+
+ try {
+ var client = new HttpClient ();
+ client.DefaultRequestHeaders.TransferEncoding.Add (new TransferCodingHeaderValue ("chunked2"));
+
+ var request = new HttpRequestMessage (HttpMethod.Get, LocalServer);
+
+ try {
+ client.SendAsync (request, HttpCompletionOption.ResponseHeadersRead).Wait ();
+ Assert.Fail ("#1");
+ } catch (AggregateException e) {
+ Assert.AreEqual (typeof (ProtocolViolationException), e.InnerException.GetType (), "#2");
+ }
+ Assert.IsNull (failed, "#102");
+ } finally {
+ listener.Abort ();
+ listener.Close ();
+ }
+ }
+
[Test]
public void Send_Complete_Content ()
{
}
}
- [Test]
- public void GetString_RelativeUri ()
- {
- var client = new HttpClient ();
- client.BaseAddress = new Uri ("http://en.wikipedia.org/wiki/");
- var uri = new Uri ("Computer", UriKind.Relative);
-
- Assert.That (client.GetStringAsync (uri).Result != null);
- Assert.That (client.GetStringAsync ("Computer").Result != null);
- }
-
[Test]
[Category ("MobileNotWorking")] // Missing encoding
public void GetString_Many ()