Testcafe - проверка аргумента командной строки вне тестового примера - PullRequest
0 голосов
/ 14 февраля 2019

Поскольку я знакомлюсь с 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 ]

0 голосов
/ 15 февраля 2019

Однако я не могу печатать или использовать какие-либо переменные вне тестовых случаев.

Пожалуйста, используйте способ программирования для запуска 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);
    });
0 голосов
/ 15 февраля 2019

Решение для достижения этой цели:

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) В вашем тестовом файле:

удалить любой код вне методов fixture и test.

импортировать файл конфигурации и внедрить его в контексте 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}`);
});
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...