Testcafe - 在测试案例之外测试命令行参数

6

我正在熟悉Testcafe,尝试使用命令行参数向用户提供更多运行测试的信息。出于这个原因,我使用了minimist包。

但是,我不能在测试用例之外打印或使用任何变量。请查看下面的代码。

import { Selector } from 'testcafe';
import minimist from 'minimist';

const args = minimist(process.argv.slice(2));
const env = args.env;

console.log('*** A SAMPLE CONSOLE OUTPUT ***'); // does not print

fixture `Getting Started`
  .page `http://devexpress.github.io/testcafe/example`;

test('My first test', async t => {
  console.log('*** ANOTHER SAMPLE CONSOLE OUTPUT ***'); // prints
  await t
    .typeText('#developer-name', 'John Smith')
    .wait(1000)
    .click('#submit-button')

    // Use the assertion to check if the actual header text is equal to the expected one
    .expect(Selector('#article-header').innerText).eql('Thank you, John Smith!');
});

我想编写一个if语句来检查env === ''或使用默认参数。
我该如何实现?
2个回答

4
实现这一目标的解决方案如下:
1)创建一个单独的 config.js 文件,用于处理自定义命令行选项:
import * as minimist from 'minimist';

const args = minimist(process.argv.slice(2));

// get the options --env=xxx --user=yyy from the command line
export const config = {
  env: args.env,
  user: args.user,
};

2) 在你的测试文件中:

移除fixturetest方法之外的任何代码。

导入配置文件并将其注入到TestController上下文中。

通过TestController上下文获取命令参数。

import 'testcafe';
import { Selector } from 'testcafe';
import { config } from './config';

fixture('Getting Started')
  .beforeEach(async (t) => {
    // inject config in the test context
    t.ctx.currentConfig = config;
  });

test('My first test', async (t) => {
  // retrieve cli args from the test context
  const currentConfig = t.ctx.currentConfig;
  console.log(`env=${currentConfig.env}`);
});

但是如果用户在没有任何参数的情况下调用测试脚本呢?(或者使用错误/不存在的参数) - user11063797
@William,config.env 将简单地未定义。 - hdorgeval

4
然而,我不能在测试用例之外打印或使用任何变量。
请使用编程方式运行TestCafe。 我已更改了您的代码示例(test.js)并创建了一个程序化地运行TestCafe的文件(run.js)。 将这些文件放入一个文件夹中,并在终端中执行命令'node run.js --env value'。 然后,您将看到以下输出:
'*** A SAMPLE CONSOLE OUTPUT ***'
Getting Started
value

test.js

import { Selector } from 'testcafe';
import minimist from 'minimist';

const args = minimist(process.argv.slice(2));
const env = args.env;

console.log('*** A SAMPLE CONSOLE OUTPUT ***'); 

fixture `Getting Started`
  .page `http://devexpress.github.io/testcafe/example`;

test('My first test', async t => {
  console.log(env); // prints
  await t
    .typeText('#developer-name', 'John Smith')
    .wait(1000)
    .click('#submit-button')
    .expect(Selector('#article-header').innerText).eql('Thank you, John Smith!');
});

run.js
const createTestCafe = require('testcafe');
let runner           = null;

createTestCafe('localhost', 1337, 1338, void 0, true)
    .then(testcafe => {
        runner = testcafe.createRunner();
    })
    .then(() => {
         return runner
            .src('test.js')
            .browsers('chrome')
            .run()
            .then(failedCount => {
                console.log(`Finished. Count failed tests:${failedCount}`);
                process.exit(failedCount)
            });
    })
    .catch(error => {
        console.log(error);
        process.exit(1);
    });

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接