Fix: ESLint cache no longer stops autofix (fixes #10679) #10694
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
What is the purpose of this pull request? (put an "X" next to item)
[ ] Documentation update
[x] Bug fix (template)
[ ] New rule (template)
[ ] Changes an existing rule (template)
[ ] Add autofixing to a rule
[ ] Add a CLI option
[ ] Add something to the core
[ ] Other, please explain:
See issue #10679.
What changes did you make? (Give an overview)
Changed CLIEngine so that it will not always used cached lint results. Specifically, if the cached lint result had errors and autofix has been turned on for the current CLIEngine run, CLIEngine will ignore the cached results and process the file normally.
This fixes the following scenario:
--cache
flag and without--fix
flag--cache
flag and--fix
flagBefore this change, the cached, fixless results would be returned. With this change, the cache results are ignored and the file is processed and autofixed.
Is there anything you'd like reviewers to focus on?
I'm realizing as I type this that maybe this could be made smarter if we look at
fixableErrorCount
andfixableWarningCount
: if those are both 0 and the cache is still valid, then no autofix would need to be applied and we could use the cache results. Thoughts?Other than that, are there any other test cases I should add?