diff --git a/.github/workflows/CI.yml b/.github/workflows/CI.yml index 5c87676e..f7ce6603 100644 --- a/.github/workflows/CI.yml +++ b/.github/workflows/CI.yml @@ -31,7 +31,7 @@ jobs: strategy: matrix: os: [ubuntu-latest, windows-latest, macOS-latest] - eslint: [8.x, 7.x] + eslint: "8.x" node: [18.x, 20.x] include: # run on node lts(ubuntu-latest) @@ -44,6 +44,9 @@ jobs: - os: ubuntu-latest node: "19.x" eslint: "8.x" + - os: ubuntu-latest + node: "20.x" + eslint: "7.0.x" runs-on: ${{ matrix.os }} steps: - name: Checkout @@ -57,10 +60,7 @@ jobs: - name: Install Packages run: npm install - name: Install ESLint ${{ matrix.eslint }} - # We need to execute this command twice because of npm's bug. - # See also: https://npm.community/t/error-node-modules-staging-eslint-e7cf6846-node-modules-eslint run: | - npm install --no-save eslint@${{ matrix.eslint }} - npm install --no-save eslint@${{ matrix.eslint }} + npm install --no-save --force eslint@${{ matrix.eslint }} - name: Test run: npm run -s test:ci diff --git a/lib/configs/recommended-module.js b/lib/configs/recommended-module.js index 38a246dd..17b4cb53 100644 --- a/lib/configs/recommended-module.js +++ b/lib/configs/recommended-module.js @@ -10,6 +10,7 @@ module.exports.eslintrc = { es2021: true, }, globals: { + ...globals.es2021, __dirname: "off", __filename: "off", exports: "off", @@ -36,7 +37,6 @@ module.exports.flat = { sourceType: "module", globals: { ...globals.node, - ...globals.es2021, ...module.exports.eslintrc.globals, }, }, diff --git a/lib/configs/recommended-script.js b/lib/configs/recommended-script.js index 1ac3fd82..6a47c917 100644 --- a/lib/configs/recommended-script.js +++ b/lib/configs/recommended-script.js @@ -10,6 +10,7 @@ module.exports.eslintrc = { es2021: true, }, globals: { + ...globals.es2021, __dirname: "readonly", __filename: "readonly", exports: "writable", @@ -33,7 +34,6 @@ module.exports.flat = { sourceType: "commonjs", globals: { ...globals.node, - ...globals.es2021, ...module.exports.eslintrc.globals, }, }, diff --git a/lib/util/is-typescript.js b/lib/util/is-typescript.js index 19d23347..fb468d21 100644 --- a/lib/util/is-typescript.js +++ b/lib/util/is-typescript.js @@ -12,7 +12,10 @@ const typescriptExtensions = [".ts", ".tsx", ".cts", ".mts"] */ module.exports = function isTypescript(context) { const sourceFileExt = path.extname( - context.physicalFilename ?? context.getPhysicalFilename() + context.physicalFilename ?? + context.getPhysicalFilename?.() ?? + context.filename ?? + context.getFilename?.() ) return typescriptExtensions.includes(sourceFileExt) }