3

我正在将 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
        }
    },
4

3 回答 3

5

我在尝试将 WDIO 升级到 v7 时也遇到了这个问题。在进一步研究时,我注意到在 wdio 配置中指定 jasmine 选项的名称已从 更改jasmineNodeOptsjasmineOpts. 它也在他们更新的文档中。一旦我在我的 wdio 配置中更新了它,现在 v7 就很好了。

于 2021-04-21T11:21:40.247 回答
0

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

于 2021-04-20T20:27:16.270 回答
0

在最新更新( https://webdriver.io/docs/frameworks/#intercept-assertion )之后,看起来区别是 jasmineOpts 与 jasmineNodeOpts 。

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

于 2021-05-28T19:30:15.690 回答