I'm trying to use nunits test engine/test runner to run specific test but somehow I can't get the filter to work (it run my test if I use an empty filter).
This is the code so far:
var package = new TestPackage("path/to/dll");
package.AddSetting("WorkDirectory", Path.GetDirectoryName("path/to/dll"));
using (ITestEngine engine = TestEngineActivator.CreateInstance())
{
engine.WorkDirectory = Path.GetDirectoryName(dllPath);
using (NUnit.Engine.ITestRunner runner = engine.GetRunner(package))
{
var filter = new TestFilter("<filter><tests><test>UnitTestProject2.UnitTest1.TestMethod1</test></tests></filter>");
var result = runner.Run(new TestEventDispatcher(), filter);
runner.Unload();
return CreateResult(result);
}
}
If I try to run this code and check the result I get:
<command-line><![CDATA[".." ]]></command-line><filter><tests><test>UnitTestProject2.UnitTest1.TestMethod1</test></tests></filter><test-suite type="Assembly" id="0" name="UnitTestProject2.dll" fullname="...dll" runstate="NotRunnable" testcasecount="1" result="Failed" label="Error" start-time="2018-02-20 20:31:57Z" end-time="2018-02-20 20:31:57Z" duration="0.001" total="1" passed="0" failed="1" inconclusive="0" skipped="0" asserts="0"><failure><message><
![CDATA[The NUnit 3 driver encountered an error while executing reflected code.]]></message><stack-trace><![CDATA[
Server stack trace:
vid NUnit.Engine.Drivers.NUnit3FrameworkDriver.CreateObject(String typeName, Object[] args)
vid NUnit.Engine.Drivers.NUnit3FrameworkDriver.Run(ITestEventListener listener, String filter)
vid NUnit.Engine.Runners.DirectTestRunner.RunTests(ITestEventListener listener, TestFilter filter)
vid System.Runtime.Remoting.Messaging.StackBuilderSink._PrivateProcessMessage(IntPtr md, Object[] args, Object server, Object[]& outArgs)
vid System.Runtime.Remoting.Messaging.StackBuilderSink.SyncProcessMessage(IMessage msg)
Exception rethrown at [0]:
vid System.Runtime.Remoting.Proxies.RealProxy.HandleReturnMessage(IMessage reqMsg, IMessage retMsg)
vid System.Runtime.Remoting.Proxies.RealProxy.PrivateInvoke(MessageData& msgData, Int32 type)
vid NUnit.Engine.ITestEngineRunner.Run(ITestEventListener listener, TestFilter filter)
vid NUnit.Engine.Runners.ProcessRunner.RunTests(ITestEventListener listener, TestFilter filter)]]></stack-trace></failure></test-suite>
Am I missing something obvious? I read through documentation here and sounds like this should be the correct way: https://github.com/nunit/docs/wiki/Test-Filters
Use the filter with no <tests>
node, ie:
<filter><test>UnitTestProject.Class1.Test123</test></filter>
For multiple tests, use:
<filter><or><test>NUnitTestRunner.Class1.Test123</test><test>NUnitTestRunner.Class1.Test456</test></or></filter>
Alternatively, you may use ITestFilterBuilder
:
Example:
using (ITestEngine engine = TestEngineActivator.CreateInstance())
{
var filterService = engine.Services.GetService<ITestFilterService>();
var builder = filterService.GetTestFilterBuilder();
builder.AddTest("UnitTestProject.Class1.Test123");
var filter = builder.GetFilter();
using (ITestRunner runner = engine.GetRunner(package))
{
var result = runner.Run(listener: null, filter: filter);
}
}
Both solutions yields passed test: total="1" passed="1"
You may look into the source code of the solution at: https://github.com/dariusz-wozniak/StackOverflowAnswers/tree/master/NUnitTestRunner .
The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.