量角器在AngularJS之外的可用性

rya*_*zec 6 selenium integration-testing reactjs protractor

所以我最近从使用AngularJS切换到ReactJS,但我确实喜欢使用Protractor E2E测试运行器,所以我想知道关于Protractor的两件事.

在不使用AngularJS的网站上使用Protractor是否有任何重大问题?我知道Protractor默认尝试与Angular同步,你得到:

Error: Angular could not be found on the page X : retries looking for angular exceeded
Run Code Online (Sandbox Code Playgroud)

但是我相信可以通过browser.ignoreSynchronization = true以前的方式来预防browser.get().除此之外还有其他问题吗?

另一个问题是Protractor会不会成为AngularJS特有的,因为它只能测试AngularJS代码?我认为可以绕过任何AngularJS特定功能(就像你可以使用的那样browser.ignoreSynchronization = true),我只是想确保这是Protractor未来的核心目标.

Chi*_*ice 8

尽管Protractor旨在为Angular应用程序编写端到端测试代码,但它仍可用于测试非Angular应用程序.

实现此目的有两种常见的解决方案:

直接访问包装的webdriver实例

browser.driver.find(By.id('test'));
Run Code Online (Sandbox Code Playgroud)

为方便起见,您可以将其导出到全局命名空间并通过别名访问它.

onPrepare: function () {
  global.drv = browser.driver;
}
Run Code Online (Sandbox Code Playgroud)

停止等待Angular完成其工作

如您所述,browser.ignoreSynchronization = true可以禁用Protractor的默认等待行为.您采用的解决方案(在browser.get()之前执行browser.ignoreSynchronization = true)可能会在您的测试代码不专用于非Angular应用程序时导致错误.browser.ignoreSynchronization是全局范围设置,这意味着一旦更改其值,此标志将影响整个测试套件.因此,除非在每个Angular测试中相应地更新标志,否则Angular测试将会出现一些错误.

尝试这种优雅而灵活的方式.

ignoreSynchronization在config.js中定义标志设置器功能

onPrepare = function () {
  global.isAngularApp = function (flag) {
    return browser.ignoreSynchronization = flag;
  }
}
Run Code Online (Sandbox Code Playgroud)

您可以在测试代码中确定标志的值

beforeEach(function() {
  isAngularApp(false);  //for non-Angular site
});
Run Code Online (Sandbox Code Playgroud)

对于非角度应用,您现在需要自己保持同步.您可以通过采用更直观的用户方法来实现此目的,现在您可以等待元素出现/消失/具有值/没有值/等.用户可以看到并做出反应的所有事情.您可以使用Selenium的隐式或显式等待以及相应的ExpectedConditions类来完成此操作.这些是Selenium Docs的详细信息.

希望它对你有所帮助.