我有一系列连接到Azure存储模拟器的单元测试。在安装程序中,我的代码检查模拟器的端口是否有监听,如果没有,则设置标志StorageNotAvailable
。
在我的每个测试中,我都有一些代码......
if ( StorageNotAvailable )
Assert.Inconclusive( "Storage emulator is not available" )
// where storage emulator is available, continue as normal
正如预期的那样,当测试返回void
时,它会在测试资源管理器中正确报告为“不确定”。
当测试运行一些异步方法,并且[TestMethod]
签名返回Task
时,测试将在TestExplorer中报告为“失败”而不是“不确定”。
如何让异步方法报告为不确定?
可能会有一些额外的细节。以下是我为了证明我所看到的问题而进行的一些示例测试。
[TestMethod]
public void MyTestMethod()
{
Assert.Inconclusive( "I am inconclusive" );
}
[TestMethod]
public async Task MyTestMethodAsync()
{
Assert.Inconclusive( "I am an error" );
}
一些环境细节也可能是有序的:
答案 0 :(得分:5)
Assert.Inconclusive
raises a special kind of exception,这将导致任务捕获该异常。由于Task库和async不知道,我们不能责怪他们抱怨。 Task框架会将异常包装在AggregateException中,我怀疑这个异常会被报告。这是一个很好的假设,但事实证明,寻找AssetInconclusiveException的代码是将引发的实例与MstestV1的实现进行比较而不是MsTestV2。
但我想这应该被认为是MsTest v2运行器中的一个错误,它应该检查所有失败的任务并查看导致失败的异常。
行为是目前已知的行为I've just submitted a PR to fix this。 Pull Request Merged,现在只是等待下一个Nuget构建触发。
答案 1 :(得分:0)
这是由MsTest.Framework代码中确认的错误引起的 - GitHub上的问题#249正在跟踪问题和最终解决方案:
将Assert.Inconclusive报告用作错误的异步测试