我在每日运行中使用多个c#Ordered测试。每个测试都需要恢复到快照,以便丢失所有数据和更改(这对我来说没问题)
但是......有时测试失败,所有信息都丢失了。 Visual Studio提供了一个很好的解释和截图(非常有用)
我的问题:有没有办法或功能来实现,如果测试失败,一些文件(日志/崩溃)被复制到网络位置(硬编码功能或链接到bat /脚本文件或回放功能的东西) ) 我在测试中尝试过try catch选项,但是你失去了从visual studio获得的好信息。如果没有办法实现这一点,我将回到try catch
此致
按要求提供了一些代码:
这是我使用的TestMethod:
//playback options + delay
Logging.playback();
Try{
Mouse.Click(uITaskListItems);
foreach (WinControl TaskList in uITaskListItems.GetChildren())
{
if (TaskList.Name.Contains(Variables.TaskItem1))
{
Mouse.Click(TaskList, MouseButtons.Right);
Mouse.Click(uIListMonitor);
break;
}
}
}catch(Exception ex){
Logging.Log(ex.Message);
Assert.Fail();
播放选项
private static void Playback_PlaybackError(object sender, PlaybackErrorEventArgs e)
{
// Wait a second
System.Threading.Thread.Sleep(1000);
// Retry the failed test operation
e.Result = PlaybackErrorOptions.Retry;
}
//playback options
public static void playback()
{
Playback.PlaybackSettings.MatchExactHierarchy = true;
Playback.PlaybackSettings.SmartMatchOptions = SmartMatchOptions.Control;
Playback.PlaybackSettings.SmartMatchOptions = SmartMatchOptions.TopLevelWindow;
Playback.PlaybackSettings.SmartMatchOptions = SmartMatchOptions.None;
Playback.PlaybackSettings.SearchTimeout = 2000;
Playback.PlaybackSettings.ShouldSearchFailFast = true;
Playback.PlaybackSettings.ThinkTimeMultiplier = 2;
Playback.PlaybackSettings.WaitForReadyLevel = WaitForReadyLevel.AllThreads;
Playback.PlaybackSettings.WaitForReadyLevel = WaitForReadyLevel.UIThreadOnly;
Playback.PlaybackSettings.WaitForReadyLevel = WaitForReadyLevel.Disabled;
Playback.PlaybackSettings.WaitForReadyTimeout = 2000;
Playback.PlaybackError -= Playback_PlaybackError;
Playback.PlaybackError += Playback_PlaybackError;
Playback.PlaybackSettings.DelayBetweenActions = 300;
}
答案 0 :(得分:1)
您可以尝试Exception课程。
使用Exception类可以获取错误的所有信息。 - "就像视觉工作室做的那样"
try
{
//make some noise...
}
catch(Exception ex)
{
Console.WriteLine(ex.InnerException);
//ex.Data, ex.HelpLink, ex.HResult, ex.Messages etc..
}
答案 1 :(得分:1)
您可以使用每次测试后执行的[TestCleanup]
方法。代码可能基于以下内容。
[TestCleanup()]
public void MyTestCleanup()
{
switch (TestContext.CurrentTestOutcome)
{
case UnitTestOutcome.Passed:
// Success.
break;
case UnitTestOutcome.Aborted:
case UnitTestOutcome.Error:
case UnitTestOutcome.Failed:
case UnitTestOutcome.Inconclusive:
case UnitTestOutcome.InProgress:
case UnitTestOutcome.Timeout:
case UnitTestOutcome.Unknown:
// Oh dear.
break;
default:
// Should never be called.
break;
}
}
一个更简单的例程可能只使用一个if
语句:
if (TestContext.CurrentTestOutcome != UnitTestOutcome.Passed )
{
// Oh dear.
}