如何在CodeceptJS和NightmareJS中应用条件到E2E测试

问题描述 投票:0回答:1

我需要的:

在CodeceptJS中进行E2E测试,使用梦魇作为主助手验证元素的存在,并根据结果继续执行一系列操作或其他操作。

示例代码:

class EventsHelper extends Helper {

  isExistsElement(selector) {
    let browser = this.helpers['Nightmare'].browser;
    return browser.evaluate((selector) => {
      return new Promise(resolve => {
        let element = document.querySelector(selector);
        resolve(element || false);
      });
    }, selector);
  }
}
module.exports = EventsHelper;

Scenario('Test 1', async (I) => {
  const isButtonRendered = await I.isExistsElement('#button');

  if (isButtonRendered) {
    I.see('Message that is displayed only if the button exists.');
    I.click('#button');
  } else {
    I.see('Alternative message that appears if this button does not exist.');
  }
});

此示例代码的当前结果是: - 如果按钮存在。

Evaluation timed out after 30000msec.  Are you calling done() or resolving your promises?
  • 否则该按钮不存在:通过。

我愿意接受建议,更正或不同的想法来解决这个问题。谢谢你们! (如果我的英语不是很清楚,请原谅我)。

javascript node.js e2e-testing codeceptjs
1个回答
0
投票

您必须为条件本身使用自定义帮助程序,根据codeceptjs开发人员,它们不支持主要scenario函数中的条件。

这是一个自定义帮助器示例:

'use strict';
import assert from 'assert';

let Helper = codecept_helper;

class MyHelper extends Helper {
  async clickIfVisible(selector, ...options) {
    const helper = this.helpers['Puppeteer'];
    try {
      const numVisible = await helper.grabNumberOfVisibleElements(selector);

      if (numVisible) {
        return helper.click(selector, ...options);
      }
    } catch (err) {
      console.log('Skipping operation as element is not visible');
    }
  }
}

module.exports = MyHelper;

更多信息:https://github.com/Codeception/CodeceptJS/issues/648

© www.soinside.com 2019 - 2024. All rights reserved.