#region CPL License /* Nuclex Framework Copyright (C) 2002-2009 Nuclex Development Labs This library is free software; you can redistribute it and/or modify it under the terms of the IBM Common Public License as published by the IBM Corporation; either version 1.0 of the License, or (at your option) any later version. This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the IBM Common Public License for more details. You should have received a copy of the IBM Common Public License along with this library */ #endregion #if UNITTEST using System; using System.Collections.Generic; using System.IO; using System.Runtime.Serialization.Formatters.Binary; using NUnit.Framework; namespace Nuclex.Networking.Http.Exceptions { /// Unit Test for the HttpException class [TestFixture] public class HttpExceptionTest { #region class TestCddbException /// Test implementation of a HTTP exception for unit testing [Serializable] private class TestHttpException : HttpException { /// Initializes the exception /// CDDB status code to provide with the exception public TestHttpException(StatusCode statusCode) : base(statusCode) { } /// Initializes the exception with an error message /// CDDB status code to provide with the exception /// Error message describing the cause of the exception public TestHttpException(StatusCode statusCode, string message) : base(statusCode, message) { } /// Initializes the exception as a followup exception /// CDDB status code to provide with the exception /// Error message describing the cause of the exception /// Preceding exception that has caused this exception public TestHttpException(StatusCode statusCode, string message, Exception inner) : base(statusCode, message, inner) { } /// Initializes the exception from its serialized state /// Contains the serialized fields of the exception /// Additional environmental informations protected TestHttpException( System.Runtime.Serialization.SerializationInfo info, System.Runtime.Serialization.StreamingContext context ) : base(info, context) { } } #endregion // class TestCddbException /// /// Verifies that the exception's default constructor is working /// [Test] public void TestDefaultConstructor() { TestHttpException testException = new TestHttpException( StatusCode.S417_Expectation_Failed ); Assert.AreEqual(StatusCode.S417_Expectation_Failed, testException.StatusCode); string testExceptionString = testException.ToString(); Assert.IsNotNull(testExceptionString); } /// /// Checks whether the exception correctly stores its inner exception /// [Test] public void TestInnerException() { Exception inner = new Exception("This is a test"); TestHttpException testException = new TestHttpException( StatusCode.S417_Expectation_Failed, "Hello World", inner ); Assert.AreSame(inner, testException.InnerException); } /// /// Test whether the exception can be serialized /// [Test] public void TestSerialization() { BinaryFormatter formatter = new BinaryFormatter(); using(MemoryStream memory = new MemoryStream()) { TestHttpException exception1 = new TestHttpException( StatusCode.S417_Expectation_Failed, "Hello World" ); formatter.Serialize(memory, exception1); memory.Position = 0; object exception2 = formatter.Deserialize(memory); Assert.IsInstanceOf(exception2); Assert.AreEqual( exception1.StatusCode, ((TestHttpException)exception2).StatusCode ); Assert.AreEqual( exception1.Message, ((TestHttpException)exception2).Message ); } } } } // namespace Nuclex.Networking.Http.Exceptions #endif // UNITTEST