Skip to content

Commit

Permalink
chore: use es6-module-loader
Browse files Browse the repository at this point in the history
Switch Traceur to use modules=“instantiate” and use es6-module-loader.
This setup supports cyclic dependencies.
  • Loading branch information
vojtajina committed Oct 8, 2014
1 parent 774901c commit cfc5fdc
Show file tree
Hide file tree
Showing 6 changed files with 76 additions and 22 deletions.
3 changes: 1 addition & 2 deletions file2modulename.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,10 +9,9 @@ function file2moduleName(filePath) {
// module name should not include `src`, `test`, `lib`
.replace(/\/src\//, '/')
.replace(/\/lib\//, '/')
.replace(/\/test\//, '/')
// module name should not have a suffix
.replace(/\.\w*$/, '');
}
if (typeof module !== 'undefined') {
module.exports = file2moduleName;
}
}
17 changes: 10 additions & 7 deletions karma-js.conf.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,12 +8,15 @@ module.exports = function(config) {
frameworks: ['jasmine'],

files: [
// Sources and specs.
// Loaded through the es6-module-loader, in `test-main.js`.
{pattern: 'modules/**', included: false},
{pattern: 'tools/transpiler/**', included: false},

'node_modules/traceur/bin/traceur-runtime.js',
'modules/**/test_lib/**/*.es6',
'modules/**/*.js',
'modules/**/*.es6',
'tools/transpiler/spec/**/*.js',
'tools/transpiler/spec/**/*.es6',
'node_modules/es6-module-loader/dist/es6-module-loader-sans-promises.src.js',
'node_modules/systemjs/lib/extension-register.js',

'file2modulename.js',
'test-main.js'
],
Expand All @@ -29,15 +32,15 @@ module.exports = function(config) {
options: {
outputLanguage: 'es5',
script: false,
modules: 'register',
modules: 'instantiate',
types: true,
typeAssertions: true,
typeAssertionModule: 'rtts_assert/rtts_assert',
annotations: true
},
resolveModuleName: file2moduleName,
transformPath: function(fileName) {
return fileName.replace('.es6', '');
return fileName.replace(/\.es6$/, '.js');
}
},

Expand Down
3 changes: 3 additions & 0 deletions modules/rtts_assert/test/rtts_assert_spec.es6
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
import {assert} from 'rtts_assert/rtts_assert';


export function main() {

// ## Basic Type Check
// By default, `instanceof` is used to check the type.
Expand Down Expand Up @@ -375,3 +376,5 @@ describe('Traceur', function() {
// <center><small>
// This documentation was generated from [assert.spec.js](https://github.com/vojtajina/assert/blob/master/test/assert.spec.js) using [Docco](http://jashkenas.github.io/docco/).
// </small></center>

}
2 changes: 2 additions & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,8 @@
"author": "Tobias Bosch <[email protected]>",
"license": "MIT",
"dependencies": {
"es6-module-loader": "^0.9.2",
"systemjs": "^0.9.1",
"gulp": "^3.8.8",
"gulp-rename": "^1.2.0",
"gulp-watch": "^1.0.3",
Expand Down
69 changes: 59 additions & 10 deletions test-main.js
Original file line number Diff line number Diff line change
@@ -1,11 +1,60 @@
var TEST_REGEXP = /_spec.*/;

Object.keys(window.__karma__.files).forEach(function(path) {
if (TEST_REGEXP.test(path)) {
var moduleName = window.file2moduleName(path);
var mod = System.get(moduleName);
if (mod && mod.main) {
mod.main();
}
}
// Use "register" extension from systemjs.
// That's what Traceur outputs: `System.register()`.
register(System);


// Cancel Karma's synchronous start,
// we will call `__karma__.start()` later, once all the specs are loaded.
__karma__.loaded = function() {};


System.baseURL = '/base/modules/';

// So that we can import packages like `core/foo`, instead of `core/src/foo`.
System.paths = {
'core/*': './core/src/*.js',
'core/test/*': './core/test/*.js',

'change_detection/*': './change_detection/src/*.js',
'change_detection/test/*': './change_detection/test/*.js',

'facade/*': './facade/src/*.js',
'facade/test/*': './facade/test/*.js',

'di/*': './di/src/*.js',
'di/test/*': './di/test/*.js',

'rtts_assert/*': './rtts_assert/src/*.js',
'rtts_assert/test/*': './rtts_assert/test/*.js',

'test_lib/*': './test_lib/src/*.js',
'test_lib/test/*': './test_lib/test/*.js',

'transpiler/*': '../tools/transpiler/*.js'
}


// Import all the specs, execute their `main()` method and kick off Karma (Jasmine).
Promise.all(
Object.keys(window.__karma__.files) // All files served by Karma.
.filter(onlySpecFiles)
.map(window.file2moduleName) // Normalize paths to module names.
.map(function(path) {
return System.import(path).then(function(module) {
if (module.hasOwnProperty('main')) {
module.main()
} else {
throw new Error('Module ' + path + ' does not implement main() method.');
}
});
})).then(function() {
__karma__.start();
}, function(error) {
console.error(error.stack || error)
__karma__.start();
});


function onlySpecFiles(path) {
return /_spec\.js$/.test(path);
}
4 changes: 1 addition & 3 deletions tools/transpiler/spec/a-0-subfolder/library_spec.js
Original file line number Diff line number Diff line change
@@ -1,3 +1 @@
function main() {
assert(true);
}
export function main() {}

0 comments on commit cfc5fdc

Please sign in to comment.