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

validate shape of packages.config and consolidate error handling #11303

Merged
merged 1 commit into from
Jan 15, 2025

Conversation

brettfo
Copy link
Contributor

@brettfo brettfo commented Jan 14, 2025

Validate the shape of packages.config when first opening the file

Fixes #11250.

During this I realized that we had way too many ways to represent errors and to convert them, so everything was consolidated into a single function JobErrorBase.ErrorFromException(). Everything else is just calling this helper and updating the tests.

@brettfo brettfo requested a review from a team as a code owner January 14, 2025 21:04
@github-actions github-actions bot added the L: dotnet:nuget NuGet packages via nuget or dotnet label Jan 14, 2025
var invalidPackageElements = Packages.Where(p => p.GetAttribute("id") is null || p.GetAttribute("version") is null).ToList();
if (invalidPackageElements.Any())
{
throw new UnparseableFileException("`package` element missing `id` or `version` attributes", path);
Copy link
Contributor Author

Choose a reason for hiding this comment

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

This was the fix for the linked issue.

@@ -14,4 +19,23 @@ public JobErrorBase(string type)

[JsonPropertyName("error-details")]
public Dictionary<string, object> Details { get; init; } = new();

public static JobErrorBase ErrorFromException(Exception ex, string jobId, string currentDirectory)
Copy link
Contributor Author

Choose a reason for hiding this comment

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

This is the consolidated error conversion.

@brettfo brettfo force-pushed the dev/brettfo/nuget-packages-config-parse branch 3 times, most recently from 1950ee9 to 8667468 Compare January 15, 2025 18:13
Copy link
Contributor

@ryanbrandenburg ryanbrandenburg 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, though I can't give approval ATM due to a permissions issue.

{
var (experimentsManager, _errorResult) = await ExperimentsManager.FromJobFileAsync(jobPath.FullName);
// since we have more than 8 arguments, we have to pull them out manually
Copy link
Contributor

Choose a reason for hiding this comment

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

That's annoying.

@brettfo brettfo force-pushed the dev/brettfo/nuget-packages-config-parse branch from 8667468 to 692d989 Compare January 15, 2025 19:29
@randhircs randhircs merged commit 47316b7 into main Jan 15, 2025
71 checks passed
@randhircs randhircs deleted the dev/brettfo/nuget-packages-config-parse branch January 15, 2025 20:23
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
L: dotnet:nuget NuGet packages via nuget or dotnet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

NuGet updater missing chance to return DependencyFileNotParseable
4 participants