Вывести консольный вывод gulp-qunit в файл - PullRequest
0 голосов
/ 02 мая 2018

Я запускаю модульные тесты с использованием QUnit и пытаюсь интегрировать QUnit в процесс автоматизации нашей сборки и непрерывной интеграции. Чтобы Atlassian Bamboo проанализировал результаты теста, он должен находиться в файле XML. Я могу создать консольный журнал в требуемом формате xml с помощью плагина qunit-reporter-junit. Когда Gulp-QUnit запускает наш файл test-runner.html, он выводит console.log на экран. Моя проблема в том, что я не могу найти способ передать этот файл console.log в файл.

Я пробовал следующие подходы:

Использование плагина gulp-log-capture (ничего не делает):

  gulp.task('qunit', function() {

  return gulp.src('./qunit/test-runner.html')
      .pipe(logCapture.start(console,'log'))
      .pipe(qunit())
      .pipe(logCapture.stop('build.xml'));
});

Передача вывода в поток записи (который выдает ошибку):

gulp.task('qunit', function() {

  return gulp.src('./qunit/test-runner.html')
      .pipe(qunit())
      .pipe(fs.createWriteStream('build.xml));
});

Использование плагина gulp-out (который просто передает входной html в новый файл):

gulp.task('qunit', function() {

  return gulp.src('./qunit/test-runner.html')
      .pipe(qunit())
      .pipe(out('build.xml');
});

XML прямо на экране, мне просто нужно каким-то образом поместить его в файл.

1 Ответ

0 голосов
/ 24 августа 2018

Оказывается, что фантом js принимает нодоподобные сценарии, которые будут выполняться при выполнении. Я в основном взял скрипт run-qunit из каталога примеров phantom-js и настроил его так, чтобы выводить консольный вывод в файл build.xml. Пример скрипта можно найти здесь: https://github.com/ariya/phantomjs/blob/master/examples/run-qunit.js

Я просто настроил прослушиватель onConsoleMessage (ln48) следующим образом:

page.onConsoleMessage = function(msg) {        
    if( msg.search(/xml/) > -1 ) {
        fs.write('build.xml',msg);
    }
    console.log(msg);
};

Чтобы запустить этот процесс как часть автоматизированного процесса сборки, в Gulp я запустил следующую задачу с помощью плагина exec.

exec = require('child_process').exec;
.
.
.
gulp.task('phantom',function() {
    exec('phantomjs ./qunit/run-qunit.js ./qunit/test-runner.html');
});

Обе эти корректировки успешно создают файл build.xml, который Atlassian Bamboo может читать как часть своего процесса.

...