From e62a64f05c0af52fbccddda0e992d11956db4d7b Mon Sep 17 00:00:00 2001 From: Gareth Jones Date: Fri, 16 Feb 2024 15:25:31 +1300 Subject: [PATCH] refactor: make config rules static rather than based off rule metadata --- src/index.ts | 50 ++++++++++++++++++++++++++++++-------------------- 1 file changed, 30 insertions(+), 20 deletions(-) diff --git a/src/index.ts b/src/index.ts index 2e51e605b..2396738e6 100644 --- a/src/index.ts +++ b/src/index.ts @@ -64,14 +64,34 @@ const rules = Object.fromEntries( .map(rule => [rule, importDefault(join(rulesDir, rule)) as RuleModule]), ); -const recommendedRules = Object.fromEntries( - Object.entries(rules) - .filter(([, rule]) => rule.meta.docs.recommended) - .map(([name, rule]) => [ - `jest/${name}`, - rule.meta.docs.recommended as TSESLint.Linter.RuleLevel, - ]), -); +const recommendedRules = { + 'jest/expect-expect': 'warn', + 'jest/no-alias-methods': 'error', + 'jest/no-commented-out-tests': 'warn', + 'jest/no-conditional-expect': 'error', + 'jest/no-deprecated-functions': 'error', + 'jest/no-disabled-tests': 'warn', + 'jest/no-done-callback': 'error', + 'jest/no-export': 'error', + 'jest/no-focused-tests': 'error', + 'jest/no-identical-title': 'error', + 'jest/no-interpolation-in-snapshots': 'error', + 'jest/no-jasmine-globals': 'error', + 'jest/no-mocks-import': 'error', + 'jest/no-standalone-expect': 'error', + 'jest/no-test-prefixes': 'error', + 'jest/valid-describe-callback': 'error', + 'jest/valid-expect': 'error', + 'jest/valid-expect-in-promise': 'error', + 'jest/valid-title': 'error', +} satisfies Record; + +const styleRules = { + 'jest/no-alias-methods': 'warn', + 'jest/prefer-to-be': 'error', + 'jest/prefer-to-contain': 'error', + 'jest/prefer-to-have-length': 'error', +} satisfies Record; const allRules = Object.fromEntries( Object.entries(rules) @@ -122,20 +142,10 @@ const createFlatConfig = ( plugin.configs = { all: createRCConfig(allRules), recommended: createRCConfig(recommendedRules), - style: createRCConfig({ - 'jest/no-alias-methods': 'warn', - 'jest/prefer-to-be': 'error', - 'jest/prefer-to-contain': 'error', - 'jest/prefer-to-have-length': 'error', - }), + style: createRCConfig(styleRules), 'flat/all': createFlatConfig(allRules), 'flat/recommended': createFlatConfig(recommendedRules), - 'flat/style': createFlatConfig({ - 'jest/no-alias-methods': 'warn', - 'jest/prefer-to-be': 'error', - 'jest/prefer-to-contain': 'error', - 'jest/prefer-to-have-length': 'error', - }), + 'flat/style': createFlatConfig(styleRules), 'flat/snapshots': { // @ts-expect-error this is introduced in flat config files: ['**/*.snap'],