Bring back isPluginRequired (#9709)

This commit is contained in:
Nicolò Ribaudo 2019-03-19 23:35:13 +01:00 committed by GitHub
parent 8476cf692f
commit c548e789bb
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 84 additions and 84 deletions

View File

@ -20,6 +20,8 @@ import availablePlugins from "./available-plugins";
import { filterStageFromList, prettifyTargets } from "./utils";
import { declare } from "@babel/helper-plugin-utils";
export { isPluginRequired } from "./filter-items";
const pluginListWithoutProposals = filterStageFromList(
pluginList,
proposalPlugins,

View File

@ -1,84 +0,0 @@
"use strict";
const filterItems = require("../lib/filter-items");
describe("filter-items", () => {
describe("isPluginRequired", () => {
const MAX_VERSION = `${Number.MAX_SAFE_INTEGER}.0.0`;
it("returns true if no targets are specified", () => {
expect(filterItems.isPluginRequired({}, {})).toBe(true);
});
it("returns true if plugin feature is not implemented in one or more targets", () => {
let targets;
const plugin = {
edge: false,
firefox: 45,
chrome: 49,
};
targets = {
chrome: MAX_VERSION,
firefox: MAX_VERSION,
};
expect(filterItems.isPluginRequired(targets, plugin)).toBe(false);
targets = {
edge: "12",
};
expect(filterItems.isPluginRequired(targets, plugin)).toBe(true);
});
it("returns false if plugin feature is implemented by lower than target", () => {
const plugin = {
chrome: 49,
};
const targets = {
chrome: MAX_VERSION,
};
expect(filterItems.isPluginRequired(targets, plugin)).toBe(false);
});
it("returns false if plugin feature is implemented is equal to target", () => {
const plugin = {
chrome: 49,
};
const targets = {
chrome: "49.0.0",
};
expect(filterItems.isPluginRequired(targets, plugin)).toBe(false);
});
it("returns true if plugin feature is implemented is greater than target", () => {
const plugin = {
chrome: 50,
};
const targets = {
chrome: "49.0.0",
};
expect(filterItems.isPluginRequired(targets, plugin)).toBe(true);
});
it("returns when target is a decimal", () => {
const plugin = {
node: 6.9,
};
const targets = {
node: "6.10.0",
};
expect(filterItems.isPluginRequired(targets, plugin)).toBe(false);
});
it("throws an error if target version is invalid", () => {
const plugin = {
chrome: 50,
};
const targets = {
chrome: 55,
};
expect(() => filterItems.isPluginRequired(targets, plugin)).toThrow();
});
});
});

View File

@ -0,0 +1,82 @@
"use strict";
const presetEnv = require("../");
describe("isPluginRequired", () => {
const MAX_VERSION = `${Number.MAX_SAFE_INTEGER}.0.0`;
it("returns true if no targets are specified", () => {
expect(presetEnv.isPluginRequired({}, {})).toBe(true);
});
it("returns true if plugin feature is not implemented in one or more targets", () => {
let targets;
const plugin = {
edge: false,
firefox: 45,
chrome: 49,
};
targets = {
chrome: MAX_VERSION,
firefox: MAX_VERSION,
};
expect(presetEnv.isPluginRequired(targets, plugin)).toBe(false);
targets = {
edge: "12",
};
expect(presetEnv.isPluginRequired(targets, plugin)).toBe(true);
});
it("returns false if plugin feature is implemented by lower than target", () => {
const plugin = {
chrome: 49,
};
const targets = {
chrome: MAX_VERSION,
};
expect(presetEnv.isPluginRequired(targets, plugin)).toBe(false);
});
it("returns false if plugin feature is implemented is equal to target", () => {
const plugin = {
chrome: 49,
};
const targets = {
chrome: "49.0.0",
};
expect(presetEnv.isPluginRequired(targets, plugin)).toBe(false);
});
it("returns true if plugin feature is implemented is greater than target", () => {
const plugin = {
chrome: 50,
};
const targets = {
chrome: "49.0.0",
};
expect(presetEnv.isPluginRequired(targets, plugin)).toBe(true);
});
it("returns when target is a decimal", () => {
const plugin = {
node: 6.9,
};
const targets = {
node: "6.10.0",
};
expect(presetEnv.isPluginRequired(targets, plugin)).toBe(false);
});
it("throws an error if target version is invalid", () => {
const plugin = {
chrome: 50,
};
const targets = {
chrome: 55,
};
expect(() => presetEnv.isPluginRequired(targets, plugin)).toThrow();
});
});