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

Support setting workload set versions in global.json #33441

Merged

Conversation

dsplaisted
Copy link
Member

Implements part of dotnet/designs#294

We may want to add some end-to-end tests.

@dotnet-issue-labeler dotnet-issue-labeler bot added Area-Workloads untriaged Request triage from a team member labels Jun 20, 2023
@dsplaisted dsplaisted requested review from mhutch, a team, joeloff, MiYanni, nagilson and JL03-Yue June 20, 2023 20:29
@@ -43,7 +43,7 @@ internal class WorkloadUninstallCommand : WorkloadCommandBase
userProfileDir = userProfileDir ?? CliFolderPathCalculator.DotnetUserProfileFolderPath;
_sdkVersion = WorkloadOptionsExtensions.GetValidatedSdkVersion(parseResult.GetValueForOption(WorkloadUninstallCommandParser.VersionOption), version, dotnetPath, userProfileDir, true);

var workloadManifestProvider = new SdkDirectoryWorkloadManifestProvider(dotnetPath, _sdkVersion.ToString(), userProfileDir);
var workloadManifestProvider = new SdkDirectoryWorkloadManifestProvider(dotnetPath, _sdkVersion.ToString(), userProfileDir, SdkDirectoryWorkloadManifestProvider.GetGlobalJsonPath(Environment.CurrentDirectory));
Copy link
Member

Choose a reason for hiding this comment

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

Can this be moved into a base constructor? Feels like a lot of repetition.

Copy link
Member Author

Choose a reason for hiding this comment

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

@joeloff I've now refactored most of the resolver creation calls into a helper class. Try to look closely at whether the new code has the same behavior as the old code, I tried to be careful but it would be easy to make a mistake.

Copy link
Member

Choose a reason for hiding this comment

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

Taking a look...

Copy link
Member

Choose a reason for hiding this comment

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

Looks consistent to me. All the default behavior appears to be on the factory side.

{
"sdk": {
"version": "8.0.200",
"workloadversion": "8.0.201"
Copy link
Member

Choose a reason for hiding this comment

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

The global.json reader looks for workloadVersion. Shouldn't this through an exception because the property is all lower case?

Copy link
Member Author

Choose a reason for hiding this comment

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

It's doing case-insensitive comparison. I'm not sure whether global.json is supposed to be case-sensitive or not, but I followed the pattern from the workload manifest parsing code, which is case-insensitive.

Copy link
Member

Choose a reason for hiding this comment

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

I went over the global.json docs. It doesn't mention anything from what I could tell. I'm fine if it's case-insensitive

Copy link
Member

Choose a reason for hiding this comment

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

As I mentioned to you in chat, the runtime treats global.json properties as case sensitive. We should probably be consistent with the runtime.

Copy link
Member Author

Choose a reason for hiding this comment

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

It's hard for me to see a downside for being case insensitive. What would the would that break? On the other hand, if we are case sensitive, some people will probably get the casing wrong and be confused as to why the setting isn't taking effect.

Copy link
Member

@baronfel baronfel Jun 23, 2023

Choose a reason for hiding this comment

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

We can mitigate that somewhat by updating the Schemastore json schema for global.json (which lives here) with this field - this enables editors to flag this error.

DotnetPath = dotnetDir,
UserProfileDir = userProfileDir,
GlobalJsonStartDir = null,
VersionFromOption = parseResult.GetValueForOption(InstallingWorkloadCommandParser.VersionOption),
Copy link
Member

Choose a reason for hiding this comment

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

What kind of version is this versionFromOption? The SDK Version? Workload version? Workload set version? I would suggest making the variable name a little more specific

@dsplaisted dsplaisted merged commit 0e69533 into dotnet:release/7.0.4xx Jun 23, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Area-Workloads untriaged Request triage from a team member
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants