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

input_munger error handling and refactor #2987

Merged
merged 5 commits into from
Sep 28, 2023

Conversation

Drblessing
Copy link
Contributor

@Drblessing Drblessing commented Jun 8, 2023

What was wrong?

The input_munger function had no friendly error output, as well as readability issues and verbose logic. This PR also makes it faster in my local testing. We can reduce the input_munger function down to a single line with:

return functools.reduce(lambda args, munger: munger(module, *args, **kwargs), self.mungers, args)

if desirable.

How was it fixed?

  • Refactor pipe the munged_inputs to a for loop.
  • Catch TypeErrors while mungers are munging input parameters.
  • Remove _munger_star_apply function.

Todo:

Cute Animal Picture

Put a link to a cute animal picture inside the parenthesis-->

@fselmo
Copy link
Collaborator

fselmo commented Aug 23, 2023

Hey @Drblessing, thanks for the PR. I love the refactor here. I'm not exactly sure what the TODO really was there for though. It seems like we would want to just let the munger raise its exception with the original message? I know you can trace back to it in the traceback but I'm not seeing the benefit in raising a new TypeError with a more broad message from the old TypeError that has a more clear message to begin with.

Also, TypeError isn't the only exception that can be raised from a munger. At the moment I see at least one instance of a ValueError. Then we have to keep catching those as well. I'd be happy with just this refactor and removing the TODO to be honest.

Curious on your thoughts here. I may very well be missing something.

@Drblessing
Copy link
Contributor Author

Drblessing commented Aug 25, 2023

Hey @fselmo thank you for the compliment. I agree with everything you stated.

Regarding the TODO, I initially thought wrapping the exception could provide a uniform error handling mechanism for all munger related errors. However, I do see your point about the original exception potentially having a more clear and informative message. Raising a broad TypeError might indeed obscure the specifics of the error and make it harder to debug, and miss other ValueError.

Given these insights, I'd be more than happy to roll back the exception handling change and focus solely on the refactor. Removing the TODO as you suggested also sounds like a clean approach.

Would the single-line solution work, assuming it passes the tests?

return functools.reduce(lambda args, munger: munger(module, *args, **kwargs), self.mungers, args)

Let me know if that works for you and I'll make the necessary updates!

@fselmo
Copy link
Collaborator

fselmo commented Aug 25, 2023

Let me know if that works for you and I'll make the necessary updates!

That sounds like a good plan to me 👍🏼. Thanks!

@fselmo fselmo merged commit 05142e9 into ethereum:main Sep 28, 2023
@fselmo
Copy link
Collaborator

fselmo commented Sep 28, 2023

Thanks again @Drblessing 👍🏼

@Drblessing Drblessing deleted the refactor-input-munger branch September 28, 2023 21:31
@Drblessing
Copy link
Contributor Author

Thank you @fselmo ! 😄

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.

2 participants