Skip to content

Conversation

@Forgind
Copy link
Contributor

@Forgind Forgind commented Jun 22, 2024

Fixes #40297

This makes an error message a little more clear and ensures that the error actually fires when appropriate. Previously, if a user had successfully installed a workload set, then immediately tried to run, for example, dotnet workload update --version 8.0.422 where 8.0.422 doesn't exist, it would fail to find 8.0422 and instead find the previous version found and 'install' that instead, claiming success. Then it would butcher the install state file and fail. This ensures that it fails early enough to not do that and in a clearer way.

@ghost ghost added Area-Workloads untriaged Request triage from a team member labels Jun 22, 2024
}

// Delete the current advertising manifest because if we fail to find the right workload version, we want to fail.
var advertisingPackagePath = Path.Combine(_userProfileDir, "sdk-advertising", _sdkFeatureBand.ToString(), "microsoft.net.workloads");
Copy link
Member

Choose a reason for hiding this comment

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

nit: Can you pull microsoft.net.workloads out into a variable with a clear name so we can tell this is the workload set folder?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

dsplaisted creates that as a constant in #39991, so I'd rather wait for that to come in then move it somewhere more central and use it.

@marcpopMSFT marcpopMSFT requested a review from dsplaisted June 25, 2024 20:39
@marcpopMSFT
Copy link
Member

CC @dsplaisted as this may conflict or not be needed with his refactor so maybe wait until after that PR is in.

</data>
<data name="WorkloadVersionRequestedNotFound" xml:space="preserve">
<value>Workload version {0} not found.</value>
<value>Workload version {0} not found. Adding a feed that contains it to your NuGet.config may help.</value>
Copy link
Member

Choose a reason for hiding this comment

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

The message now uses WorkloadVersionFromGlobalJsonNotFound, and the text is:

Workload update failed: Workload version 8.0.300-preview.0.24217.2, which was specified in C:\SdkTesting\global.json, was not found. Run "dotnet workload restore" to install this workload version.

I don't think we need a message here about adding a feed, as in most cases the workload should be available on NuGet.org and they shouldn't need to mess with their feeds. If the dotnet workload restore command fails, that's when we could mention the feeds. It looks like that message could stand to be cleaned up, currently it looks something like this:

Unhandled exception: System.IO.FileNotFoundException: Workload version 8.0.300-preview.0.24217.2, which was specified in C:\SdkTesting\global.json, was not found. Run "dotnet workload restore" to install this workload version.
at Microsoft.NET.Sdk.WorkloadManifestReader.SdkDirectoryWorkloadManifestProvider.ThrowExceptionIfManifestsNotAvailable() in C:\git\dotnet-sdk\src\Resolvers\Microsoft.NET.Sdk.WorkloadManifestReader\SdkDirectoryWorkloadManifestProvider.cs:line 231
at Microsoft.NET.Sdk.WorkloadManifestReader.SdkDirectoryWorkloadManifestProvider.GetManifests() in C:\git\dotnet-sdk\src\Resolvers\Microsoft.NET.Sdk.WorkloadManifestReader\SdkDirectoryWorkloadManifestProvider.cs:line 269
at Microsoft.NET.Sdk.WorkloadManifestReader.WorkloadResolver.LoadManifestsFromProvider(IWorkloadManifestProvider manifestProvider) in C:\git\dotnet-sdk\src\Resolvers\Microsoft.NET.Sdk.WorkloadManifestReader\WorkloadResolver.cs:line 124
at Microsoft.NET.Sdk.WorkloadManifestReader.WorkloadResolver.InitializeManifests() in C:\git\dotnet-sdk\src\Resolvers\Microsoft.NET.Sdk.WorkloadManifestReader\WorkloadResolver.cs:line 91
at Microsoft.NET.Sdk.WorkloadManifestReader.WorkloadResolver.GetInstalledManifests() in C:\git\dotnet-sdk\src\Resolvers\Microsoft.NET.Sdk.WorkloadManifestReader\WorkloadResolver.cs:line 771
at Microsoft.DotNet.Workloads.Workload.Update.WorkloadUpdateCommand.Execute() in C:\git\dotnet-sdk\src\Cli\dotnet\commands\dotnet-workload\update\WorkloadUpdateCommand.cs:line 86
at Microsoft.DotNet.Cli.WorkloadUpdateCommandParser.<>c.b__6_0(ParseResult parseResult) in C:\git\dotnet-sdk\src\Cli\dotnet\commands\dotnet-workload\update\WorkloadUpdateCommandParser.cs:line 52
at System.CommandLine.Invocation.AnonymousCliAction.Invoke(ParseResult parseResult)
at System.CommandLine.Invocation.InvocationPipeline.Invoke(ParseResult parseResult)
at System.CommandLine.ParseResult.Invoke()
at Microsoft.DotNet.Cli.Program.ProcessArgs(String[] args, TimeSpan startupTime, ITelemetry telemetryClient) in C:\git\dotnet-sdk\src\Cli\dotnet\Program.cs:line 232

Comment on lines +126 to +131
// Delete the current advertising manifest because if we fail to find the right workload version, we want to fail.
var advertisingPackagePath = Path.Combine(_userProfileDir, "sdk-advertising", _sdkFeatureBand.ToString(), "microsoft.net.workloads");
if (Directory.Exists(advertisingPackagePath))
{
Directory.Delete(advertisingPackagePath, recursive: true);
}
Copy link
Member

Choose a reason for hiding this comment

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

I think after my refactoring, this is probably not necessary anymore. Can you verify or explain what the scenario was where this was broken?

@marcpopMSFT
Copy link
Member

@Forgind I think we should retarget to main along with the merge conflict resolution

@Forgind
Copy link
Contributor Author

Forgind commented Jul 18, 2024

I tested this out on main, and it seems like it's no longer an issue, or if it is, the repro steps are a bit different. I don't think this is relevant anymore. Closing.

@Forgind Forgind closed this Jul 18, 2024
@Forgind Forgind deleted the error-condition-fix branch July 18, 2024 20:22
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.

3 participants