javascript - 在 Protractor 中使用expect()时遇到问题,想要获取第一个 child 的文本并将其与字符串进行比较

标签 javascript protractor e2e-testing

我想获取元素的子元素文本并测试它是否等于用户输入字符串。

已尝试下面的代码,这导致了相同的错误消息

await expect(element(by.className('tlid-translation translation').isDisplayed()).to.equal(true)

以及随机添加一些 .finally 或检查 element.all,但这些似乎都没有帮助。

页面:

var CalculatorPage = function() {

    var expect = require('chai').expect;

  this.get = function() {
    browser.waitForAngularEnabled(false);
    browser.get('https://translate.google.com/', 50000);
  };

  this.checkTrans = async(stringg) => {
       await expect(element(by.className('tlid-translation translation').get(0).getText()).to.equal(stringg)
    }


};

module.exports = CalculatorPage;


步骤:


var chai = require('chai').use(require('chai-as-promised'));
var expect = chai.expect;

var CalculatorSteps = function() {

  var TranslatePage = require("../pages/translate_page.js");


  this.World = function MyWorld() {
    this.page = new TranslatePage();
  };

  this.When('I see $stringg as translated', async function end(stringg) {
      await this.page.checkTrans(stringg)
    })

};

module.exports = CalculatorSteps;

错误消息:

AssertionError: expected { Object (browser_, then, ...) } to equal true

最佳答案

具体:

问题出在代码中的括号。另外,避免使用已弃用的方法

更改:

await expect(element(by.className('tlid-translation translation').isDisplayed()).to.equal(true)

await expect(element(by.css('tlid-translation translation:nth-child(1)')).getText()).toBe(stringg);

更改:

await expect(element(by.className('tlid-translation translation').isDisplayed()).to.equal(true)

await expect(element(by.className('tlid-translation translation')).isDisplayed()).toBeTruthy();

一般情况:

  • expect() 需要一个 promise 。大多数 Protractor API 处理的是 promise 它必须处理浏览器的异步性质。制作 确保 expect() 得到了 promise
  • element() 需要一个定位器,例如。 by.css('div')。确保那是 案件。
  • element(Locator) 上的方法将始终返回一个 Protractor promise 。确保代码以这种方式处理它。
  • 我更喜欢 CSS 选择器来获取子元素而不是使用 获取所有元素,然后从该列表中获取一个元素。这样它的 性能更高一点,我们不需要 API 来处理。

希望有帮助..

关于javascript - 在 Protractor 中使用expect()时遇到问题,想要获取第一个 child 的文本并将其与字符串进行比较,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57341265/

相关文章:

e2e-testing - 如何测试单击下拉菜单并将其关闭的功能

date - 如何在 testcafe 中模拟 Date()?

javascript - 无法POST表单数据

angularjs - 在 Protractor 中包含下划线 javascript 库

javascript - Protractor Promise 回调不显示内容。如何调用返回项的方法?

javascript - Protractor 在不使用 browser.sleep 的情况下编写更干净的测试用例

javascript - 如何获取 httpOnly(安全)cookie TestCafe?

javascript - HTML5 Canvas Javascript 如何制作平滑的笔刷

javascript - 防止 craftyJS 中的对象裁剪

javascript - 将 Observable 与 async/await 结合使用是一种好习惯吗?