我有一个函数.getText
,在接下来的页面上,我需要从中返回一个变量num3
进行比较。但是最后的断言失败了,因为num3是“ undefined”。
var num3;
...
.getText('my_selector', function(result) {
const num = (number * result.value) * 0.05;
const num2 = (number * result.value) - num;
num3 = Math.round(num2 * 100) / 100;
this.expect.element('my_selector').to.have.value.equal(num3); })
...
.assert.containsText('my_selector2', num3) //undefined
最佳答案
我找到了解决此问题的方法。我们需要.perform函数。 http://nightwatchjs.org/api#perform
var num3;
...
.getText('my_selector', function(result) {
const num = (number * result.value) * 0.05;
const num2 = (number * result.value) - num;
num3 = Math.round(num2 * 100) / 100;
this.expect.element('my_selector').to.have.value.equal(num3); })
...
.perform( function(){
this.api
.useXpath()//it's necessary if you use Xpath selector
.assert.containsText('my_selector2', num3)
})
有关为何需要这样做的更多信息,请阅读Nightwatch command queue。