From 041528ebfad3cd3f18d9c624ad52a21ca06f661d Mon Sep 17 00:00:00 2001 From: alonso Date: Sat, 5 Oct 2019 16:44:14 -0500 Subject: [PATCH] Added ordered-imports converter --- src/rules/converters.ts | 2 + src/rules/converters/ordered-imports.ts | 26 +++++++ .../converters/tests/ordered-imports.test.ts | 70 +++++++++++++++++++ 3 files changed, 98 insertions(+) create mode 100644 src/rules/converters/ordered-imports.ts create mode 100644 src/rules/converters/tests/ordered-imports.test.ts diff --git a/src/rules/converters.ts b/src/rules/converters.ts index 78b2b9e94..11b38357a 100644 --- a/src/rules/converters.ts +++ b/src/rules/converters.ts @@ -90,6 +90,7 @@ import { convertObjectLiteralKeyQuotes } from "./converters/object-literal-key-q import { convertObjectLiteralShorthand } from "./converters/object-literal-shorthand"; import { convertOneVariablePerDeclaration } from "./converters/one-variable-per-declaration"; import { convertOnlyArrowFunctions } from "./converters/only-arrow-functions"; +import { convertOrderedImports } from "./converters/ordered-imports"; import { convertPreferConst } from "./converters/prefer-const"; import { convertPreferForOf } from "./converters/prefer-for-of"; import { convertPreferFunctionOverMethod } from "./converters/prefer-function-over-method"; @@ -207,6 +208,7 @@ export const converters = new Map([ ["object-literal-shorthand", convertObjectLiteralShorthand], ["one-variable-per-declaration", convertOneVariablePerDeclaration], ["only-arrow-functions", convertOnlyArrowFunctions], + ["ordered-imports", convertOrderedImports], ["prefer-const", convertPreferConst], ["prefer-for-of", convertPreferForOf], ["prefer-function-over-method", convertPreferFunctionOverMethod], diff --git a/src/rules/converters/ordered-imports.ts b/src/rules/converters/ordered-imports.ts new file mode 100644 index 000000000..9db2fd9a9 --- /dev/null +++ b/src/rules/converters/ordered-imports.ts @@ -0,0 +1,26 @@ +import { RuleConverter } from "../converter"; + +export const convertOrderedImports: RuleConverter = tslintRule => { + const notices: string[] = []; + const unsupportedtslintOptions = [ + "import-sources-order", + "named-imports-order", + "module-source-path", + ]; + + unsupportedtslintOptions.forEach(option => { + if (tslintRule.ruleArguments.includes(option)) { + notices.push(`Option "${option}" is not supported by ESLint.`); + } + }); + + return { + rules: [ + { + ...(notices.length > 0 && { notices }), + ruleName: "import/order", + }, + ], + plugins: ["import"], + }; +}; diff --git a/src/rules/converters/tests/ordered-imports.test.ts b/src/rules/converters/tests/ordered-imports.test.ts new file mode 100644 index 000000000..38957cbf3 --- /dev/null +++ b/src/rules/converters/tests/ordered-imports.test.ts @@ -0,0 +1,70 @@ +import { convertOrderedImports } from "../ordered-imports"; + +describe(convertOrderedImports, () => { + test("conversion without arguments", () => { + const result = convertOrderedImports({ + ruleArguments: [], + }); + + expect(result).toEqual({ + rules: [ + { + ruleName: "import/order", + }, + ], + plugins: ["import"], + }); + }); + + test("conversion with allow-declarations argument", () => { + const result = convertOrderedImports({ + ruleArguments: ["import-sources-order"], + }); + + expect(result).toEqual({ + rules: [ + { + notices: ['Option "import-sources-order" is not supported by ESLint.'], + ruleName: "import/order", + }, + ], + plugins: ["import"], + }); + }); + + test("conversion with allow-declarations argument", () => { + const result = convertOrderedImports({ + ruleArguments: ["named-imports-order"], + }); + + expect(result).toEqual({ + rules: [ + { + notices: ['Option "named-imports-order" is not supported by ESLint.'], + ruleName: "import/order", + }, + ], + plugins: ["import"], + }); + }); + + test("conversion with unsupported arguments", () => { + const result = convertOrderedImports({ + ruleArguments: ["import-sources-order", "named-imports-order", "module-source-path"], + }); + + expect(result).toEqual({ + rules: [ + { + notices: [ + 'Option "import-sources-order" is not supported by ESLint.', + 'Option "named-imports-order" is not supported by ESLint.', + 'Option "module-source-path" is not supported by ESLint.', + ], + ruleName: "import/order", + }, + ], + plugins: ["import"], + }); + }); +});