ale*_*cxe 9 testing selenium static-code-analysis protractor angular
我们有一个相当庞大的测试代码库(大约10000行javascript代码),在某些情况下,我们需要关闭Protractor-to-Angular同步:
browser.ignoreSynchronization = true;
Run Code Online (Sandbox Code Playgroud)
但问题是,我们有时会忘记再次打开同步,使所有后续测试失败,原因不明,需要时间和精力进行调试.
有没有办法确保在测试中重新启用同步?
我们确实有基于静态代码的分析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.
})
Run Code Online (Sandbox Code Playgroud)
在实际代码中,我会将其包装到调用的函数resetBrowser或类似的东西中.你也可以从它返回承诺,然后从钩子返回那个承诺 - 所以新的测试不会开始,直到诺言解决
有一次,当我遇到同样的情况时,我创建了一个辅助函数,并在导航到新页面之前调用了它。您仍然必须“记住”调用该函数,但至少这在代码中只给了您一个地方来处理该更改。
isAngularSite(flag) {
browser.ignoreSynchronization = !flag;
}
Run Code Online (Sandbox Code Playgroud)
在我的代码中,我称之为 utils.isAngularSite(false);