From 85b03c2bc48bbe2e9527fb00a55fc1de55fc1909 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Miroslav=20Jona=C5=A1?= Date: Thu, 7 Sep 2023 13:17:22 +0200 Subject: [PATCH] fix(linter): ensure config manipulations are run only if config is supported (#19035) (cherry picked from commit aa223621f72f0c1cfc4ea494cc1f58154b8acbbb) --- packages/js/src/generators/library/library.ts | 21 +++++++++++-------- .../src/generators/utils/eslint-file.ts | 9 ++++---- .../update-16-8-0-add-ignored-files.spec.ts | 1 + .../update-16-8-0-add-ignored-files.ts | 8 ++++++- 4 files changed, 25 insertions(+), 14 deletions(-) diff --git a/packages/js/src/generators/library/library.ts b/packages/js/src/generators/library/library.ts index 652ae846d5323..47560e74b2015 100644 --- a/packages/js/src/generators/library/library.ts +++ b/packages/js/src/generators/library/library.ts @@ -267,18 +267,21 @@ export async function addLint( // nx-ignore-next-line } = require('@nx/linter/src/generators/utils/eslint-file'); + // if config is not supported, we don't need to do anything + if (!isEslintConfigSupported(tree)) { + return task; + } + // Also update the root ESLint config. The lintProjectGenerator will not generate it for root projects. // But we need to set the package.json checks. if (options.rootProject) { - if (isEslintConfigSupported(tree)) { - addOverrideToLintConfig(tree, '', { - files: ['*.json'], - parser: 'jsonc-eslint-parser', - rules: { - '@nx/dependency-checks': 'error', - }, - }); - } + addOverrideToLintConfig(tree, '', { + files: ['*.json'], + parser: 'jsonc-eslint-parser', + rules: { + '@nx/dependency-checks': 'error', + }, + }); } // If project lints package.json with @nx/dependency-checks, then add ignore files for diff --git a/packages/linter/src/generators/utils/eslint-file.ts b/packages/linter/src/generators/utils/eslint-file.ts index 084e69a9322d9..d2358406598d8 100644 --- a/packages/linter/src/generators/utils/eslint-file.ts +++ b/packages/linter/src/generators/utils/eslint-file.ts @@ -55,7 +55,7 @@ export function findEslintFile(tree: Tree, projectRoot = ''): string | null { export function isEslintConfigSupported(tree: Tree, projectRoot = ''): boolean { const eslintFile = findEslintFile(tree, projectRoot); if (!eslintFile) { - return; + return false; } return eslintFile.endsWith('.json') || eslintFile.endsWith('.config.js'); } @@ -233,6 +233,9 @@ export function lintConfigHasOverride( lookup: (override: Linter.ConfigOverride) => boolean, checkBaseConfig = false ): boolean { + if (!isEslintConfigSupported(tree, root)) { + return false; + } const isBase = checkBaseConfig && findEslintFile(tree, root).includes('.base'); if (useFlatConfig(tree)) { @@ -248,9 +251,7 @@ export function lintConfigHasOverride( isBase ? baseEsLintConfigFile : '.eslintrc.json' ); - return tree.exists(fileName) - ? readJson(tree, fileName).overrides?.some(lookup) || false - : false; + return readJson(tree, fileName).overrides?.some(lookup) || false; } } diff --git a/packages/linter/src/migrations/update-16-8-0-add-ignored-files/update-16-8-0-add-ignored-files.spec.ts b/packages/linter/src/migrations/update-16-8-0-add-ignored-files/update-16-8-0-add-ignored-files.spec.ts index 0bc8b28b375cc..48e1252014f21 100644 --- a/packages/linter/src/migrations/update-16-8-0-add-ignored-files/update-16-8-0-add-ignored-files.spec.ts +++ b/packages/linter/src/migrations/update-16-8-0-add-ignored-files/update-16-8-0-add-ignored-files.spec.ts @@ -8,6 +8,7 @@ describe('update-16-8-0-add-ignored-files migration', () => { beforeEach(() => { tree = createTreeWithEmptyWorkspace(); + tree.write('.eslintrc.json', '{}'); }); it('should run successfully when eslint config is not present', async () => { diff --git a/packages/linter/src/migrations/update-16-8-0-add-ignored-files/update-16-8-0-add-ignored-files.ts b/packages/linter/src/migrations/update-16-8-0-add-ignored-files/update-16-8-0-add-ignored-files.ts index 90fe479ebedec..a070ef746cff4 100644 --- a/packages/linter/src/migrations/update-16-8-0-add-ignored-files/update-16-8-0-add-ignored-files.ts +++ b/packages/linter/src/migrations/update-16-8-0-add-ignored-files/update-16-8-0-add-ignored-files.ts @@ -2,6 +2,7 @@ import { getProjects, Tree } from '@nx/devkit'; import { forEachExecutorOptions } from '@nx/devkit/src/generators/executor-options-utils'; import { findEslintFile, + isEslintConfigSupported, lintConfigHasOverride, updateOverrideInLintConfig, } from '../../generators/utils/eslint-file'; @@ -16,7 +17,12 @@ export default function update(tree: Tree) { const addIgnorePattern = (ignorePattern: string) => (_options: unknown, projectName: string) => { const project = projects.get(projectName); - if (!findEslintFile(tree, project.root)) return; + if ( + !findEslintFile(tree, project.root) || + !isEslintConfigSupported(tree) + ) { + return; + } if ( lintConfigHasOverride( tree,