clean up plugin manager constructor and add some basic plugin manager tests

This commit is contained in:
Sebastian McKenzie 2015-04-30 18:06:15 +01:00
parent 98206df864
commit ee0c88a070
3 changed files with 50 additions and 7 deletions

View File

@ -219,7 +219,12 @@ export default class File {
// init plugins!
var beforePlugins = [];
var afterPlugins = [];
var pluginManager = new PluginManager(this, this.transformers, beforePlugins, afterPlugins);
var pluginManager = new PluginManager({
file: this,
transformers: this.transformers,
before: beforePlugins,
after: afterPlugins
});
for (var i = 0; i < file.opts.plugins.length; i++) {
pluginManager.add(file.opts.plugins[i]);
}

View File

@ -18,18 +18,18 @@ export default class PluginManager {
return transformer;
}
constructor(file, transformers, before, after) {
constructor({ file, transformers, before, after } = { transformers: {}, before: [], after: [] }) {
this.transformers = transformers;
this.file = file;
this.before = before;
this.after = after;
}
subnormaliseString(name) {
subnormaliseString(key, _position) {
// this is a plugin in the form of "foobar" or "foobar:after"
// where the optional colon is the delimiter for plugin position in the transformer stack
var [name, position] = name.split(":");
var [name, position = _position] = key.split(":");
var loc = util.resolveRelative(name) || util.resolveRelative(`babel-plugin-${name}`);
if (loc) {
@ -42,7 +42,7 @@ export default class PluginManager {
}
}
validate(plugin) {
validate(name, plugin) {
// validate transformer key
var key = plugin.key;
if (this.transformers[key]) {
@ -69,7 +69,7 @@ export default class PluginManager {
}
if (typeof name === "string") {
({ plugin, position } = this.subnormaliseString(name));
({ plugin, position } = this.subnormaliseString(name, position));
}
} else {
throw new TypeError(messages.get("pluginIllegalKind", typeof name, name));
@ -89,7 +89,7 @@ export default class PluginManager {
}
//
this.validate(plugin);
this.validate(name, plugin);
// build!
var pass = this.transformers[plugin.key] = plugin.buildPass(this.file);

View File

@ -1,6 +1,8 @@
require("../../lib/babel/api/node");
var buildExternalHelpers = require("../../lib/babel/tools/build-external-helpers");
var PluginManager = require("../../lib/babel/transformation/file/plugin-manager");
var Transformer = require("../../lib/babel/transformation/transformer");
var transform = require("../../lib/babel/transformation");
var assert = require("assert");
var File = require("../../lib/babel/transformation/file");
@ -51,4 +53,40 @@ suite("api", function () {
assert.ok(script.indexOf("inherits") === -1);
});
});
suite("plugins", function () {
test("unknown plugin", function () {
assert.throws(function () {
new PluginManager().subnormaliseString("foo bar");
}, /Unknown plugin/);
});
test("key collision", function () {
assert.throws(function () {
new PluginManager({
transformers: { "es6.arrowFunctions": true }
}).validate("foobar", { key: "es6.arrowFunctions" });
}, /collides with another/);
});
test("not transformer", function () {
assert.throws(function () {
new PluginManager().validate("foobar", {});
}, /didn't export a Transformer instance/);
assert.throws(function () {
new PluginManager().validate("foobar", "");
}, /didn't export a Transformer instance/);
assert.throws(function () {
new PluginManager().validate("foobar", []);
}, /didn't export a Transformer instance/);
});
test("object request");
test("string request");
test("transformer request");
});
});