#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