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.
14d3e0ba30
...
0df1b867a4
@ -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"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
2
.github/workflows/lint.yml
vendored
2
.github/workflows/lint.yml
vendored
@ -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"
|
||||||
|
16
README.md
16
README.md
@ -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"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"extends": "./index.js",
|
"extends": "./index.js",
|
||||||
"parserOptions": {
|
"parserOptions": {
|
||||||
"projectService": true
|
"project": "./tsconfig.json"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
735
package-lock.json
generated
735
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
22
package.json
22
package.json
@ -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"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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),
|
|
||||||
)
|
|
||||||
})
|
})
|
||||||
|
Loading…
x
Reference in New Issue
Block a user