From 9bff4fbca354089f79ed8b7e5bcd2b22e0a57801 Mon Sep 17 00:00:00 2001 From: Nick Schonning Date: Fri, 6 Dec 2024 12:11:42 -0500 Subject: [PATCH] Hoist ESLint config in streaming --- .eslintrc.js | 35 +++++++++++++++++++++++++++++++++ streaming/.eslintrc.cjs | 43 ----------------------------------------- streaming/package.json | 1 - yarn.lock | 1 - 4 files changed, 35 insertions(+), 45 deletions(-) delete mode 100644 streaming/.eslintrc.cjs diff --git a/.eslintrc.js b/.eslintrc.js index 93ff1d7b59..b044bc58f4 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -362,6 +362,41 @@ module.exports = defineConfig({ env: { jest: true, }, + }, + { + files: ['streaming/*.js'], + env: { + browser: false, + }, + parserOptions: { + project: true, + tsconfigRootDir: 'streaming/', + ecmaFeatures: { + jsx: false, + }, + ecmaVersion: 2021, + }, + rules: { + // In the streaming server we need to delete some variables to ensure + // garbage collection takes place on the values referenced by those objects; + // The alternative is to declare the variable as nullable, but then we need + // to assert it's in existence before every use, which becomes much harder + // to maintain. + 'no-delete-var': 'off', + + // This overrides the base configuration for this rule to pick up + // dependencies for the streaming server from the correct package.json file. + 'import/no-extraneous-dependencies': [ + 'error', + { + optionalDependencies: false, + peerDependencies: false, + includeTypes: true, + packageDir: 'streaming', + }, + ], + 'import/extensions': ['error', 'always'], + }, } ], }); diff --git a/streaming/.eslintrc.cjs b/streaming/.eslintrc.cjs deleted file mode 100644 index e25cff7df0..0000000000 --- a/streaming/.eslintrc.cjs +++ /dev/null @@ -1,43 +0,0 @@ -/* eslint-disable import/no-commonjs */ - -// @ts-check - -// @ts-ignore - This needs to be a CJS file (eslint does not yet support ESM configs), and TS is complaining we use require -const { defineConfig } = require('eslint-define-config'); - -module.exports = defineConfig({ - extends: ['../.eslintrc.js'], - env: { - browser: false, - }, - parserOptions: { - project: true, - tsconfigRootDir: __dirname, - ecmaFeatures: { - jsx: false, - }, - ecmaVersion: 2021, - }, - rules: { - // In the streaming server we need to delete some variables to ensure - // garbage collection takes place on the values referenced by those objects; - // The alternative is to declare the variable as nullable, but then we need - // to assert it's in existence before every use, which becomes much harder - // to maintain. - 'no-delete-var': 'off', - - // This overrides the base configuration for this rule to pick up - // dependencies for the streaming server from the correct package.json file. - 'import/no-extraneous-dependencies': [ - 'error', - { - devDependencies: ['streaming/.eslintrc.cjs'], - optionalDependencies: false, - peerDependencies: false, - includeTypes: true, - packageDir: __dirname, - }, - ], - 'import/extensions': ['error', 'always'], - }, -}); diff --git a/streaming/package.json b/streaming/package.json index e40d262378..775ee12e69 100644 --- a/streaming/package.json +++ b/streaming/package.json @@ -36,7 +36,6 @@ "@types/pg": "^8.6.6", "@types/uuid": "^10.0.0", "@types/ws": "^8.5.9", - "eslint-define-config": "^2.0.0", "pino-pretty": "^11.0.0", "typescript": "^5.0.4" }, diff --git a/yarn.lock b/yarn.lock index f1ba5a5379..b007b73322 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2996,7 +2996,6 @@ __metadata: bufferutil: "npm:^4.0.7" cors: "npm:^2.8.5" dotenv: "npm:^16.0.3" - eslint-define-config: "npm:^2.0.0" express: "npm:^4.18.2" ioredis: "npm:^5.3.2" jsdom: "npm:^25.0.0"