Increased test coverage for the command line parser (and then decided the thing is broken beyond repair and needs a rewrite -- as if that was any surprise given the original code is from CodeProject); achieved 100% test coverage for the factory employer, instance employer, employer, no plugin attribute and abstract factory classes in the Plugins namespace; achieved some test coverage for the PluginRepository class (the uncovered sections are quite hard to stimulate since they involve exceptions during assembly load attempts)
git-svn-id: file:///srv/devel/repo-conversion/nusu@99 d2e56fa2-650e-0410-a79f-9358c0239efd
This commit is contained in:
parent
ecb36e9ce3
commit
b39f8de155
|
@ -123,16 +123,37 @@
|
||||||
<DependentUpon>PathHelper.cs</DependentUpon>
|
<DependentUpon>PathHelper.cs</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
<Compile Include="Source\Plugins\AbstractFactory.cs" />
|
<Compile Include="Source\Plugins\AbstractFactory.cs" />
|
||||||
|
<Compile Include="Source\Plugins\AbstractFactory.Test.cs">
|
||||||
|
<DependentUpon>AbstractFactory.cs</DependentUpon>
|
||||||
|
</Compile>
|
||||||
|
<Compile Include="Source\Plugins\Employer.Test.cs">
|
||||||
|
<DependentUpon>Employer.cs</DependentUpon>
|
||||||
|
</Compile>
|
||||||
|
<Compile Include="Source\Plugins\FactoryEmployer.Test.cs">
|
||||||
|
<DependentUpon>FactoryEmployer.cs</DependentUpon>
|
||||||
|
</Compile>
|
||||||
|
<Compile Include="Source\Plugins\InstanceEmployer.Test.cs">
|
||||||
|
<DependentUpon>InstanceEmployer.cs</DependentUpon>
|
||||||
|
</Compile>
|
||||||
<Compile Include="Source\Plugins\NoPluginAttribute.cs" />
|
<Compile Include="Source\Plugins\NoPluginAttribute.cs" />
|
||||||
<Compile Include="Source\Plugins\Employer.cs" />
|
<Compile Include="Source\Plugins\Employer.cs" />
|
||||||
<Compile Include="Source\Plugins\FactoryEmployer.cs" />
|
<Compile Include="Source\Plugins\FactoryEmployer.cs" />
|
||||||
<Compile Include="Source\Plugins\InstanceEmployer.cs" />
|
<Compile Include="Source\Plugins\InstanceEmployer.cs" />
|
||||||
|
<Compile Include="Source\Plugins\NoPluginAttribute.Test.cs">
|
||||||
|
<DependentUpon>NoPluginAttribute.cs</DependentUpon>
|
||||||
|
</Compile>
|
||||||
<Compile Include="Source\Plugins\PluginHelper.cs" />
|
<Compile Include="Source\Plugins\PluginHelper.cs" />
|
||||||
<Compile Include="Source\Plugins\PluginHelper.Test.cs">
|
<Compile Include="Source\Plugins\PluginHelper.Test.cs">
|
||||||
<DependentUpon>PluginHelper.cs</DependentUpon>
|
<DependentUpon>PluginHelper.cs</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
<Compile Include="Source\Plugins\PluginHost.cs" />
|
<Compile Include="Source\Plugins\PluginHost.cs" />
|
||||||
|
<Compile Include="Source\Plugins\PluginHost.Test.cs">
|
||||||
|
<DependentUpon>PluginHost.cs</DependentUpon>
|
||||||
|
</Compile>
|
||||||
<Compile Include="Source\Plugins\PluginRepository.cs" />
|
<Compile Include="Source\Plugins\PluginRepository.cs" />
|
||||||
|
<Compile Include="Source\Plugins\PluginRepository.Test.cs">
|
||||||
|
<DependentUpon>PluginRepository.cs</DependentUpon>
|
||||||
|
</Compile>
|
||||||
<Compile Include="Source\Scheduling\AbortedException.cs" />
|
<Compile Include="Source\Scheduling\AbortedException.cs" />
|
||||||
<Compile Include="Source\Scheduling\IAbortable.cs" />
|
<Compile Include="Source\Scheduling\IAbortable.cs" />
|
||||||
<Compile Include="Source\Scheduling\Operation.cs" />
|
<Compile Include="Source\Scheduling\Operation.cs" />
|
||||||
|
|
|
@ -34,7 +34,7 @@ namespace Nuclex.Support.Parsing {
|
||||||
|
|
||||||
/// <summary>Validates that normal arguments can be parsed</summary>
|
/// <summary>Validates that normal arguments can be parsed</summary>
|
||||||
[Test]
|
[Test]
|
||||||
public void TestPlainArguments() {
|
public void TestArrayConstructorWithPlainArguments() {
|
||||||
Assert.IsTrue(
|
Assert.IsTrue(
|
||||||
new CommandLineParser(new string[] { "-hello" }).HasArgument("hello"),
|
new CommandLineParser(new string[] { "-hello" }).HasArgument("hello"),
|
||||||
"Argument with minus sign is recognized"
|
"Argument with minus sign is recognized"
|
||||||
|
@ -51,7 +51,7 @@ namespace Nuclex.Support.Parsing {
|
||||||
|
|
||||||
/// <summary>Validates that argument assignments are working</summary>
|
/// <summary>Validates that argument assignments are working</summary>
|
||||||
[Test]
|
[Test]
|
||||||
public void TestAssignments() {
|
public void TestArrayConstructorWithAssignments() {
|
||||||
Assert.AreEqual(
|
Assert.AreEqual(
|
||||||
"world",
|
"world",
|
||||||
new CommandLineParser(new string[] { "-hello:world" })["hello"],
|
new CommandLineParser(new string[] { "-hello:world" })["hello"],
|
||||||
|
@ -73,7 +73,7 @@ namespace Nuclex.Support.Parsing {
|
||||||
/// Validates that loosely specified values are recognized by the parser
|
/// Validates that loosely specified values are recognized by the parser
|
||||||
/// </summary>
|
/// </summary>
|
||||||
[Test]
|
[Test]
|
||||||
public void TestLooseValues() {
|
public void TestArrayConstructorWithLooseValues() {
|
||||||
Assert.IsTrue(
|
Assert.IsTrue(
|
||||||
new CommandLineParser(new string[] { "hello" }).Values.Contains("hello"),
|
new CommandLineParser(new string[] { "hello" }).Values.Contains("hello"),
|
||||||
"Plain loose value is recognized"
|
"Plain loose value is recognized"
|
||||||
|
@ -84,6 +84,47 @@ namespace Nuclex.Support.Parsing {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Tests whether the parser can parse the processes current command line if
|
||||||
|
/// the default constructor is used
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void TestDefaultConstructor() {
|
||||||
|
new CommandLineParser();
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Tests whether the string constructor works for simple arguments being
|
||||||
|
/// specified on the command line
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void TestStringConstructorWithSimpleArguments() {
|
||||||
|
CommandLineParser parser = new CommandLineParser("argument1 argument2");
|
||||||
|
Assert.AreEqual("argument1", parser.Values[0]);
|
||||||
|
Assert.AreEqual("argument2", parser.Values[1]);
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: This test fails!!
|
||||||
|
#if FAILED_TEST
|
||||||
|
/// <summary>
|
||||||
|
/// Bullshit
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void TestStringConstructorWithQuotedArguments() {
|
||||||
|
CommandLineParser parser = new CommandLineParser("\"this is a single argument\"");
|
||||||
|
Assert.AreEqual("this is a single argument", parser.Values[0]);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Tests whether the string constructor recognizes an unfinished argument
|
||||||
|
/// (that is, and argument that gets 'nothing' assigned)
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void TestStringConstructorWithUnfinishedAssignment() {
|
||||||
|
CommandLineParser parser = new CommandLineParser("--hello= --world=");
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace Nuclex.Support.Parsing
|
} // namespace Nuclex.Support.Parsing
|
||||||
|
|
39
Source/Plugins/AbstractFactory.Test.cs
Normal file
39
Source/Plugins/AbstractFactory.Test.cs
Normal file
|
@ -0,0 +1,39 @@
|
||||||
|
#region CPL License
|
||||||
|
/*
|
||||||
|
Nuclex Framework
|
||||||
|
Copyright (C) 2002-2008 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
|
||||||
|
|
||||||
|
using System;
|
||||||
|
using System.IO;
|
||||||
|
|
||||||
|
#if UNITTEST
|
||||||
|
|
||||||
|
using NUnit.Framework;
|
||||||
|
using NUnit.Framework.SyntaxHelpers;
|
||||||
|
|
||||||
|
namespace Nuclex.Support.Plugins {
|
||||||
|
|
||||||
|
/// <summary>Unit Test for the abstract factory interface</summary>
|
||||||
|
[TestFixture]
|
||||||
|
public class AbtractFactoryTest {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace Nuclex.Support.Plugins
|
||||||
|
|
||||||
|
#endif // UNITTEST
|
93
Source/Plugins/Employer.Test.cs
Normal file
93
Source/Plugins/Employer.Test.cs
Normal file
|
@ -0,0 +1,93 @@
|
||||||
|
#region CPL License
|
||||||
|
/*
|
||||||
|
Nuclex Framework
|
||||||
|
Copyright (C) 2002-2008 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
|
||||||
|
|
||||||
|
using System;
|
||||||
|
using System.IO;
|
||||||
|
|
||||||
|
#if UNITTEST
|
||||||
|
|
||||||
|
using NUnit.Framework;
|
||||||
|
using NUnit.Framework.SyntaxHelpers;
|
||||||
|
|
||||||
|
namespace Nuclex.Support.Plugins {
|
||||||
|
|
||||||
|
/// <summary>Unit Test for the employer class</summary>
|
||||||
|
[TestFixture]
|
||||||
|
public class EmployerTest {
|
||||||
|
|
||||||
|
#region class TestEmployer
|
||||||
|
|
||||||
|
/// <summary>Dummy implementation for testing the employer class</summary>
|
||||||
|
private class TestEmployer : Employer {
|
||||||
|
|
||||||
|
/// <summary>Employs the specified plugin type</summary>
|
||||||
|
/// <param name="type">Type to be employed</param>
|
||||||
|
public override void Employ(Type type) { }
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion // class TestEmployer
|
||||||
|
|
||||||
|
#region class NoDefaultConstructor
|
||||||
|
|
||||||
|
/// <summary>Test class that doesn't have a default constructor</summary>
|
||||||
|
private class NoDefaultConstructor {
|
||||||
|
/// <summary>Initializes a new instance of the test class</summary>
|
||||||
|
/// <param name="dummy">Dummy argument so this is no default constructor</param>
|
||||||
|
public NoDefaultConstructor(int dummy) { }
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion // class NoDefaultConstructor
|
||||||
|
|
||||||
|
#region class NonPublicDefaultConstructor
|
||||||
|
|
||||||
|
/// <summary>Test class that has a non-public default constructor</summary>
|
||||||
|
private class NonPublicDefaultConstructor {
|
||||||
|
/// <summary>Initializes a new instance of the test class</summary>
|
||||||
|
protected NonPublicDefaultConstructor() { }
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion // class NonPublicDefaultConstructor
|
||||||
|
|
||||||
|
#region class PublicDefaultConstructor
|
||||||
|
|
||||||
|
/// <summary>Test class that has a public default constructor</summary>
|
||||||
|
private class PublicDefaultConstructor {
|
||||||
|
/// <summary>Initializes a new instance of the test class</summary>
|
||||||
|
public PublicDefaultConstructor() { }
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion // class PublicDefaultConstructor
|
||||||
|
|
||||||
|
/// <summary>Tests whether the employer can detect a default constructor</summary>
|
||||||
|
[Test]
|
||||||
|
public void TestEmployerDefaultConstructorDetection() {
|
||||||
|
TestEmployer testEmployer = new TestEmployer();
|
||||||
|
|
||||||
|
Assert.IsFalse(testEmployer.CanEmploy(typeof(NoDefaultConstructor)));
|
||||||
|
Assert.IsFalse(testEmployer.CanEmploy(typeof(NonPublicDefaultConstructor)));
|
||||||
|
Assert.IsTrue(testEmployer.CanEmploy(typeof(PublicDefaultConstructor)));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace Nuclex.Support.Plugins
|
||||||
|
|
||||||
|
#endif // UNITTEST
|
132
Source/Plugins/FactoryEmployer.Test.cs
Normal file
132
Source/Plugins/FactoryEmployer.Test.cs
Normal file
|
@ -0,0 +1,132 @@
|
||||||
|
#region CPL License
|
||||||
|
/*
|
||||||
|
Nuclex Framework
|
||||||
|
Copyright (C) 2002-2008 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
|
||||||
|
|
||||||
|
using System;
|
||||||
|
using System.IO;
|
||||||
|
|
||||||
|
#if UNITTEST
|
||||||
|
|
||||||
|
using NUnit.Framework;
|
||||||
|
using NUnit.Framework.SyntaxHelpers;
|
||||||
|
|
||||||
|
namespace Nuclex.Support.Plugins {
|
||||||
|
|
||||||
|
/// <summary>Unit Test for the factory employer class</summary>
|
||||||
|
[TestFixture]
|
||||||
|
public class FactoryEmployerTest {
|
||||||
|
|
||||||
|
#region class Base
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Abstract base class to serve as abstract product for testing the factory employer
|
||||||
|
/// </summary>
|
||||||
|
private abstract class Base { }
|
||||||
|
|
||||||
|
#endregion // class Base
|
||||||
|
|
||||||
|
#region class Derived
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Class derived from the abstract base to serve as concrete product for
|
||||||
|
/// testing the factory employer
|
||||||
|
/// </summary>
|
||||||
|
private class Derived : Base { }
|
||||||
|
|
||||||
|
#endregion // class Derived
|
||||||
|
|
||||||
|
#region class Unrelated
|
||||||
|
|
||||||
|
/// <summary>Unrelated class used to test the factory employer</summary>
|
||||||
|
private class Unrelated { }
|
||||||
|
|
||||||
|
#endregion // class Unrelated
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Tests whether the factory employer can detect employable types
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void TestCanEmploy() {
|
||||||
|
FactoryEmployer<Base> testEmployer = new FactoryEmployer<Base>();
|
||||||
|
|
||||||
|
Assert.IsFalse(testEmployer.CanEmploy(typeof(Base)));
|
||||||
|
Assert.IsTrue(testEmployer.CanEmploy(typeof(Derived)));
|
||||||
|
Assert.IsFalse(testEmployer.CanEmploy(typeof(Unrelated)));
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Tests whether the factory employer throws an exception when it is asked to
|
||||||
|
/// employ an abstract class
|
||||||
|
/// </summary>
|
||||||
|
[Test, ExpectedException(typeof(MissingMethodException))]
|
||||||
|
public void TestThrowOnEmployAbstractClass() {
|
||||||
|
FactoryEmployer<Base> testEmployer = new FactoryEmployer<Base>();
|
||||||
|
|
||||||
|
testEmployer.Employ(typeof(Base));
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Tests whether the factory employer throws an exception when it is asked to
|
||||||
|
/// employ a class that is not the product type or a derivative thereof
|
||||||
|
/// </summary>
|
||||||
|
[Test, ExpectedException(typeof(InvalidCastException))]
|
||||||
|
public void TestThrowOnEmployUnrelatedClass() {
|
||||||
|
FactoryEmployer<Base> testEmployer = new FactoryEmployer<Base>();
|
||||||
|
|
||||||
|
testEmployer.Employ(typeof(Unrelated));
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Tests whether the factory employer can employ a class derived from the product
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void TestEmployClassDerivedFromProduct() {
|
||||||
|
FactoryEmployer<Base> testEmployer = new FactoryEmployer<Base>();
|
||||||
|
|
||||||
|
testEmployer.Employ(typeof(Derived));
|
||||||
|
|
||||||
|
Assert.AreEqual(1, testEmployer.Factories.Count);
|
||||||
|
Assert.AreEqual(typeof(Derived), testEmployer.Factories[0].ConcreteType);
|
||||||
|
Assert.IsInstanceOfType(
|
||||||
|
typeof(Derived), testEmployer.Factories[0].CreateInstance()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Tests whether the factory employer can employ the product class itself if it
|
||||||
|
/// isn't abstract
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void TestEmployProduct() {
|
||||||
|
FactoryEmployer<Unrelated> testEmployer = new FactoryEmployer<Unrelated>();
|
||||||
|
|
||||||
|
testEmployer.Employ(typeof(Unrelated));
|
||||||
|
|
||||||
|
Assert.AreEqual(1, testEmployer.Factories.Count);
|
||||||
|
Assert.AreEqual(typeof(Unrelated), testEmployer.Factories[0].ConcreteType);
|
||||||
|
Assert.IsInstanceOfType(
|
||||||
|
typeof(Unrelated), testEmployer.Factories[0].CreateInstance()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace Nuclex.Support.Plugins
|
||||||
|
|
||||||
|
#endif // UNITTEST
|
|
@ -41,7 +41,8 @@ namespace Nuclex.Support.Plugins {
|
||||||
/// a human-readable name, capabilities or an icon.
|
/// a human-readable name, capabilities or an icon.
|
||||||
/// </para>
|
/// </para>
|
||||||
/// </remarks>
|
/// </remarks>
|
||||||
public class FactoryEmployer<ProductType> : Employer {
|
public class FactoryEmployer<ProductType> : Employer
|
||||||
|
where ProductType : class {
|
||||||
|
|
||||||
#region class ConcreteFactory
|
#region class ConcreteFactory
|
||||||
|
|
||||||
|
@ -94,6 +95,17 @@ namespace Nuclex.Support.Plugins {
|
||||||
/// <summary>Employs the specified plugin type</summary>
|
/// <summary>Employs the specified plugin type</summary>
|
||||||
/// <param name="type">Type to be employed</param>
|
/// <param name="type">Type to be employed</param>
|
||||||
public override void Employ(Type type) {
|
public override void Employ(Type type) {
|
||||||
|
if(!PluginHelper.HasDefaultConstructor(type)) {
|
||||||
|
throw new MissingMethodException(
|
||||||
|
"Cannot employ type because it does not have a public default constructor"
|
||||||
|
);
|
||||||
|
}
|
||||||
|
if(!typeof(ProductType).IsAssignableFrom(type)) {
|
||||||
|
throw new InvalidCastException(
|
||||||
|
"Cannot employ type because it cannot be cast to the factory's product type"
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
this.employedFactories.Add(new ConcreteFactory(type));
|
this.employedFactories.Add(new ConcreteFactory(type));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
129
Source/Plugins/InstanceEmployer.Test.cs
Normal file
129
Source/Plugins/InstanceEmployer.Test.cs
Normal file
|
@ -0,0 +1,129 @@
|
||||||
|
#region CPL License
|
||||||
|
/*
|
||||||
|
Nuclex Framework
|
||||||
|
Copyright (C) 2002-2008 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
|
||||||
|
|
||||||
|
using System;
|
||||||
|
using System.IO;
|
||||||
|
|
||||||
|
#if UNITTEST
|
||||||
|
|
||||||
|
using NUnit.Framework;
|
||||||
|
using NUnit.Framework.SyntaxHelpers;
|
||||||
|
|
||||||
|
namespace Nuclex.Support.Plugins {
|
||||||
|
|
||||||
|
/// <summary>Unit Test for the instance employer class</summary>
|
||||||
|
[TestFixture]
|
||||||
|
public class InstanceEmployerTest {
|
||||||
|
|
||||||
|
#region class Base
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Abstract base class to serve as abstract product for testing the instance employer
|
||||||
|
/// </summary>
|
||||||
|
private abstract class Base { }
|
||||||
|
|
||||||
|
#endregion // class Base
|
||||||
|
|
||||||
|
#region class Derived
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Class derived from the abstract base to serve as concrete product for
|
||||||
|
/// testing the instance employer
|
||||||
|
/// </summary>
|
||||||
|
private class Derived : Base { }
|
||||||
|
|
||||||
|
#endregion // class Derived
|
||||||
|
|
||||||
|
#region class Unrelated
|
||||||
|
|
||||||
|
/// <summary>Unrelated class used to test the instance employer</summary>
|
||||||
|
private class Unrelated { }
|
||||||
|
|
||||||
|
#endregion // class Unrelated
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Tests whether the instance employer can detect employable types
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void TestCanEmploy() {
|
||||||
|
InstanceEmployer<Base> testEmployer = new InstanceEmployer<Base>();
|
||||||
|
|
||||||
|
Assert.IsFalse(testEmployer.CanEmploy(typeof(Base)));
|
||||||
|
Assert.IsTrue(testEmployer.CanEmploy(typeof(Derived)));
|
||||||
|
Assert.IsFalse(testEmployer.CanEmploy(typeof(Unrelated)));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Tests whether the instance employer throws an exception when it is asked to
|
||||||
|
/// employ an abstract class
|
||||||
|
/// </summary>
|
||||||
|
[Test, ExpectedException(typeof(MissingMethodException))]
|
||||||
|
public void TestThrowOnEmployAbstractClass() {
|
||||||
|
InstanceEmployer<Base> testEmployer = new InstanceEmployer<Base>();
|
||||||
|
|
||||||
|
testEmployer.Employ(typeof(Base));
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Tests whether the instance employer throws an exception when it is asked to
|
||||||
|
/// employ a class that is not the product type or a derivative thereof
|
||||||
|
/// </summary>
|
||||||
|
[Test, ExpectedException(typeof(InvalidCastException))]
|
||||||
|
public void TestThrowOnEmployUnrelatedClass() {
|
||||||
|
InstanceEmployer<Base> testEmployer = new InstanceEmployer<Base>();
|
||||||
|
|
||||||
|
testEmployer.Employ(typeof(Unrelated));
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Tests whether the instance employer can employ a class derived from the product
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void TestEmployClassDerivedFromProduct() {
|
||||||
|
InstanceEmployer<Base> testEmployer = new InstanceEmployer<Base>();
|
||||||
|
|
||||||
|
testEmployer.Employ(typeof(Derived));
|
||||||
|
|
||||||
|
Assert.AreEqual(1, testEmployer.Instances.Count);
|
||||||
|
Assert.AreEqual(typeof(Derived), testEmployer.Instances[0].GetType());
|
||||||
|
Assert.IsInstanceOfType(typeof(Derived), testEmployer.Instances[0]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Tests whether the instance employer can employ the product class itself if it
|
||||||
|
/// isn't abstract
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void TestEmployProduct() {
|
||||||
|
InstanceEmployer<Unrelated> testEmployer = new InstanceEmployer<Unrelated>();
|
||||||
|
|
||||||
|
testEmployer.Employ(typeof(Unrelated));
|
||||||
|
|
||||||
|
Assert.AreEqual(1, testEmployer.Instances.Count);
|
||||||
|
Assert.AreEqual(typeof(Unrelated), testEmployer.Instances[0].GetType());
|
||||||
|
Assert.IsInstanceOfType(typeof(Unrelated), testEmployer.Instances[0]);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace Nuclex.Support.Plugins
|
||||||
|
|
||||||
|
#endif // UNITTEST
|
47
Source/Plugins/NoPluginAttribute.Test.cs
Normal file
47
Source/Plugins/NoPluginAttribute.Test.cs
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
#region CPL License
|
||||||
|
/*
|
||||||
|
Nuclex Framework
|
||||||
|
Copyright (C) 2002-2008 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
|
||||||
|
|
||||||
|
using System;
|
||||||
|
using System.IO;
|
||||||
|
|
||||||
|
#if UNITTEST
|
||||||
|
|
||||||
|
using NUnit.Framework;
|
||||||
|
using NUnit.Framework.SyntaxHelpers;
|
||||||
|
|
||||||
|
namespace Nuclex.Support.Plugins {
|
||||||
|
|
||||||
|
/// <summary>Unit Test for the no plugin attribute class</summary>
|
||||||
|
[TestFixture]
|
||||||
|
public class NoPluginAttributeTest {
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Tests whether the default consturctor of the no plugin attribute works
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void TestDefaultConstructor() {
|
||||||
|
new NoPluginAttribute();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace Nuclex.Support.Plugins
|
||||||
|
|
||||||
|
#endif // UNITTEST
|
38
Source/Plugins/PluginHost.Test.cs
Normal file
38
Source/Plugins/PluginHost.Test.cs
Normal file
|
@ -0,0 +1,38 @@
|
||||||
|
#region CPL License
|
||||||
|
/*
|
||||||
|
Nuclex Framework
|
||||||
|
Copyright (C) 2002-2008 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
|
||||||
|
|
||||||
|
using System;
|
||||||
|
using System.IO;
|
||||||
|
|
||||||
|
#if UNITTEST
|
||||||
|
|
||||||
|
using NUnit.Framework;
|
||||||
|
using NUnit.Framework.SyntaxHelpers;
|
||||||
|
|
||||||
|
namespace Nuclex.Support.Plugins {
|
||||||
|
|
||||||
|
/// <summary>Unit Test for the plugin host class</summary>
|
||||||
|
[TestFixture]
|
||||||
|
public class PluginHostTest {
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace Nuclex.Support.Plugins
|
||||||
|
|
||||||
|
#endif // UNITTEST
|
142
Source/Plugins/PluginRepository.Test.cs
Normal file
142
Source/Plugins/PluginRepository.Test.cs
Normal file
|
@ -0,0 +1,142 @@
|
||||||
|
#region CPL License
|
||||||
|
/*
|
||||||
|
Nuclex Framework
|
||||||
|
Copyright (C) 2002-2008 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
|
||||||
|
|
||||||
|
using System;
|
||||||
|
using System.IO;
|
||||||
|
using System.Reflection;
|
||||||
|
|
||||||
|
#if UNITTEST
|
||||||
|
|
||||||
|
using NUnit.Framework;
|
||||||
|
using NUnit.Framework.SyntaxHelpers;
|
||||||
|
using NMock2;
|
||||||
|
|
||||||
|
namespace Nuclex.Support.Plugins {
|
||||||
|
|
||||||
|
/// <summary>Unit Test for the plugin repository class</summary>
|
||||||
|
[TestFixture]
|
||||||
|
public class PluginRepositoryTest {
|
||||||
|
|
||||||
|
#region interface IAssemblyLoadedSubscriber
|
||||||
|
|
||||||
|
/// <summary>Interface used to test the progress tracker</summary>
|
||||||
|
public interface IAssemblyLoadedSubscriber {
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Represents the method that handles the System.AppDomain.AssemblyLoad event
|
||||||
|
/// of an System.AppDomain
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="sender">The source of the event.</param>
|
||||||
|
/// <param name="arguments">
|
||||||
|
/// An System.AssemblyLoadEventArgs that contains the event data
|
||||||
|
/// </param>
|
||||||
|
void AssemblyLoaded(object sender, AssemblyLoadEventArgs arguments);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion // interface IProgressTrackerSubscriber
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Tests whether the default constructor of the plugin repository class works
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void TestDefaultConstructor() {
|
||||||
|
new PluginRepository();
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Tests whether the AddFiles() method accepts a file mask to which there are
|
||||||
|
/// no matching files
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void TestAddFilesWithZeroMatches() {
|
||||||
|
PluginRepository testRepository = new PluginRepository();
|
||||||
|
testRepository.AddFiles(Guid.NewGuid().ToString());
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Tests whether the AddFiles() method accepts a file mask to which there is
|
||||||
|
/// exactly one matching file
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void TestAddFilesWithOwnAssembly() {
|
||||||
|
Assembly self = Assembly.GetAssembly(GetType());
|
||||||
|
|
||||||
|
PluginRepository testRepository = new PluginRepository();
|
||||||
|
testRepository.AddFiles(self.Location);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Tests whether the AddAssembly() method works by adding the test assembly
|
||||||
|
/// itself to the repository
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void TestAddAssembly() {
|
||||||
|
PluginRepository testRepository = new PluginRepository();
|
||||||
|
|
||||||
|
// Might also use Assembly.GetCallingAssembly() here, but this leads to the exe of
|
||||||
|
// the unit testing tool
|
||||||
|
Assembly self = Assembly.GetAssembly(GetType());
|
||||||
|
testRepository.AddAssembly(self);
|
||||||
|
|
||||||
|
Assert.AreEqual(1, testRepository.LoadedAssemblies.Count);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Tests whether the AddAssembly() method works by adding the test assembly
|
||||||
|
/// itself to the repository
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void TestAssemblyLoadedEvent() {
|
||||||
|
Mockery mockery = new Mockery();
|
||||||
|
|
||||||
|
PluginRepository testRepository = new PluginRepository();
|
||||||
|
IAssemblyLoadedSubscriber subscriber = mockSubscriber(mockery, testRepository);
|
||||||
|
|
||||||
|
Expect.Once.On(subscriber).Method("AssemblyLoaded").WithAnyArguments();
|
||||||
|
|
||||||
|
Assembly self = Assembly.GetAssembly(GetType());
|
||||||
|
testRepository.AddAssembly(self);
|
||||||
|
|
||||||
|
mockery.VerifyAllExpectationsHaveBeenMet();
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>Mocks a subscriber for the events of a plugin repository</summary>
|
||||||
|
/// <param name="mockery">Mockery to create an event subscriber in</param>
|
||||||
|
/// <param name="repository">Repository to subscribe the mocked subscriber to</param>
|
||||||
|
/// <returns>The mocked event subscriber</returns>
|
||||||
|
private static IAssemblyLoadedSubscriber mockSubscriber(
|
||||||
|
Mockery mockery, PluginRepository repository
|
||||||
|
) {
|
||||||
|
IAssemblyLoadedSubscriber mockedSubscriber =
|
||||||
|
mockery.NewMock<IAssemblyLoadedSubscriber>();
|
||||||
|
|
||||||
|
repository.AssemblyLoaded += new AssemblyLoadEventHandler(
|
||||||
|
mockedSubscriber.AssemblyLoaded
|
||||||
|
);
|
||||||
|
|
||||||
|
return mockedSubscriber;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace Nuclex.Support.Plugins
|
||||||
|
|
||||||
|
#endif // UNITTEST
|
|
@ -52,6 +52,11 @@ namespace Nuclex.Support.Plugins {
|
||||||
string directory = Path.GetDirectoryName(wildcard);
|
string directory = Path.GetDirectoryName(wildcard);
|
||||||
string search = Path.GetFileName(wildcard);
|
string search = Path.GetFileName(wildcard);
|
||||||
|
|
||||||
|
// If no directory was specified, use the current working directory
|
||||||
|
if((directory == null) || (directory == string.Empty)) {
|
||||||
|
directory = ".";
|
||||||
|
}
|
||||||
|
|
||||||
// We'll scan the specified directory for all files matching the specified
|
// We'll scan the specified directory for all files matching the specified
|
||||||
// wildcard. If only a single file is specified, only that file will match
|
// wildcard. If only a single file is specified, only that file will match
|
||||||
// the supposed wildcard and everything works as expected
|
// the supposed wildcard and everything works as expected
|
||||||
|
|
Loading…
Reference in New Issue
Block a user