Skip to content

Commit

Permalink
chore(build): refactor test.unit.cjs to use the broccoli pipeline
Browse files Browse the repository at this point in the history
This change solves several problems:
- the broccoli pipeline is used to compile the node/cjs tree upon any change to the modules/ directory
- jasmine tests run in a new process removing the need to clean up environment after each test
- since we transpile only those test files that are actually needed for node/cjs build, we transpile less and don't need to filter out tests
  • Loading branch information
IgorMinar committed Apr 27, 2015
1 parent 427f0d0 commit 725f909
Show file tree
Hide file tree
Showing 4 changed files with 56 additions and 19 deletions.
49 changes: 31 additions & 18 deletions gulpfile.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
var autoprefixer = require('gulp-autoprefixer');
var format = require('gulp-clang-format');
var fork = require('child_process').fork;
var gulp = require('gulp');
var gulpPlugins = require('gulp-load-plugins')();
var sass = require('gulp-sass');
Expand All @@ -8,6 +9,7 @@ var runSequence = require('run-sequence');
var madge = require('madge');
var merge = require('merge');
var path = require('path');
var Q = require('q');

var gulpTraceur = require('./tools/transpiler/gulp-traceur');
var clean = require('./tools/build/clean');
Expand Down Expand Up @@ -465,27 +467,38 @@ gulp.task('test.unit.cjs/ci', function () {
gulp.task('test.unit.cjs', ['build.js.cjs'], function () {
//Run tests once
runSequence('test.unit.cjs/ci', function() {});
});

//Watcher to transpile file changed
gulp.watch(CONFIG.transpile.src.js.concat(['modules/**/*.cjs']), function(event) {
var relPath = path.relative(__dirname, event.path).replace(/\\/g, "/");
gulp.src(relPath)
.pipe(gulpPlugins.rename({extname: '.'+ 'js'}))
.pipe(gulpTraceur(CONFIG.transpile.options.js.cjs, file2moduleName))
.pipe(transformCJSTests())
.pipe(gulp.dest(CONFIG.dest.js.cjs + path.dirname(relPath.replace("modules", ""))));
function runNodeJasmineTests() {
var doneDeferred = Q.defer();
var jasmineProcess = fork('./tools/traceur-jasmine', ['dist/js/cjs/angular2/test/**/*_spec.js'], {
stdio: 'inherit'
});
//Watcher to run tests when dist/js/cjs/angular2 is updated by the first watcher (after clearing the node cache)
gulp.watch(CONFIG.dest.js.cjs + '/angular2/**/*.js', function(event) {
for (var id in require.cache) {
if (id.replace(/\\/g, "/").indexOf(CONFIG.dest.js.cjs) > -1) {
delete require.cache[id];
}
}
global.assert = undefined; // https://github.com/angular/angular/issues/1340
runSequence('test.unit.cjs/ci', function() {});

jasmineProcess.on('close', function (code) {
doneDeferred.resolve();
});

return doneDeferred.promise;
}

gulp.task('test.unit.cjs/ci', runNodeJasmineTests);

gulp.task('test.unit.cjs', ['build.broccoli.tools'], function (done) {
//Run tests once
var nodeBroccoliBuilder = getBroccoli().forNodeTree();


nodeBroccoliBuilder.doBuild().then(function() {
gulp.start('build/linknodemodules.js.cjs');
return runNodeJasmineTests();
}).then(function() {
//Watcher to transpile file changed
gulp.watch('modules/**', function(event) {
console.log("fs changes detected", event);
nodeBroccoliBuilder.doBuild().then(runNodeJasmineTests);
});
});
});

// ------------------
Expand Down Expand Up @@ -621,7 +634,7 @@ gulp.task('broccoli.js.cjs', ['build.broccoli.tools'], function() {
gulp.task('build.js.cjs', function(done) {
runSequence(
'broccoli.js.cjs',
['build/linknodemodules.js.cjs'],
'build/linknodemodules.js.cjs',
done
);
});
Expand Down
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -83,6 +83,7 @@
"lodash": "^2.4.1",
"madge": "^0.5.0",
"merge": "^1.2.0",
"minijasminenode2": "^1.0.0",
"minimatch": "^2.0.1",
"minimist": "1.1.x",
"parse5": "1.3.2",
Expand Down
9 changes: 8 additions & 1 deletion tools/broccoli/trees/node_tree.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,14 @@ module.exports = function makeNodeTree() {

var modulesTree = new Funnel('modules', {
include: ['angular2/**', 'benchpress/**', 'rtts_assert/**', '**/e2e_test/**'],
exclude: ['angular2/src/core/zone/vm_turn_zone.es6']
exclude: [
'angular2/src/core/zone/vm_turn_zone.es6',
'angular2/test/core/application_spec.js',
'angular2/test/core/testability/**',
'angular2/test/core/zone/**',
'angular2/test/render/**',
'angular2/test/forms/integration_spec.js'
]
});

var nodeTree = new TraceurCompiler(modulesTree, '.js', '.map', {
Expand Down
16 changes: 16 additions & 0 deletions tools/traceur-jasmine/index.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
'use strict';

var glob = require('glob');
var minijasminenode2 = require('minijasminenode2');
var path = require('path');
// Require traceur to exposes $traceurRuntime on global context so that CJS files can run
require('traceur/bin/traceur-runtime.js');

glob(process.argv[2], function (error, specFiles) {
minijasminenode2.executeSpecs({
includeStackTrace: true,
defaultTimeoutInterval: 1000,
showColors: process.argv.indexOf('--no-color') === -1,
specs: specFiles
});
});

0 comments on commit 725f909

Please sign in to comment.