编码ui测试失败后的操作

时间:2014-11-20 08:46:43

标签: c# automated-tests coded-ui-tests

我在每日运行中使用多个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;
  }

2 个答案:

答案 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.
    }
相关问题