张贴到谷歌集团的SpecFlow,但很少或根本没有活动,所以我们开始。
我有一个SpecFlow/Selenium/MSBuild项目,我正在通过命令行运行one简单场景,如下所示:
SpecRun.exe run Default.srprofile "/filter:@%filter%"浏览器实例启动,断言完成,浏览器实例关闭。这大约需要5-10秒。
但是:在此之后,我必须等待60秒,直到SpecRun进程关闭,并给出如下结果:
Discovered 1 tests
Thread#0:
0% completed
Thread#0: S
100% completed
Done.
Result: all tests passed
Total: 1
Succeeded: 1
Ignored: 0
Pending: 0
Skipped: 0
Failed: 0
Execution Time: 00:01:01.1724989我目前假设,这是因为它正在将测试执行报告写入磁盘。但我不知道怎么关掉它..。http://www.specflow.org/documentation/Reporting/和,我不知道为什么这将需要60秒,或如何进一步调试这一点。
我已经删除了AfterScenario,并检查了selenium驱动程序退出/关闭并验证这不是导致问题的原因。
有人能解释一下这件事吗?
谢谢
发布于 2014-09-02 12:35:46
老天啊。BaseStepDefinitions出现了严重的问题。做了更多的调试,发现BeforeScenario在一次测试中被击中了25次。每一种情况下启动和关闭25个实例。通过用一个干净的文件重新开始来修正这个问题,比如:
[Binding]
public class BaseStepDefinitions
{
public static IWebDriver Driver;
private static void Setup()
{
Driver = new ChromeDriver();
}
[BeforeFeature]
public static void BeforeFeature()
{
Setup();
}
[AfterFeature]
public static void AfterFeature()
{
Driver.Dispose();
}
}我不会发布我的原始文件,因为这是令人尴尬的。
这是一个类似的问题,帮助我https://groups.google.com/forum/#!topic/specflow/LSt0PGv2DeY
https://stackoverflow.com/questions/25544640
复制相似问题