Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat!: Update shouldUseFlatConfig and CLI so flat config is default #17748

Merged
merged 13 commits into from
Dec 20, 2023

Conversation

nzakas
Copy link
Member

@nzakas nzakas commented Nov 10, 2023

Prerequisites checklist

What is the purpose of this pull request? (put an "X" next to an item)

[ ] Documentation update
[ ] Bug fix (template)
[ ] New rule (template)
[ ] Changes an existing rule (template)
[ ] Add autofix to a rule
[ ] Add a CLI option
[x] Add something to the core
[ ] Other, please explain:

What changes did you make? (Give an overview)

Updates shouldUseFlatConfig() to return true unless the ESLINT_USE_FLAT_CONFIG environment variable is "false".

Also ensures the CLI emits a warning when eslintrc is used.

Refs #13481

Is there anything you'd like reviewers to focus on?

@nzakas nzakas requested a review from a team as a code owner November 10, 2023 16:31
@eslint-github-bot eslint-github-bot bot added breaking This change is backwards-incompatible feature This change adds a new feature to ESLint labels Nov 10, 2023
Copy link

netlify bot commented Nov 10, 2023

Deploy Preview for docs-eslint canceled.

Name Link
🔨 Latest commit 4816e25
🔍 Latest deploy log https://app.netlify.com/sites/docs-eslint/deploys/658372e99d687400089a4ecc

@nzakas nzakas changed the title feat!: Update shouldUseFlatConfig so flat config is default feat!: Update shouldUseFlatConfig and CLI so flat config is default Nov 10, 2023
@nzakas
Copy link
Member Author

nzakas commented Nov 10, 2023

Tests are failing because rules are being called with syntax that isn't supported in those older Node.js versions. Need to investigate why that's happening.

@klebba
Copy link

klebba commented Nov 10, 2023

This PR timely! I was just about to open a related docs issue: https://eslint.org/docs/latest/use/configure/configuration-files-new#configuration-file-resolution

You can prevent this search for eslint.config.js by setting the ESLINT_USE_FLAT_CONFIG environment variable to true [...]

I think this should guide developers to set the variable to false

@nzakas
Copy link
Member Author

nzakas commented Nov 13, 2023

@klebba documentation updates are being tracked in #13481, and that is one of the documentation changes we'll be making.

@mdjermanovic mdjermanovic marked this pull request as draft November 15, 2023 11:21
Copy link

Hi everyone, it looks like we lost track of this pull request. Please review and see what the next steps are. This pull request will auto-close in 7 days without an update.

tests/bin/eslint.js Show resolved Hide resolved
tests/lib/cli.js Outdated Show resolved Hide resolved
tests/lib/cli.js Outdated Show resolved Hide resolved
tests/lib/cli.js Outdated Show resolved Hide resolved
tests/lib/cli.js Outdated
const configPath = getFixturePath(".eslintrc");
const filePath = getFixturePath("passing.js");

await cli.execute(`--config ${configPath} ${filePath}`, null, false);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

After these changes, npm test will be logging more than 100 deprecation warnings until we drop eslintrc in v10.

Can we avoid that?

allowFlatConfig = false is passed only from tests, so we could update the condition in lib/cli.js to avoid logging warnings while running tests:

-if (!usingFlatConfig) {
+if (allowFlatConfig && !usingFlatConfig) {
    process.emitWarning("You are using an eslintrc configuration file, which is deprecated and support will be removed in v10.0.0. Please migrate to an eslint.config.js file. See https://eslint.org/docs/latest/use/configure/migration-guide for details.", "ESLintRCWarning");
}

Then, we could update this test this way to make it work:

Suggested change
await cli.execute(`--config ${configPath} ${filePath}`, null, false);
const localCLI = proxyquire("../../lib/cli", {
"./eslint/flat-eslint": { shouldUseFlatConfig: () => Promise.resolve(false) }
});
await localCLI.execute(`--config ${configPath} ${filePath}`);

Or, perhaps even better, merge this test into the test for ESLINT_USE_FLAT_CONFIG=false as that's anyway the most realistic test:

it(`should not use it when ESLINT_USE_FLAT_CONFIG=false even if an eslint.config.js is present:${configType}`, async () => {
    process.env.ESLINT_USE_FLAT_CONFIG = "false";
    process.cwd = getFixturePath;

    const exitCode = await cli.execute(`--no-ignore --ext .js ${getFixturePath("files")}`, null, useFlatConfig);

    assert.strictEqual(exitCode, 0);

+   if (useFlatConfig) {
+       assert.strictEqual(processStub.callCount, 1, "calls `process.emitWarning()` once");
+       assert.strictEqual(processStub.getCall(0).args[1], "ESLintRCWarning");
+   }
});

That would leave npm test with zero eslintrc deprecation warnings (assuming #17797 will be merged; those tests pass allowFlatConfig = true but mistakenly still work in eslintc mode, so they're mistakenly logging deprecation warnings).

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good suggestion, I went with the second approach.

lib/cli.js Outdated Show resolved Hide resolved
Copy link

github-actions bot commented Dec 7, 2023

Hi everyone, it looks like we lost track of this pull request. Please review and see what the next steps are. This pull request will auto-close in 7 days without an update.

@github-actions github-actions bot added the Stale label Dec 7, 2023
@mdjermanovic mdjermanovic added cli Relates to ESLint's command-line interface core Relates to ESLint's core APIs and features accepted There is consensus among the team that this change meets the criteria for inclusion labels Dec 14, 2023
Copy link
Member

@mdjermanovic mdjermanovic left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM, thanks!

Copy link
Member

@mdjermanovic mdjermanovic left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This might fix merge conflicts.

tests/lib/cli.js Outdated Show resolved Hide resolved
@eslint-github-bot eslint-github-bot bot locked and limited conversation to collaborators Jun 18, 2024
@eslint-github-bot eslint-github-bot bot added the archived due to age This issue has been archived; please open a new issue for any further discussion label Jun 18, 2024
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
accepted There is consensus among the team that this change meets the criteria for inclusion archived due to age This issue has been archived; please open a new issue for any further discussion breaking This change is backwards-incompatible cli Relates to ESLint's command-line interface core Relates to ESLint's core APIs and features feature This change adds a new feature to ESLint
Projects
Archived in project
Development

Successfully merging this pull request may close these issues.

4 participants