我正在思考如何实现这一点,而且我的知识似乎太差,无法理解实现。
我有一个代码,可以将源代码编译为DLL。
然后我需要以某种方式在这个Dll上运行单元测试,并检查里面的3-4个方法。
我正试图以这种方式运行单元测试。
CompilerResults compileResults = codeProvider.CompileAssemblyFromSource(compilerParameters, new string[] { sourceCode });
Assembly myAssembly = compileResults.CompiledAssembly;
TestPackage testPackage = new TestPackage(@"TestingProject.dll");
testPackage.Assemblies.Add(myAssembly);
RemoteTestRunner remoteTestRunner = new RemoteTestRunner();
remoteTestRunner.Load(testPackage);
TestResult testResult = remoteTestRunner.Run(new NullListener(),TestFilter.Empty,false,LoggingThreshold.All);
这就是测试
[Test]
public void AddTest(IDynamicScript s)
{
Assert.AreEqual(10, s.Add(5,5));
Assert.AreNotEqual(10,s.Add(4,5));
}
由于汇编是动态编译的,我不能将它引用到单元测试项目中,并且它不会编译,请关于如何实现这一点的任何建议
答案 0 :(得分:1)
经过一些修改后,您的代码工作正常。这些是必要的变化:
nunit.framework.dll
程序集的路径,我从主要加载的副本的位置获取AppDomain,但您也可以从文件系统中引用它而不加载它。通常,您还需要提供包含您正在测试的代码的程序集的路径TestPackage
类的构造函数在其构造函数中采用绝对路径,在本例中我提供了生成的程序集的位置这是带有更正的代码:
var sourceCode = @"
using NUnit.Framework;
public class Fixture
{
[Test]
public void AddTest()
{
Assert.AreEqual(10, 5+5);
}
}";
var provider = new CSharpCodeProvider();
CompilerResults compileResults = provider.CompileAssemblyFromSource(
new CompilerParameters(new[]{ typeof(TestAttribute).Assembly.Location }),
new[]{ sourceCode });
var assembly = compileResults.CompiledAssembly;
var package = new TestPackage(assembly.Location);
var runner = new RemoteTestRunner();
runner.Load(package);
var result = runner.Run(new NullListener(),
TestFilter.Empty,
false,
LoggingThreshold.All);