-
Notifications
You must be signed in to change notification settings - Fork 115
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
Rescue StandardError when processing file #343
Rescue StandardError when processing file #343
Conversation
ee3d5fa
to
9eda05a
Compare
|
||
assert_match(/Packwerk is inspecting 13 files/, captured_output) | ||
assert_match(%r{components/timeline/app/models/bad_file.rb}, captured_output) | ||
assert_match(/Passed `nil` into T.must/, captured_output) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should we be making this code more fault tolerant? If this stack trace is within Packwerk, I imagine the end user should not be concerned with this and it is actually a bug.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
My main goal here is solving for unknowns by allowing packwerk to have more helpful debugging output. Perhaps instead this should say something to the effect of: "packwerk encountered an internal error. Please file an issue and include this error message and stacktrace."
What do you think?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Made this update
@@ -53,6 +53,9 @@ def call(relative_file) | |||
ProcessedFile.new(unresolved_references: unresolved_references) | |||
rescue Parsers::ParseError => e | |||
ProcessedFile.new(offenses: [e.result]) | |||
rescue StandardError => e |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What exactly is raising the error? The way this code is, if I write bad code in packwerk it is our users that will see the error, not us.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I've updated the message to make the intent clearer – that this is an internal error.
Now, instead of packwerk just blowing up with no information about what file is causing issues:
- It will list the file that is causing issues
- It will make it clear it's an internal issue
- It gives the user information about how to unblock
- It gives information helpful for debugging and issue reporting
|
||
RSpec.describe ActiveAdmin::Resource::BelongsTo do | ||
it "should have an owner" do | ||
expect(belongs_to.owner).to eq post_config |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not sure I get this example. It is failing because belongs_to
doesn't exist? Is packwerk executing the Ruby code instead of just parsing it?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
No – it's only parsing it. However, when it parses it, the AssociationInspector
calls association_name
which calls:
association_name_node = T.must(arguments[0])
In this case, arguments[0]
is nil
, which throws an error.
I've simplified the code to better capture the error.
I think we should fix this parsing issue, for sure, and then perhaps replace this test with a stub to reflect other unknowns. The main thing is I want consumers of packwerk to be able to report better errors.
2dd00f0
to
c3bba85
Compare
What are you trying to accomplish?
This should help #299.
While it doesn't solve the parsing error, it should improve debug reports by printing out which files are erroring with the error message.
Right now, when there is a
NodeHelpers::TypeError
OR a SorbetTypeError
(the test case I added reproduces this by creating a false positive AR association), Packwerk just crashes with a messy message:It's not clear what file is causing
packwerk
to break. It might be better to list out the files that have issues to exclude them, fix the issues, or better report the issue to packwerk maintainers.What approach did you choose and why?
I decided to rescue all of
StandardError
, because there are a number of possibly unexpected things that can cause packwerk parsing to break. In theory we could target more specific errors, but then we wouldn't be catching all possible errors and ambiguous errors continue to be reported ambiguously.What should reviewers focus on?
I wasn't able to reproduce the specific case in the issue – any thoughts on what is going on there?
Let me know if I should approach this a different way.
Type of Change
Checklist