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

Fix fsi auto-loading of script file inside NuGet package. #18177

Merged
merged 7 commits into from
Jan 13, 2025

Conversation

teo-tsirpanis
Copy link
Contributor

Description

In the project file generated by FSharp.DependencyManager.NuGet, we've been referencing a PackageRoot item metadata that does not exist (line 136), causing inability to find the script file,

Fixes #18176 as validated locally by patching the FSharp.DependencyManager.Nuget.dll of a .NET SDK installation.

Checklist

  • Test cases added

  • Performance benchmarks added in case of performance changes

  • Release notes entry updated:

    Please make sure to add an entry with short succinct description of the change as well as link to this pull request to the respective release notes file, if applicable.

    Release notes files:

    • If anything under src/Compiler has been changed, please make sure to make an entry in docs/release-notes/.FSharp.Compiler.Service/<version>.md, where <version> is usually "highest" one, e.g. 42.8.200
    • If language feature was added (i.e. LanguageFeatures.fsi was changed), please add it to docs/release-notes/.Language/preview.md
    • If a change to FSharp.Core was made, please make sure to edit docs/release-notes/.FSharp.Core/<version>.md where version is "highest" one, e.g. 8.0.200.

    Information about the release notes entries format can be found in the documentation.
    Example:

    If you believe that release notes are not necessary for this PR, please add NO_RELEASE_NOTES label to the pull request.

@teo-tsirpanis teo-tsirpanis requested a review from a team as a code owner December 25, 2024 01:36
Copy link
Contributor

✅ No release notes required

Copy link
Member

@baronfel baronfel left a comment

Choose a reason for hiding this comment

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

This MSBuild-fu is good.

@T-Gro
Copy link
Member

T-Gro commented Jan 2, 2025

This is a good fix.

@teo-tsirpanis We do have some existing tests which use "nuget: .." dependency loading and validating some cases.

Do you have a package where the fixed behavior happens?
If yes, could this be added as a test?

Copy link
Member

@KevinRansom KevinRansom left a comment

Choose a reason for hiding this comment

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

looks good.

@KevinRansom
Copy link
Member

I will take a look at the test failures.

Copy link
Member

@KevinRansom KevinRansom left a comment

Choose a reason for hiding this comment

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

The test failures are signficant.

@teo-tsirpanis
Copy link
Contributor Author

@KevinRansom CI is now green. @T-Gro I will make use of this for the next version of the Farkle library, but it is not yet published. I don't know any other package that does this.

@T-Gro
Copy link
Member

T-Gro commented Jan 6, 2025

@KevinRansom CI is now green. @T-Gro I will make use of this for the next version of the Farkle library, but it is not yet published. I don't know any other package that does this.

It would be great if there was at least 1 integration test, even for a preview/beta version of anything, demonstrating this does not crash and indeed loads the script.

Or perharps if the test first created a local package, changed nuget to look at local folder instead of public feed, and loaded it?

@T-Gro T-Gro enabled auto-merge (squash) January 13, 2025 13:02
@T-Gro T-Gro merged commit c350a41 into dotnet:main Jan 13, 2025
33 checks passed
@teo-tsirpanis teo-tsirpanis deleted the fsi-nuget-script-fix branch January 14, 2025 15:31
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Archived in project
Development

Successfully merging this pull request may close these issues.

F# Interactive does not auto-load script inside NuGet package.
4 participants