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

fix55816: exclude files with re-exports if excluded by preferences.autoImportFileExcludePatterns #58537

Merged
merged 7 commits into from
Jun 18, 2024

Conversation

iisaduan
Copy link
Member

@iisaduan iisaduan commented May 14, 2024

Fixes #55816

This failure happened when a file foo.ts that re-exports some variable T is ignored by "typescript.preferences.autoImportFileExcludePatterns". foo.ts was properly ignored by exportMap, but the autoImports still attempted to generate the import with foo.ts instead of the file that originally exported T, which lead to a failure.

This PR allows the moduleSymbol found by autoImports to not match the moduleSymbol found by exportInfoMap if the moduleSymbol found by autoimports is excluded. Furthermore, if the import info still cannot be resolved, the quickfix will still be available and we will generate the implementation code without the import statement.

@iisaduan iisaduan requested a review from andrewbranch May 14, 2024 19:11
@typescript-bot typescript-bot added the For Milestone Bug PRs that fix a bug with a specific milestone label May 14, 2024
@iisaduan iisaduan requested a review from navya9singh May 14, 2024 19:11
@fatcerberus
Copy link

Fixes #55816

Is that the right issue? It seems unrelated.

@iisaduan
Copy link
Member Author

iisaduan commented May 14, 2024

It is the correct issue, see the call stack here. The quick fix is not offered because getting autoimports fails when the file is excluded in preferences

if (skipAlias(info[0].symbol, getChecker(info[0].isFromPackageJson)) === symbol && info.some(i => i.moduleSymbol === moduleSymbol || i.symbol.parent === moduleSymbol)) {
if (
skipAlias(info[0].symbol, getChecker(info[0].isFromPackageJson)) === symbol
&& info.some(i => moduleSymbolExcluded || i.moduleSymbol === moduleSymbol || i.symbol.parent === moduleSymbol)
Copy link
Member

Choose a reason for hiding this comment

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

Plot twist: all existing tests pass if you delete this entire info.some(...) part of the condition. That might be all that’s needed to fix the bug?

Copy link
Member Author

@iisaduan iisaduan May 15, 2024

Choose a reason for hiding this comment

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

I tried that and wasn't sure if that was the best fix, since I tracked it back to here, where it looked like it was intentionally added. :D if your opinion is that the check was unnecessary, I'll change it back to just deleting this extra check

Copy link
Member Author

Choose a reason for hiding this comment

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

Actually, I remember something did break when I tried that-- tests/cases/fourslash/server/autoImportReExportFromAmbientModule.ts breaks with the info.some call removed. Since exporting ambient modules doesn't use filenames, I figured it would be alright to skip the check for ignored files

Copy link
Member

Choose a reason for hiding this comment

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

Suggested change
&& info.some(i => moduleSymbolExcluded || i.moduleSymbol === moduleSymbol || i.symbol.parent === moduleSymbol)
&& (moduleSymbolExcluded || info.some(i => i.moduleSymbol === moduleSymbol || i.symbol.parent === moduleSymbol))

if (skipAlias(info[0].symbol, getChecker(info[0].isFromPackageJson)) === symbol && info.some(i => i.moduleSymbol === moduleSymbol || i.symbol.parent === moduleSymbol)) {
if (
skipAlias(info[0].symbol, getChecker(info[0].isFromPackageJson)) === symbol
&& info.some(i => moduleSymbolExcluded || i.moduleSymbol === moduleSymbol || i.symbol.parent === moduleSymbol)
Copy link
Member

Choose a reason for hiding this comment

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

Suggested change
&& info.some(i => moduleSymbolExcluded || i.moduleSymbol === moduleSymbol || i.symbol.parent === moduleSymbol)
&& (moduleSymbolExcluded || info.some(i => i.moduleSymbol === moduleSymbol || i.symbol.parent === moduleSymbol))

src/services/codefixes/importFixes.ts Outdated Show resolved Hide resolved
@iisaduan
Copy link
Member Author

iisaduan commented Jun 6, 2024

@typescript-bot pack this

@typescript-bot
Copy link
Collaborator

typescript-bot commented Jun 6, 2024

Starting jobs; this comment will be updated as builds start and complete.

Command Status Results
pack this ✅ Started

verify.codeFix({
description: "Implement interface 'Parts'",
newFileContent:
`import { Event } from '../event/event';
Copy link
Member

Choose a reason for hiding this comment

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

Huh, this one with the broken import ended up working? What’s different from when we debugged it yesterday and this was crashing? Is there a test case that exercises if (!exportInfo) return;?

Copy link
Member Author

Choose a reason for hiding this comment

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

Yes, the broken import that we fixed was in thing,ts, and the file that the codefix was triggered in is in a different part of the folder tree than thing

Copy link
Member Author

Choose a reason for hiding this comment

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

I was trying to make cases with other file structures, since I was trying to test if the codefix would still crash in situations where the import map resolved to a different preferred file to generate the import from

@iisaduan
Copy link
Member Author

I added a debug statement to only exit quietly if preferences.autoImportFileExcludePatterns is provided, like @andrewbranch mentioned. It seems that otherwise, if the import was unresolved, autoimports goes through other functions to try to generate imports.

Co-authored-by: Andrew Branch <andrewbranch@users.noreply.github.com>
@iisaduan iisaduan merged commit f999951 into microsoft:main Jun 18, 2024
28 checks passed
@iisaduan iisaduan deleted the autoimport-excludePatternsFail branch June 18, 2024 21:03
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Author: Team For Milestone Bug PRs that fix a bug with a specific milestone
Projects
None yet
Development

Successfully merging this pull request may close these issues.

TS is offering no quick fix to implement interface
4 participants