如何解决TestCafe - 如何增加 If 语句的最大等待时间或为 If 语句显式定义的超时
我正在尝试编写两个 If 语句,如果条件交替出现,那么我的代码工作正常。
但是当两个语句同时为真时,第二个 If 语句总是被跳过,因为在第一个条件执行后有 5-6 秒的时间差。
因此,即使第二个条件有效(等待窗口出现),它也不会进入第二个 if 语句。
我尝试写入超时,但它在 testcafe 中不起作用。
如果有任何内置函数可用于 If-Condition 就像它用于断言一样,请有人帮忙 -
// await t.expect('.boarding-pass',{ timeout: 10000 });
类似选项在 If Condition 下不起作用 - // if ( '.boarding-pass'.exists,{ timeout: 10000 }){ do something}
仅当登机牌屏幕出现时才有效,如果没有,则等待 10 秒并跳过第二个 If 语句。
我暂时不放代码。如果你真的需要真正的代码来解决我的问题,那么我会尝试使用一些公共应用程序重新创建它。
解决方法
您可以使用内置的 Wait Mechanism for Selectors 有条件地执行测试语句。
例如,以下代码等待两个元素出现在 DOM 中(您可以指定 timeout 选项),如果某个元素存在且可见,则单击它。
import { Selector } from 'testcafe';
fixture('Selector')
.page('http://devexpress.github.io/testcafe/example');
test ('test1',async (t)=\> {
const selector1 = Selector('#remote-testing');
const selector2 = Selector('#remote-testing-wrong',{ timeout: 10000 } ); //wrong id,it will never appear
const element1 = await selector1();
const element2 = await selector2();
if(element1 && element1.visible) {
await t.click(selector1);
}
if(element2 && element2.visible) {
await t.click(selector2);
}
});
请注意,仅当页面包含偶尔出现且不可预测的元素(如第三方组件的聊天窗口)时才应使用此方法,并且您无法在测试中将其关闭。如果元素总是在执行测试场景时出现,推荐的方法是使用内置的等待机制来执行点击、打字等操作
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。