[英]How to not forget to turn the Protractor to Angular sync on again?
我们有一个相当庞大的测试代码库(大约10000行javascript代码),在某些情况下,我们需要关闭Protractor-to-Angular同步:
browser.ignoreSynchronization = true;
但问题是, 我们有时会忘记再次打开同步,使所有后续测试失败,原因不明,需要时间和精力进行调试。
有没有办法确保在测试中重新启用同步?
我们确实有基于ESLint
静态代码分析并执行代码审查。
我只是做了AfterTest钩子(取决于你的测试运行器),在那里我将所有东西都设置回其起始状态,所以如果我甚至忘记在测试中切换回来,或者由于某种原因测试崩溃 - 下一次测试不会受到影响:
我的茉莉花代码。 量角器配置:
onPrepare() {
...
afterEach(function () {
// Setting ignoreSychronization back to true, in case it was changed in tests
browser.waitForAngularEnabled(true);
// Setting back to default frame. In case test was working in iframe
browser.switchTo().defaultContent();
// This depends on your architecture. We do clean run for each test.
browser.manage().deleteAllCookies();
browser.executeScript('window.sessionStorage.clear(); window.localStorage.clear();').then(
undefined,
function (err) {
// Errors will be thrown when browser is on default data URL.
// Session and Local storage is disabled for data URLs
// This callback is needed to not crash test, and just ignore error.
});
browser.manage().timeouts().implicitlyWait(5000); // I even rewrite implicit wait back to default value, in case i touched it in tests
// Also you might want to clear indexdb storage after tests.
})
在实际代码中,我会将其包装到名为resetBrowser
函数或类似的东西中。 你也可以从它返回承诺,然后从钩子返回那个承诺 - 所以新的测试不会开始,直到诺言解决
有一次,当我在这个相同的场景中挣扎时,我创建了一个辅助函数并在导航到新页面之前调用它。 您仍然必须“记住”调用该函数,但至少这只会在您处理该更改的代码中只提供一个位置。
isAngularSite(flag) {
browser.ignoreSynchronization = !flag;
}
在我的代码中,我称之为utils.isAngularSite(false);
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.