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

Refactor error handling #8486

Merged
merged 5 commits into from
Nov 29, 2023
Merged

Conversation

deivid-rodriguez
Copy link
Contributor

It's not straightforward to know where new errors need to be added, so that they are properly passed back to the server.

Also, error handling is duplicated in dry-run.rb script and updater commands.

This PR tries to improve both of the above things.

@deivid-rodriguez deivid-rodriguez force-pushed the deivid-rodriguez/refactor-errors branch from eb1584d to 7fd4fc7 Compare November 29, 2023 17:27
Comment on lines +406 to 411
raise unless error_details

puts " => handled error whilst fetching dependencies: #{error_details.fetch(:"error-type")} " \
"#{error_details.fetch(:"error-detail")}"

[]
Copy link
Contributor

Choose a reason for hiding this comment

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

Is there any reason why we cannot raise when there are error details? Is that because we only throw when there are unknown exceptions?

Also, rather than puts, is there any reason not to use the Logger with error level?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I followed the same strategy already used for fetching files. Same for using puts, I just did what we were already doing in other error handling blocks.

Comment on lines +11 to +20
when Dependabot::ToolVersionNotSupported
{
"error-type": "tool_version_not_supported",
"error-detail": {
"tool-name": error.tool_name,
"detected-version": error.detected_version,
"supported-versions": error.supported_versions
}
}
when Dependabot::BranchNotFound
Copy link
Contributor

@yeikel yeikel Nov 29, 2023

Choose a reason for hiding this comment

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

I think that it would be ideal if each of these exceptions produced these via their constructors and exposed a dedicated method to fetch this parseable error message. If we had that, we would not need this mapping at all as it would be something like error.fetcher_error_details or similar

Copy link
Contributor Author

Choose a reason for hiding this comment

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

That's neat, I think it'd be a cool follow up to this PR!

@deivid-rodriguez deivid-rodriguez merged commit 9aac940 into main Nov 29, 2023
149 checks passed
@deivid-rodriguez deivid-rodriguez deleted the deivid-rodriguez/refactor-errors branch November 29, 2023 18:08
@deivid-rodriguez
Copy link
Contributor Author

@yeikel I'm merging this because I have an enhancement I want to ship based on this PR (#8326). But your ideas look great, we can implement them as follow ups 👍.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants