我正在尝试从 mstest 获取失败测试用例的错误消息。
我在网上找到了一些使用 TestContext 的东西,下面是我的代码片段。
public static string GetErrorMessageFromTestContext(TestContext testContext) {
BindingFlags privateGetterFlags = BindingFlags.GetField |
BindingFlags.GetProperty |
BindingFlags.NonPublic |
BindingFlags.Instance |
BindingFlags.FlattenHierarchy;
var m_message = string.Empty;
Type t = testContext.GetType();
if (testContext.CurrentTestOutcome == UnitTestOutcome.Failed)
{
var field = t.GetField("m_currentResult", privateGetterFlags);
object m_currentResult = field.GetValue(testContext);
field = m_currentResult.GetType().GetField("m_errorInfo",
privateGetterFlags);
var m_errorInfo = field.GetValue(m_currentResult);
field = m_errorInfo.GetType().GetField("m_message",
privateGetterFlags);
m_message = field.GetValue(m_errorInfo) as string;
}
return m_message;
}
这个东西应该从失败的案例中返回错误消息。但是,当执行该行时:
var field = t.GetField("m_currentResult", privateGetterFlags);
字段被分配为 null。不确定原因是什么,所以我也愿意接受其他解决方案。谢谢!
富国沪深
相关分类