1
1
mirror of https://github.com/theoludwig/eslint-config-conventions.git synced 2025-01-07 08:55:41 +01:00

Compare commits

..

No commits in common. "14d3e0ba309ce0b212f15ed5e19c3f520b4a4a4d" and "0df1b867a4e2412784d3ace1263169132ffbc55d" have entirely different histories.

7 changed files with 462 additions and 394 deletions

View File

@ -93,12 +93,25 @@
], ],
"no-array-constructor": "error", "no-array-constructor": "error",
"no-caller": "error", "no-caller": "error",
"no-confusing-arrow": "error",
"no-delete-var": "error", "no-delete-var": "error",
"no-empty": ["error", { "allowEmptyCatch": true }], "no-empty": ["error", { "allowEmptyCatch": true }],
"no-empty-static-block": "error", "no-empty-static-block": "error",
"no-eval": "error", "no-eval": "error",
"no-floating-decimal": "error",
"no-global-assign": "error", "no-global-assign": "error",
"no-implied-eval": "error", "no-implied-eval": "error",
"no-mixed-operators": [
"error",
{
"groups": [
["==", "!=", "===", "!==", ">", ">=", "<", "<="],
["&&", "||"],
["in", "instanceof"]
],
"allowSamePrecedence": true
}
],
"no-multi-str": "error", "no-multi-str": "error",
"no-new-func": "error", "no-new-func": "error",
"no-object-constructor": "error", "no-object-constructor": "error",
@ -135,11 +148,13 @@
"prefer-object-has-own": "error", "prefer-object-has-own": "error",
"prefer-promise-reject-errors": "error", "prefer-promise-reject-errors": "error",
"prefer-regex-literals": ["error", { "disallowRedundantWrapping": true }], "prefer-regex-literals": ["error", { "disallowRedundantWrapping": true }],
"quote-props": ["error", "as-needed"],
"radix": "error", "radix": "error",
"yoda": ["error", "never"], "yoda": ["error", "never"],
"curly": ["error", "all"], "curly": ["error", "all"],
"func-style": ["error", "expression"], "func-style": ["error", "expression"],
"prefer-arrow-callback": "error", "prefer-arrow-callback": "error",
"arrow-parens": ["error", "always"],
"arrow-body-style": ["error", "always"], "arrow-body-style": ["error", "always"],
"promise/param-names": "error", "promise/param-names": "error",
@ -173,7 +188,6 @@
"unicorn/require-array-join-separator": "error", "unicorn/require-array-join-separator": "error",
"unicorn/prefer-number-properties": "error", "unicorn/prefer-number-properties": "error",
"unicorn/prefer-modern-math-apis": "error", "unicorn/prefer-modern-math-apis": "error",
"unicorn/prefer-structured-clone": "error",
"unicorn/template-indent": "error" "unicorn/template-indent": "error"
}, },
"overrides": [ "overrides": [
@ -185,6 +199,8 @@
"no-undef": "off", "no-undef": "off",
"no-dupe-class-members": "off", "no-dupe-class-members": "off",
"@typescript-eslint/no-dupe-class-members": "error", "@typescript-eslint/no-dupe-class-members": "error",
"no-loss-of-precision": "off",
"@typescript-eslint/no-loss-of-precision": "error",
"no-unused-vars": "off", "no-unused-vars": "off",
"@typescript-eslint/no-unused-vars": [ "@typescript-eslint/no-unused-vars": [
"error", "error",
@ -215,7 +231,7 @@
{ "builtinGlobals": false } { "builtinGlobals": false }
], ],
"no-throw-literal": "off", "no-throw-literal": "off",
"@typescript-eslint/only-throw-error": "error", "@typescript-eslint/no-throw-literal": "error",
"no-unused-expressions": "off", "no-unused-expressions": "off",
"@typescript-eslint/no-unused-expressions": [ "@typescript-eslint/no-unused-expressions": [
"error", "error",
@ -227,15 +243,14 @@
], ],
"no-useless-constructor": "off", "no-useless-constructor": "off",
"@typescript-eslint/no-useless-constructor": "error", "@typescript-eslint/no-useless-constructor": "error",
"@typescript-eslint/no-unnecessary-template-expression": "error", "@typescript-eslint/no-useless-template-literals": "error",
"@typescript-eslint/adjacent-overload-signatures": "error", "@typescript-eslint/adjacent-overload-signatures": "error",
"@typescript-eslint/array-type": [ "@typescript-eslint/array-type": [
"error", "error",
{ "default": "array-simple" } { "default": "array-simple" }
], ],
"@typescript-eslint/no-unsafe-function-type": "error", "@typescript-eslint/ban-types": "error",
"@typescript-eslint/no-wrapper-object-types": "error",
"@typescript-eslint/consistent-type-definitions": [ "@typescript-eslint/consistent-type-definitions": [
"error", "error",
"interface" "interface"
@ -280,6 +295,7 @@
], ],
"@typescript-eslint/no-unnecessary-boolean-literal-compare": "error", "@typescript-eslint/no-unnecessary-boolean-literal-compare": "error",
"@typescript-eslint/no-unnecessary-type-assertion": "error", "@typescript-eslint/no-unnecessary-type-assertion": "error",
"@typescript-eslint/no-var-requires": "error",
"@typescript-eslint/no-require-imports": "error", "@typescript-eslint/no-require-imports": "error",
"@typescript-eslint/no-unsafe-unary-minus": "error", "@typescript-eslint/no-unsafe-unary-minus": "error",
"@typescript-eslint/no-array-delete": "error", "@typescript-eslint/no-array-delete": "error",
@ -297,7 +313,7 @@
], ],
"@typescript-eslint/prefer-readonly": "error", "@typescript-eslint/prefer-readonly": "error",
"@typescript-eslint/prefer-reduce-type-parameter": "error", "@typescript-eslint/prefer-reduce-type-parameter": "error",
"@typescript-eslint/prefer-return-this-type": "error", "@typescript-eslint/prefer-ts-expect-error": "error",
"@typescript-eslint/promise-function-async": "error", "@typescript-eslint/promise-function-async": "error",
"prefer-promise-reject-errors": "off", "prefer-promise-reject-errors": "off",
"@typescript-eslint/prefer-promise-reject-errors": "error", "@typescript-eslint/prefer-promise-reject-errors": "error",
@ -313,6 +329,7 @@
"error", "error",
{ "allowNumber": true } { "allowNumber": true }
], ],
"@typescript-eslint/return-await": ["error", "always"],
"@typescript-eslint/strict-boolean-expressions": [ "@typescript-eslint/strict-boolean-expressions": [
"error", "error",
{ {
@ -324,7 +341,8 @@
"allowNullableNumber": false, "allowNullableNumber": false,
"allowAny": false "allowAny": false
} }
] ],
"@typescript-eslint/type-annotation-spacing": "error"
} }
} }
] ]

View File

@ -31,4 +31,4 @@ jobs:
steps: steps:
- uses: "actions/checkout@v4.1.7" - uses: "actions/checkout@v4.1.7"
- uses: "wagoid/commitlint-github-action@v6.1.2" - uses: "wagoid/commitlint-github-action@v6.0.1"

View File

@ -35,9 +35,9 @@ More information about **formatting rules** vs **code-quality rules** can be fou
```sh ```sh
npm install --save-dev \ npm install --save-dev \
eslint@^8.57.0 \ eslint@^8.56.0 \
eslint-plugin-promise@^7.0.0 \ eslint-plugin-promise@^6.1.1 \
eslint-plugin-unicorn@^55.0.0 \ eslint-plugin-unicorn@^53.0.0 \
eslint-config-conventions@latest eslint-config-conventions@latest
``` ```
@ -55,9 +55,9 @@ If you want to use **TypeScript**, you also need to install:
```sh ```sh
npm install --save-dev \ npm install --save-dev \
"typescript@^5.6.2" \ "typescript@^5.3.3" \
"@typescript-eslint/eslint-plugin@^8.0.0" \ "@typescript-eslint/eslint-plugin@>=6.21.0" \
"@typescript-eslint/parser@^8.0.0" "@typescript-eslint/parser@>=6.21.0"
``` ```
Dependencies are: Dependencies are:
@ -72,7 +72,6 @@ Dependencies are:
```json ```json
{ {
"root": true,
"extends": ["conventions"], "extends": ["conventions"],
"plugins": ["promise", "unicorn"] "plugins": ["promise", "unicorn"]
} }
@ -82,7 +81,6 @@ Dependencies are:
```json ```json
{ {
"root": true,
"extends": ["conventions"], "extends": ["conventions"],
"plugins": ["promise", "unicorn"], "plugins": ["promise", "unicorn"],
"overrides": [ "overrides": [
@ -91,7 +89,7 @@ Dependencies are:
"parser": "@typescript-eslint/parser", "parser": "@typescript-eslint/parser",
"plugins": ["@typescript-eslint"], "plugins": ["@typescript-eslint"],
"parserOptions": { "parserOptions": {
"projectService": true "project": "./tsconfig.json"
} }
} }
] ]

View File

@ -1,6 +1,6 @@
{ {
"extends": "./index.js", "extends": "./index.js",
"parserOptions": { "parserOptions": {
"projectService": true "project": "./tsconfig.json"
} }
} }

735
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -43,23 +43,23 @@
"release": "semantic-release" "release": "semantic-release"
}, },
"peerDependencies": { "peerDependencies": {
"eslint": "^8.57.0", "eslint": "^8.56.0",
"eslint-plugin-promise": "^7.0.0", "eslint-plugin-promise": "^6.1.1 || ^7.0.0",
"eslint-plugin-unicorn": "^55.0.0" "eslint-plugin-unicorn": "^51.0.1 || ^52.0.0 || ^53.0.0 || ^54.0.0 || ^55.0.0"
}, },
"devDependencies": { "devDependencies": {
"@types/eslint": "8.56.12", "@types/eslint": "8.56.11",
"@types/node": "22.5.5", "@types/node": "20.14.12",
"@typescript-eslint/eslint-plugin": "8.6.0", "@typescript-eslint/eslint-plugin": "7.17.0",
"@typescript-eslint/parser": "8.6.0", "@typescript-eslint/parser": "7.17.0",
"editorconfig-checker": "5.1.8", "editorconfig-checker": "5.1.8",
"eslint": "8.57.1", "eslint": "8.57.0",
"eslint-plugin-promise": "7.1.0", "eslint-plugin-promise": "7.0.0",
"eslint-plugin-unicorn": "55.0.0", "eslint-plugin-unicorn": "55.0.0",
"markdownlint-cli2": "0.14.0", "markdownlint-cli2": "0.13.0",
"markdownlint-rule-relative-links": "3.0.0", "markdownlint-rule-relative-links": "3.0.0",
"prettier": "3.3.3", "prettier": "3.3.3",
"semantic-release": "23.1.1", "semantic-release": "23.1.1",
"typescript": "5.6.2" "typescript": "5.5.4"
} }
} }

View File

@ -16,31 +16,8 @@ test("ensure we validate correctly JavaScript files", async () => {
const [withErrors] = await eslint.lintFiles( const [withErrors] = await eslint.lintFiles(
"test/fixtures/javascript-with-errors.js", "test/fixtures/javascript-with-errors.js",
) )
assert.strictEqual(noErrors?.errorCount, 0, JSON.stringify(noErrors, null, 2)) assert.strictEqual(noErrors?.errorCount, 0)
assert.strictEqual( assert.strictEqual(withErrors?.errorCount, 3)
withErrors?.errorCount,
3,
JSON.stringify(withErrors, null, 2),
)
})
test("ensure we do not use deprecated rules", async () => {
const [javascriptLintResult] = await eslint.lintFiles(
"test/fixtures/javascript-no-errors.js",
)
const [typescriptLintResult] = await eslint.lintFiles(
"test/fixtures/typescript-no-errors.ts",
)
assert.strictEqual(
javascriptLintResult.usedDeprecatedRules.length,
0,
JSON.stringify(javascriptLintResult, null, 2),
)
assert.strictEqual(
typescriptLintResult.usedDeprecatedRules.length,
0,
JSON.stringify(typescriptLintResult, null, 2),
)
}) })
test("ensure we validate correctly TypeScript files", async () => { test("ensure we validate correctly TypeScript files", async () => {
@ -50,32 +27,20 @@ test("ensure we validate correctly TypeScript files", async () => {
const [withErrors] = await eslint.lintFiles( const [withErrors] = await eslint.lintFiles(
"test/fixtures/javascript-with-errors.js", "test/fixtures/javascript-with-errors.js",
) )
assert.strictEqual(noErrors?.errorCount, 0, JSON.stringify(noErrors, null, 2)) assert.strictEqual(noErrors?.errorCount, 0)
assert.strictEqual( assert.strictEqual(withErrors?.errorCount, 3)
withErrors?.errorCount,
3,
JSON.stringify(withErrors, null, 2),
)
}) })
test("ensure we allow top-level await", async () => { test("ensure we allow top-level await", async () => {
const [lintResult] = await eslint.lintFiles( const [lintResult] = await eslint.lintFiles(
"test/fixtures/top-level-await.mjs", "test/fixtures/top-level-await.mjs",
) )
assert.strictEqual( assert.strictEqual(lintResult?.errorCount, 0)
lintResult?.errorCount,
0,
JSON.stringify(lintResult, null, 2),
)
}) })
test("ensure we allow to ignore floating promise with void operator (@typescript-eslint/no-floating-promises)", async () => { test("ensure we allow to ignore floating promise with void operator (@typescript-eslint/no-floating-promises)", async () => {
const [lintResult] = await eslint.lintFiles( const [lintResult] = await eslint.lintFiles(
"test/fixtures/typescript-no-errors-ignore-promise.ts", "test/fixtures/typescript-no-errors-ignore-promise.ts",
) )
assert.strictEqual( assert.strictEqual(lintResult?.errorCount, 0)
lintResult?.errorCount,
0,
JSON.stringify(lintResult, null, 2),
)
}) })