Restrict Babel's plugins/presets to a single target. (#5547)
This commit is contained in:
@@ -116,11 +116,13 @@ describe("api", function () {
|
||||
});
|
||||
|
||||
it("exposes the resolvePlugin method", function() {
|
||||
assert.equal(babel.resolvePlugin("nonexistent-plugin"), null);
|
||||
assert.throws(() => babel.resolvePlugin("nonexistent-plugin"),
|
||||
/Cannot find module 'babel-plugin-nonexistent-plugin'/);
|
||||
});
|
||||
|
||||
it("exposes the resolvePreset method", function() {
|
||||
assert.equal(babel.resolvePreset("nonexistent-preset"), null);
|
||||
assert.throws(() => babel.resolvePreset("nonexistent-preset"),
|
||||
/Cannot find module 'babel-preset-nonexistent-preset'/);
|
||||
});
|
||||
|
||||
it("transformFile", function (done) {
|
||||
|
||||
0
packages/babel-core/test/fixtures/resolution/babel-org-paths/node_modules/@babel/plugin-foo/index.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/babel-org-paths/node_modules/@babel/plugin-foo/index.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/babel-org-paths/node_modules/@babel/preset-foo/index.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/babel-org-paths/node_modules/@babel/preset-foo/index.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/babel-scoped-nested-module-paths/node_modules/@babel/mod/plugin.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/babel-scoped-nested-module-paths/node_modules/@babel/mod/plugin.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/babel-scoped-nested-module-paths/node_modules/@babel/mod/preset.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/babel-scoped-nested-module-paths/node_modules/@babel/mod/preset.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/foo-org-paths/node_modules/@foo/babel-plugin-mod/index.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/foo-org-paths/node_modules/@foo/babel-plugin-mod/index.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/foo-org-paths/node_modules/@foo/babel-preset-mod/index.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/foo-org-paths/node_modules/@foo/babel-preset-mod/index.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/module-paths/node_modules/plugin/index.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/module-paths/node_modules/plugin/index.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/module-paths/node_modules/preset/index.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/module-paths/node_modules/preset/index.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/nested-module-paths/node_modules/mod/plugin.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/nested-module-paths/node_modules/mod/plugin.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/nested-module-paths/node_modules/mod/preset.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/nested-module-paths/node_modules/mod/preset.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/relative-paths/dir/plugin.js
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/relative-paths/dir/plugin.js
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/relative-paths/dir/preset.js
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/relative-paths/dir/preset.js
vendored
Normal file
@@ -1 +0,0 @@
|
||||
!node_modules/
|
||||
@@ -1 +0,0 @@
|
||||
var x = "before";
|
||||
@@ -1 +0,0 @@
|
||||
var x = "AFTER";
|
||||
@@ -1,9 +0,0 @@
|
||||
module.exports = function () {
|
||||
return {
|
||||
visitor: {
|
||||
StringLiteral: function (path) {
|
||||
path.node.value = "after";
|
||||
},
|
||||
},
|
||||
};
|
||||
};
|
||||
@@ -1,19 +0,0 @@
|
||||
module.exports = function (context, options, fileContext) {
|
||||
if (/resolve-addons-relative-to-file$/.test(fileContext.dirname)) {
|
||||
return {
|
||||
plugins: [plugin],
|
||||
};
|
||||
}
|
||||
return {};
|
||||
};
|
||||
|
||||
function plugin () {
|
||||
return {
|
||||
visitor: {
|
||||
StringLiteral: function (path) {
|
||||
path.node.value =
|
||||
path.node.value.toUpperCase();
|
||||
},
|
||||
},
|
||||
};
|
||||
}
|
||||
0
packages/babel-core/test/fixtures/resolution/scoped-nested-module-paths/node_modules/@foo/mod/plugin.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/scoped-nested-module-paths/node_modules/@foo/mod/plugin.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/scoped-nested-module-paths/node_modules/@foo/mod/preset.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/scoped-nested-module-paths/node_modules/@foo/mod/preset.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/standard-paths/node_modules/babel-plugin-mod/index.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/standard-paths/node_modules/babel-plugin-mod/index.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/standard-paths/node_modules/babel-preset-mod/index.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/standard-paths/node_modules/babel-preset-mod/index.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/throw-babel-paths/node_modules/@babel/plugin-foo/index.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/throw-babel-paths/node_modules/@babel/plugin-foo/index.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/throw-babel-paths/node_modules/@babel/preset-foo/index.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/throw-babel-paths/node_modules/@babel/preset-foo/index.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/throw-missing-paths/.gitignore
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/throw-missing-paths/.gitignore
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/throw-module-paths/node_modules/foo/index.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/throw-module-paths/node_modules/foo/index.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/throw-opposite-paths/node_modules/babel-plugin-testplugin/index.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/throw-opposite-paths/node_modules/babel-plugin-testplugin/index.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/throw-opposite-paths/node_modules/babel-preset-testpreset/index.js
generated
vendored
Normal file
0
packages/babel-core/test/fixtures/resolution/throw-opposite-paths/node_modules/babel-preset-testpreset/index.js
generated
vendored
Normal file
@@ -1,56 +1,398 @@
|
||||
import assert from "assert";
|
||||
import async from "async";
|
||||
import * as babel from "../lib/index";
|
||||
import fs from "fs";
|
||||
import path from "path";
|
||||
|
||||
// Test that plugins & presets are resolved relative to `filename`.
|
||||
describe("addon resolution", function () {
|
||||
it("addon resolution", function (done) {
|
||||
const fixtures = {};
|
||||
const paths = {};
|
||||
const base = path.join(__dirname, "fixtures", "resolution");
|
||||
|
||||
paths.fixtures = path.join(
|
||||
__dirname,
|
||||
"fixtures",
|
||||
"resolution",
|
||||
"resolve-addons-relative-to-file"
|
||||
);
|
||||
beforeEach(function() {
|
||||
this.cwd = process.cwd();
|
||||
process.chdir(base);
|
||||
});
|
||||
|
||||
async.each(
|
||||
["actual", "expected"],
|
||||
function (key, mapDone) {
|
||||
paths[key] = path.join(paths.fixtures, key + ".js");
|
||||
fs.readFile(paths[key], { encoding: "utf8" }, function (err, data) {
|
||||
if (err) return mapDone(err);
|
||||
fixtures[key] = data.trim();
|
||||
mapDone();
|
||||
});
|
||||
},
|
||||
fixturesReady
|
||||
);
|
||||
afterEach(function() {
|
||||
process.chdir(this.cwd);
|
||||
});
|
||||
|
||||
function fixturesReady (err) {
|
||||
if (err) return done(err);
|
||||
it("should find module: presets", function() {
|
||||
process.chdir("module-paths");
|
||||
|
||||
const orignalCwd = process.cwd();
|
||||
try {
|
||||
process.chdir(paths.fixtures);
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
presets: [
|
||||
"module:preset",
|
||||
],
|
||||
});
|
||||
});
|
||||
|
||||
const actual = babel.transform(fixtures.actual, {
|
||||
babelrc: false,
|
||||
filename: paths.actual,
|
||||
plugins: ["addons/plugin"],
|
||||
presets: ["addons/preset"],
|
||||
}).code;
|
||||
it("should find module: plugins", function() {
|
||||
process.chdir("module-paths");
|
||||
|
||||
assert.equal(actual, fixtures.expected);
|
||||
} finally {
|
||||
process.chdir(orignalCwd);
|
||||
}
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
plugins: [
|
||||
"module:plugin",
|
||||
],
|
||||
});
|
||||
});
|
||||
|
||||
done();
|
||||
}
|
||||
// fixturesReady
|
||||
it("should find standard presets", function() {
|
||||
process.chdir("standard-paths");
|
||||
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
presets: [
|
||||
"mod",
|
||||
],
|
||||
});
|
||||
});
|
||||
|
||||
it("should find standard plugins", function() {
|
||||
process.chdir("standard-paths");
|
||||
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
plugins: [
|
||||
"mod",
|
||||
],
|
||||
});
|
||||
});
|
||||
|
||||
it("should find standard presets with an existing prefix", function() {
|
||||
process.chdir("standard-paths");
|
||||
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
presets: [
|
||||
"babel-preset-mod",
|
||||
],
|
||||
});
|
||||
});
|
||||
|
||||
it("should find standard plugins with an existing prefix", function() {
|
||||
process.chdir("standard-paths");
|
||||
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
plugins: [
|
||||
"babel-plugin-mod",
|
||||
],
|
||||
});
|
||||
});
|
||||
|
||||
it("should find @babel scoped presets", function() {
|
||||
process.chdir("babel-org-paths");
|
||||
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
presets: [
|
||||
"@babel/foo",
|
||||
],
|
||||
});
|
||||
});
|
||||
|
||||
it("should find @babel scoped plugins", function() {
|
||||
process.chdir("babel-org-paths");
|
||||
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
plugins: [
|
||||
"@babel/foo",
|
||||
],
|
||||
});
|
||||
});
|
||||
|
||||
it("should find @babel scoped presets with an existing prefix", function() {
|
||||
process.chdir("babel-org-paths");
|
||||
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
presets: [
|
||||
"@babel/preset-foo",
|
||||
],
|
||||
});
|
||||
});
|
||||
|
||||
it("should find @babel scoped plugins", function() {
|
||||
process.chdir("babel-org-paths");
|
||||
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
plugins: [
|
||||
"@babel/plugin-foo",
|
||||
],
|
||||
});
|
||||
});
|
||||
|
||||
it("should find @foo scoped presets", function() {
|
||||
process.chdir("foo-org-paths");
|
||||
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
presets: [
|
||||
"@foo/mod",
|
||||
],
|
||||
});
|
||||
});
|
||||
|
||||
it("should find @foo scoped plugins", function() {
|
||||
process.chdir("foo-org-paths");
|
||||
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
plugins: [
|
||||
"@foo/mod",
|
||||
],
|
||||
});
|
||||
});
|
||||
|
||||
it("should find @foo scoped presets with an existing prefix", function() {
|
||||
process.chdir("foo-org-paths");
|
||||
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
presets: [
|
||||
"@foo/babel-preset-mod",
|
||||
],
|
||||
});
|
||||
});
|
||||
|
||||
it("should find @foo scoped plugins with an existing prefix", function() {
|
||||
process.chdir("foo-org-paths");
|
||||
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
plugins: [
|
||||
"@foo/babel-plugin-mod",
|
||||
],
|
||||
});
|
||||
});
|
||||
|
||||
it("should find relative path presets", function() {
|
||||
process.chdir("relative-paths");
|
||||
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
presets: [
|
||||
"./dir/preset.js",
|
||||
],
|
||||
});
|
||||
});
|
||||
|
||||
it("should find relative path plugins", function() {
|
||||
process.chdir("relative-paths");
|
||||
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
plugins: [
|
||||
"./dir/plugin.js",
|
||||
],
|
||||
});
|
||||
});
|
||||
|
||||
it("should find module file presets", function() {
|
||||
process.chdir("nested-module-paths");
|
||||
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
presets: [
|
||||
"mod/preset",
|
||||
],
|
||||
});
|
||||
});
|
||||
|
||||
it("should find module file plugins", function() {
|
||||
process.chdir("nested-module-paths");
|
||||
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
plugins: [
|
||||
"mod/plugin",
|
||||
],
|
||||
});
|
||||
});
|
||||
|
||||
it("should find @foo scoped module file presets", function() {
|
||||
process.chdir("scoped-nested-module-paths");
|
||||
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
presets: [
|
||||
"@foo/mod/preset",
|
||||
],
|
||||
});
|
||||
});
|
||||
|
||||
it("should find @foo scoped module file plugins", function() {
|
||||
process.chdir("scoped-nested-module-paths");
|
||||
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
plugins: [
|
||||
"@foo/mod/plugin",
|
||||
],
|
||||
});
|
||||
});
|
||||
|
||||
it("should find @babel scoped module file presets", function() {
|
||||
process.chdir("babel-scoped-nested-module-paths");
|
||||
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
presets: [
|
||||
"@babel/mod/preset",
|
||||
],
|
||||
});
|
||||
});
|
||||
|
||||
it("should find @babel scoped module file plugins", function() {
|
||||
process.chdir("babel-scoped-nested-module-paths");
|
||||
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
plugins: [
|
||||
"@babel/mod/plugin",
|
||||
],
|
||||
});
|
||||
});
|
||||
|
||||
it("should throw about module: usage for presets", function() {
|
||||
process.chdir("throw-module-paths");
|
||||
|
||||
assert.throws(() => {
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
presets: [
|
||||
"foo",
|
||||
],
|
||||
});
|
||||
// eslint-disable-next-line max-len
|
||||
}, /Cannot find module 'babel-preset-foo'.*\n- If you want to resolve "foo", use "module:foo"/);
|
||||
});
|
||||
|
||||
it("should throw about module: usage for plugins", function() {
|
||||
process.chdir("throw-module-paths");
|
||||
|
||||
assert.throws(() => {
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
plugins: [
|
||||
"foo",
|
||||
],
|
||||
});
|
||||
// eslint-disable-next-line max-len
|
||||
}, /Cannot find module 'babel-plugin-foo'.*\n- If you want to resolve "foo", use "module:foo"/);
|
||||
});
|
||||
|
||||
it("should throw about @babel usage for presets", function() {
|
||||
process.chdir("throw-babel-paths");
|
||||
|
||||
assert.throws(() => {
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
presets: [
|
||||
"foo",
|
||||
],
|
||||
});
|
||||
// eslint-disable-next-line max-len
|
||||
}, /Cannot find module 'babel-preset-foo'.*\n- Did you mean "@babel\/foo"\?/);
|
||||
});
|
||||
|
||||
it("should throw about @babel usage for plugins", function() {
|
||||
process.chdir("throw-babel-paths");
|
||||
|
||||
assert.throws(() => {
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
plugins: [
|
||||
"foo",
|
||||
],
|
||||
});
|
||||
// eslint-disable-next-line max-len
|
||||
}, /Cannot find module 'babel-plugin-foo'.*\n- Did you mean "@babel\/foo"\?/);
|
||||
});
|
||||
|
||||
it("should throw about passing a preset as a plugin", function() {
|
||||
process.chdir("throw-opposite-paths");
|
||||
|
||||
assert.throws(() => {
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
presets: [
|
||||
"testplugin",
|
||||
],
|
||||
});
|
||||
// eslint-disable-next-line max-len
|
||||
}, /Cannot find module 'babel-preset-testplugin'.*\n- Did you accidentally pass a preset as a plugin\?/);
|
||||
});
|
||||
|
||||
it("should throw about passing a plugin as a preset", function() {
|
||||
process.chdir("throw-opposite-paths");
|
||||
|
||||
assert.throws(() => {
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
plugins: [
|
||||
"testpreset",
|
||||
],
|
||||
});
|
||||
// eslint-disable-next-line max-len
|
||||
}, /Cannot find module 'babel-plugin-testpreset'.*\n- Did you accidentally pass a plugin as a preset\?/);
|
||||
});
|
||||
|
||||
it("should throw about missing presets", function() {
|
||||
process.chdir("throw-missing-paths");
|
||||
|
||||
assert.throws(() => {
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
presets: [
|
||||
"foo",
|
||||
],
|
||||
});
|
||||
}, /Cannot find module 'babel-preset-foo'/);
|
||||
});
|
||||
|
||||
it("should throw about missing plugins", function() {
|
||||
process.chdir("throw-missing-paths");
|
||||
|
||||
assert.throws(() => {
|
||||
babel.transform("", {
|
||||
filename: "filename.js",
|
||||
babelrc: false,
|
||||
plugins: [
|
||||
"foo",
|
||||
],
|
||||
});
|
||||
}, /Cannot find module 'babel-plugin-foo'/);
|
||||
});
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user