mirror of
https://github.com/hedgedoc/hedgedoc.git
synced 2024-11-22 09:46:30 -05:00
925bb85d2f
TypeORMs Equal constructor is buggy and should not be used. This introduces a ESLint rule that checks for that. Signed-off-by: David Mehren <git@herrmehren.de>
91 lines
2.5 KiB
JavaScript
91 lines
2.5 KiB
JavaScript
/* SPDX-FileCopyrightText: 2021 The HedgeDoc developers (see AUTHORS file)
|
|
*
|
|
* SPDX-License-Identifier: CC0-1.0
|
|
*/
|
|
module.exports = {
|
|
parser: '@typescript-eslint/parser',
|
|
parserOptions: {
|
|
project: 'tsconfig.json',
|
|
sourceType: 'module',
|
|
},
|
|
overrides: [
|
|
{
|
|
files: ['test/**', 'src/**/*.spec.ts'],
|
|
extends: ['plugin:jest/recommended'],
|
|
rules: {
|
|
'@typescript-eslint/unbound-method': 'off',
|
|
'@typescript-eslint/no-unsafe-assignment': 'off',
|
|
'@typescript-eslint/no-unsafe-argument': 'off',
|
|
'@typescript-eslint/no-unsafe-member-access': 'off',
|
|
'@typescript-eslint/require-await': 'off',
|
|
'@typescript-eslint/explicit-function-return-type': 'off',
|
|
'jest/unbound-method': 'error',
|
|
'jest/expect-expect': [
|
|
'error',
|
|
{
|
|
assertFunctionNames: [
|
|
'expect',
|
|
'request.**.expect',
|
|
'agent[0-9]?.**.expect',
|
|
],
|
|
},
|
|
],
|
|
'jest/no-standalone-expect': [
|
|
'error',
|
|
{
|
|
additionalTestBlockFunctions: ['afterEach', 'beforeAll'],
|
|
},
|
|
],
|
|
},
|
|
},
|
|
],
|
|
plugins: ['@typescript-eslint', 'jest', 'eslint-plugin-local-rules'],
|
|
extends: [
|
|
'eslint:recommended',
|
|
'plugin:@typescript-eslint/recommended',
|
|
'plugin:@typescript-eslint/recommended-requiring-type-checking',
|
|
'plugin:prettier/recommended',
|
|
],
|
|
root: true,
|
|
env: {
|
|
node: true,
|
|
jest: true,
|
|
},
|
|
rules: {
|
|
'prettier/prettier': ['error', require('./.prettierrc.json')],
|
|
'local-rules/correct-logger-context': 'error',
|
|
'local-rules/no-typeorm-equal': 'error',
|
|
'func-style': ['error', 'declaration'],
|
|
'@typescript-eslint/no-unused-vars': [
|
|
'warn',
|
|
{ argsIgnorePattern: '^_+$' },
|
|
],
|
|
'@typescript-eslint/explicit-function-return-type': 'warn',
|
|
'no-return-await': 'off',
|
|
'@typescript-eslint/return-await': ['error', 'always'],
|
|
'@typescript-eslint/naming-convention': [
|
|
'error',
|
|
{
|
|
selector: 'default',
|
|
format: ['camelCase'],
|
|
leadingUnderscore: 'allow',
|
|
trailingUnderscore: 'allow',
|
|
},
|
|
{
|
|
selector: 'enumMember',
|
|
format: ['UPPER_CASE'],
|
|
},
|
|
{
|
|
selector: 'variable',
|
|
format: ['camelCase', 'UPPER_CASE'],
|
|
leadingUnderscore: 'allow',
|
|
trailingUnderscore: 'allow',
|
|
},
|
|
|
|
{
|
|
selector: 'typeLike',
|
|
format: ['PascalCase'],
|
|
},
|
|
],
|
|
},
|
|
};
|