Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/mono/mono.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarek Safar <marek.safar@gmail.com>2014-06-24 15:57:53 +0400
committerMarek Safar <marek.safar@gmail.com>2014-06-24 16:20:16 +0400
commitbfa0db9efa35d96e35400603e4c8e49e2162faa9 (patch)
treee1fc42035cf83dea3b323491993499b45d9e8baf /mcs/class/System.Net.Http
parent4e937922fa1a857e1c74ac9127ee5d5f3b91f09d (diff)
[System.Net.Http] Fix disposing of DelegatingHandler. Fixes #20818
Diffstat (limited to 'mcs/class/System.Net.Http')
-rw-r--r--mcs/class/System.Net.Http/System.Net.Http/DelegatingHandler.cs16
-rw-r--r--mcs/class/System.Net.Http/System.Net.Http_test.dll.sources1
-rw-r--r--mcs/class/System.Net.Http/Test/System.Net.Http/DelegatingHandlerTest.cs63
3 files changed, 78 insertions, 2 deletions
diff --git a/mcs/class/System.Net.Http/System.Net.Http/DelegatingHandler.cs b/mcs/class/System.Net.Http/System.Net.Http/DelegatingHandler.cs
index 2458975d687..fe940df8962 100644
--- a/mcs/class/System.Net.Http/System.Net.Http/DelegatingHandler.cs
+++ b/mcs/class/System.Net.Http/System.Net.Http/DelegatingHandler.cs
@@ -34,6 +34,7 @@ namespace System.Net.Http
public abstract class DelegatingHandler : HttpMessageHandler
{
bool disposed;
+ HttpMessageHandler handler;
protected DelegatingHandler ()
{
@@ -47,13 +48,24 @@ namespace System.Net.Http
InnerHandler = innerHandler;
}
- public HttpMessageHandler InnerHandler { get; set; }
+ public HttpMessageHandler InnerHandler {
+ get {
+ return handler;
+ }
+ set {
+ if (value == null)
+ throw new ArgumentNullException ("InnerHandler");
+
+ handler = value;
+ }
+ }
protected override void Dispose (bool disposing)
{
if (disposing && !disposed) {
disposed = true;
- InnerHandler.Dispose ();
+ if (InnerHandler != null)
+ InnerHandler.Dispose ();
}
base.Dispose (disposing);
diff --git a/mcs/class/System.Net.Http/System.Net.Http_test.dll.sources b/mcs/class/System.Net.Http/System.Net.Http_test.dll.sources
index e5ce8f75050..29d4d75f5e3 100644
--- a/mcs/class/System.Net.Http/System.Net.Http_test.dll.sources
+++ b/mcs/class/System.Net.Http/System.Net.Http_test.dll.sources
@@ -1,3 +1,4 @@
+System.Net.Http/DelegatingHandlerTest.cs
System.Net.Http/ByteArrayContentTest.cs
System.Net.Http/FormUrlEncodedContentTest.cs
System.Net.Http/HttpClientHandlerTest.cs
diff --git a/mcs/class/System.Net.Http/Test/System.Net.Http/DelegatingHandlerTest.cs b/mcs/class/System.Net.Http/Test/System.Net.Http/DelegatingHandlerTest.cs
new file mode 100644
index 00000000000..d6812e7f1d2
--- /dev/null
+++ b/mcs/class/System.Net.Http/Test/System.Net.Http/DelegatingHandlerTest.cs
@@ -0,0 +1,63 @@
+//
+// DelegatingHandlerTest.cs
+//
+// Authors:
+// Marek Safar <marek.safar@gmail.com>
+//
+// Copyright (C) 2014 Xamarin Inc (http://www.xamarin.com)
+//
+// Permission is hereby granted, free of charge, to any person obtaining
+// a copy of this software and associated documentation files (the
+// "Software"), to deal in the Software without restriction, including
+// without limitation the rights to use, copy, modify, merge, publish,
+// distribute, sublicense, and/or sell copies of the Software, and to
+// permit persons to whom the Software is furnished to do so, subject to
+// the following conditions:
+//
+// The above copyright notice and this permission notice shall be
+// included in all copies or substantial portions of the Software.
+//
+// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
+// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
+// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
+// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+//
+
+using System;
+using NUnit.Framework;
+using System.Net.Http;
+using System.IO;
+using System.Threading.Tasks;
+
+namespace MonoTests.System.Net.Http
+{
+ [TestFixture]
+ public class DelegatingHandlerTest
+ {
+ class DefaultHandler : DelegatingHandler
+ {
+ }
+
+
+ [Test]
+ public void DisposeTest ()
+ {
+ var handler = new DefaultHandler ();
+ handler.Dispose ();
+ }
+
+ [Test]
+ public void InnerHandler_Invalid ()
+ {
+ var handler = new DefaultHandler ();
+ try {
+ handler.InnerHandler = null;
+ Assert.Fail ("#1");
+ } catch (ArgumentNullException) {
+ }
+ }
+ }
+}