WebdriverIO-Jasmine Async 功能未在 10000 毫秒内完成

问题描述

我正在将 Wdio 与 Jasmine 和 Chai 一起使用。

我收到以下错误,并且我已经尝试找出根本原因超过一天了。

错误:超时 - 异步函数未在 10000 毫秒内完成(由 jasmine.DEFAULT_TIMEOUT_INTERVAL 设置)

代码

describe('Lead Routing Functionality',() => {
    beforeEach(function () {
        LightningLeadPage.open();
        LightningLeadPage.login();
        console.log('[TEST STEP INFO]: Checking Header: ');
    });
it('Verify validation',() => {
        LightningLeadPage.click_app_launcher();
});
              *************
export default class Lightning_Page {
click_app_launcher() {
    console.log("[TEST STEP INFO]: Verify App launcher icon is present. ");
    console.log('DEBUG : I am waiting...')
    this.appLauncher().waitForExist(this.waitDuration());
    console.log("[TEST STEP INFO]: Clicking on App Launcher");
    this.appLauncher().click();
  }

我注意到 console.log('DEBUG : I am waiting...') 没有打印在控制台上。

Error log:
[0-0] Error in "Verify validation"
Error: Timeout - Async function did not complete within 10000ms (set by jasmine.DEFAULT_TIMEOUT_INTERVAL)
    at <Jasmine>
    at listOnTimeout (internal/timers.js:549:17)
    at processtimers (internal/timers.js:492:7)
[0-0] DEPRECATION: An asynchronous before/it/after function took a done callback but also returned a promise. This is not supported and will stop working in the future. Either remove the done callback (recommended) or change the function to not return a promise.

config.js 值:

waitforTimeout: 10000,connectionRetryTimeout: 90000,connectionRetryCount: 3,wdioRetries:3,jasmineNodeOpts: {
        defaultTimeoutInterval: (24 * 60 * 60 * 1000),expectationResultHandler: function(passed,assertion) {
            // do something
        }
    },

解决方法

我在尝试将 WDIO 升级到 v7 时也遇到了这个问题。在进一步研究时,我注意到 wdio 配置中指定 jasmine 选项的名称已从 jasmineNodeOpts 更改为 jasmineOpts。它也在他们的 updated documentation 中。一旦我在 wdio 配置中更新了它,它现在适用于 v7。

,

我发现这是 wdio/jasmine V7 及更高版本的问题。将其恢复为 6.something,它应该可以工作(6.7.2 对我有用)。 您可以在测试开始时进行调试,但它仍然会失败 - 可能想在 wdio git 上报告此问题

,

在最新更新 (https://webdriver.io/docs/frameworks/#intercept-assertion) 之后,jasmineOpts 与 jasmineNodeOpts 的区别似乎有所不同。

我刚刚从 jasmineNodeOpts 更改为 jasmineOpts。一切都像升级前一样。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...