- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我遇到一个问题,有时会执行 promise 代码,有时它会跳过处理 promise 的语句,即使用 then 语句,我尝试了两种方法仍然存在问题。
几个容易混淆的地方:
例子:
await item.element(by.css("h4 a")).getText().then(async(text)=> {
if (text == product) {
await item.element(by.css("button[class*='btn-info']")).click();
}
工作结果:
在上图中,变量打印的结果如 80000 等
我的代码如下:
第一种方法:
我已经替换了每个函数关键字并将 async 与 fat 函数放在一起,我还在允许的地方添加了 await 。另外,我有使用 await 然后一起使用
import { Given, When, Then } from "cucumber";
import { browser, element, by } from "protractor";
import { async } from "q";
import chai from "chai"
let assert = chai.assert;
async function selectItems(product) {
//take 4 cards into list
//go through each index in the list - and get the title= if title =desired title then in that index i will select add button
await element.all(by.tagName("app-card")).each(async(item) => {
await item.element(by.css("h4 a")).getText().then(async(text)=> {
if (text == product) {
await item.element(by.css("button[class*='btn-info']")).click();
}
})
})
}
Given(':I will navigate to qaacamedy site', async () => {
await browser.get("https://qaclickacademy.github.io/protocommerce/");
await console.log("browser lunched");
});
When(': click on the shop and add all products in cart', async () => {
await element(by.linkText("Shop")).click();
await selectItems("Samsung Note 8");
await selectItems("iphone X");
await element(by.partialLinkText("Checkout")).getText().then(function(text) {
let res = text.split("(");
let x = res[1].trim().charAt(0);
let y = x;
console.log(y);
assert.equal(res[1].trim().charAt(0),x);
})
});
When(': I calculate all price', async () => {
let value;
let amount=new Array() ;
let set= new Set();
await element(by.partialLinkText("Checkout")).click();
await element.all(by.css("td[class*='text-center']")).each(function(item){
item.element(by.css("strong")).getText().then(function(text) {
console.log(text);
let res =text.split('.');
value=Number(res[1].trim());
amount.push(value);
set.add(value);
console.log("my value ="+value);
console.log("my amounts"+amount);
})
})
let add=0;
// for (let i = 0; i < amount.length; i++) {
// await console.log("array value = "+amount[i]);
// add=add+amount[i];
// }
for (let num of set) {
await console.log("iterbale value of set = "+num); //1 2 3 4 5 6
add=add+num;
}
await console.log("total calculate value ="+add);
await console.log("my amounts final"+amount);
});
Then(': some should be shown', async () => {
await console.log("Then Statement");
});
如上结果所示,语句现在没有打印出来,但有时我会得到结果
第二种方法:
我也尝试将 promise 函数设置为异步:
import { Given, When, Then } from "cucumber";
import { browser, element, by } from "protractor";
import { async } from "q";
import chai from "chai"
let assert = chai.assert;
async function selectItems(product) {
//take 4 cards into list
//go through each index in the list - and get the title= if title =desired title then in that index i will select add button
await element.all(by.tagName("app-card")).each(async(item) => {
await item.element(by.css("h4 a")).getText().then(async(text)=> {
if (text == product) {
await item.element(by.css("button[class*='btn-info']")).click();
}
})
})
}
Given(':I will navigate to qaacamedy site', async () => {
await browser.get("https://qaclickacademy.github.io/protocommerce/");
await console.log("browser lunched");
});
When(': click on the shop and add all products in cart', async () => {
await element(by.linkText("Shop")).click();
await selectItems("Samsung Note 8");
await selectItems("iphone X");
await element(by.partialLinkText("Checkout")).getText().then(async(text)=> {
let res = text.split("(");
let x = res[1].trim().charAt(0);
let y = x;
await console.log(y);
await assert.equal(res[1].trim().charAt(0),x);
})
});
When(': I calculate all price', async () => {
let value;
let amount=new Array() ;
let set= new Set();
await element(by.partialLinkText("Checkout")).click();
await element.all(by.css("td[class*='text-center']")).each(async(item)=>{
item.element(by.css("strong")).getText().then(async(text)=> {
await console.log(text);
let res =text.split('.');
value=Number(res[1].trim());
amount.push(value);
set.add(value);
await console.log("my value ="+value);
await console.log("my amounts"+amount);
})
})
let add=0;
// for (let i = 0; i < amount.length; i++) {
// await console.log("array value = "+amount[i]);
// add=add+amount[i];
// }
for (let num of set) {
await console.log("iterbale value of set = "+num); //1 2 3 4 5 6
add=add+num;
}
await console.log("total calculate value ="+add);
await console.log("my amounts final"+amount);
});
Then(': sum should be shown', async () => {
await console.log("Then Statement");
});
在第二种方法中,我也遇到了同样的问题。
还建议,处理 promise 函数以及以下内容是否是一种好的做法:
await element(by.partialLinkText("Checkout")).getText().then(async(text)=> {
在上述两种方法中,我都使用了以下标志:
SELENIUM_PROMISE_MANAGER: false,
如果我使用 launch.json 使用 Debug模式,这个问题总是特别出现
我的特征文件如下所示:
Feature: I am going to validate the qaacamedy site
Scenario: practice assignment
Given :I will navigate to qaacamedy site
When : click on the shop and add all products in cart
When : I calculate all price
Then : sum should be shown
还尝试删除 async 、 async kit 和 protractor 包并重新安装它,一旦它工作但过了一段时间它又开始向我显示问题。不明白为什么相同的代码会有不同的行为,我没有得到问题的主要原因,在同一个地方停留了很多天
请调查一下,这是我在 Protractor 上遇到的最后一个严重问题
最佳答案
由于您正在使用 async/await
,因此您应该避免传统的 promise 处理(例如 then
)。看起来您正在 await
ing 不返回 promise 的方法,这本质上是毫无意义的。在回调上声明 async
不会使调用方法异步。
selectItems
的正确实现看起来像这样:
async function selectItems(product) {
// async functions return a promise, use 'map' so we can wait for the promises to resolve using Promise.all
const promises = element.all(by.tagName("app-card")).map(async (item) => {
// use await on getText() since it returns a promise
const text = await item.element(by.css("h4 a")).getText();
if (text == product) {
// return the promise produced by 'click'
return item.element(by.css("button[class*='btn-info']")).click();
}
});
return Promise.all(promises);
}
还应更新测试以避免将 async/await
语法与传统的 promise 处理混合。
关于javascript - 执行跳过 promise 语句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56030116/
创建一个“海盗对话”,可以选择左手或右手。我希望它对“左”和“右”的不同拼写做出积极的回答(正如您将在代码中看到的那样),但是,当我为所有非“右”或“左”的输入添加最终的“else”代码时,它给了我一
With 语句 对一个对象执行一系列的语句。 With object statements End With 参数 object 必需的部分
While...Wend 语句 当指定的条件为 True 时,执行一系列的语句。 While condition  ; Version [stat
所以我正在处理的代码有一个小问题。 while True: r = input("Line: ") n = r.split() if r == " ":
我有一个对象数组: var contacts = [ { "firstName": "Akira", "lastName": "Laine", "number"
int main() { int f=fun(); ... } int fun() { return 1; return 2; } 在上面的程序中,当从main函数中调用一个
我的项目中有很多 if 语句、嵌套 if 语句和 if-else 语句,我正在考虑将它们更改为 switch 语句。其中一些将具有嵌套的 switch 语句。我知道就编译而言,switch 语句通常更
Rem 语句 包含程序中的解释性注释。 Rem comment 或 ' comment comment 参数是需要包含的注释文本。在 Rem 关键字和 comment 之间应有一个空格。
ReDim 语句 在过程级中声明动态数组变量并分配或重新分配存储空间。 ReDim [Preserve] varname(subscripts) [, varname(subscripts)]
Randomize 语句 初始化随机数生成器。 Randomize [number] number 参数可以是任何有效的数值表达式。 说明 Randomize 使用 number 参数初始
Public 语句 定义公有变量并分配存储空间。在 Class 块中定义私有变量。 Public varname[([subscripts])][, varname[([subscripts])
Sub 语句 声明 Sub 过程的名称、参数以及构成其主体的代码。 [Public [Default]| Private] Sub name [( arglist )]
Set 语句 将对象引用赋给一个variable或property,或者将对象引用与事件关联。 Set objectvar = {objectexpression | New classname
我有这个代码块,有时第一个 if 语句先运行,有时第二个 if 语句先运行。我不确定为什么会这样,因为我认为 javascript 是同步的。 for (let i = 0; i < dataObje
这是一个 javascript 代码,我想把它写成这样:如果此人回答是,则回复“那很酷”,如果此人回答否,则回复“我会让你开心”,如果此人回答的问题包含"is"或“否”,请说“仅键入”是或否,没有任何
这是我的任务,我尝试仅使用简短的 if 语句来完成此任务,我得到的唯一错误是使用“(0.5<=ratio<2 )”,除此之外,构造正确吗? Scanner scn = new Scanner(
有没有办法在 select 语句中使用 if 语句? 我不能在这个中使用 Case 语句。实际上我正在使用 iReport 并且我有一个参数。我想要做的是,如果用户没有输入某个参数,它将选择所有实例。
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: If vs. Switch Speed 我将以 C++ 为例,但我要问的问题不是针对特定语言的。我的意思是一
Property Set 语句 在 Class 块中,声明名称、参数和代码,这些构成了将引用设置到对象的 Property 过程的主体。 [Public | Private] Pro
Property Let 语句 在 Class 块中,声明名称、参数和代码等,它们构成了赋值(设置)的 Property 过程的主体。 [Public | Private] Prop
我是一名优秀的程序员,十分优秀!