-
-
Notifications
You must be signed in to change notification settings - Fork 8.3k
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
[rb] Add backtrace locations and cause to errors #14170
Conversation
PR Reviewer Guide 🔍
|
PR Code Suggestions ✨
|
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 am not sure I follow the implementation and how it works. What we discussed in #13222 was to stop manipulating backtrace, create a nextra error instance and explicitly pass cause
for errors created from the remote server in
selenium/rb/lib/selenium/webdriver/remote/response.rb
Lines 41 to 43 in 5ce5555
ex = klass.new(message) | |
ex.set_backtrace(caller) | |
add_backtrace ex, backtrace |
Does this PR achieve the same in some other manner?
Oh Maybe I miss understood this, because I tried to call both backtrace_locations and case on the ex, and I noticed I couldn't so I implemented the methods that are being inherited from exception, so now when creating an error both the case and backtrace_locations are set automatically So for example this test: it 'has cause' do
driver.find_element(id: 'nonexistent')
rescue WebDriver::Error::NoSuchElementError => e
expect(e.cause).to be_a(WebDriver::Error::NoSuchElementError)
end returns cause as:
And this test : it 'has backtrace locations' do
driver.find_element(id: 'nonexistent')
rescue WebDriver::Error::NoSuchElementError => e
expect(e.backtrace_locations).not_to be_empty
end
Also these are the methods from the exception class that I'm overriding, that returns nil even if the backtrace is not set: # This method is not affected by Exception#set_backtrace().
def backtrace_locations; end
# Returns the previous exception ($!) at the time this exception was raised.
# This is useful for wrapping exceptions and retaining the original exception
# information.
def cause; end |
@p0deje I see what you are saying and I updated the implementation by removing the backtrace manipulation, and the test kept working, now I will update the cause, thank you! it's my first time working with exceptions so sorry for the confusion |
This looks like it's going in the right direction! Nice work. |
Thank you so much, hopefully based on my last comment regarding the backtrace and cause we know where to go from here :) and also thank you @p0deje for all the help |
@p0deje I looked into the failures, and they seems to be related to the action builder and Firefox on windows, I can try to use parallels on my mac to look into them, but I'm not sure if those tests should be fixed on this PR |
Don't worry about these, they are not related. |
You might want to split it if it's not an array of strings - you might want to test it. You can also see the output by using |
server_trace.split("\n") | ||
end | ||
|
||
ex.set_backtrace(backtrace + ex.backtrace) |
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.
This is probably the only line that should have been changed.
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 noticed during testing that when setting the backtrace to the exception a couple of things happened:
-
The cause was not set which was the issue
-
Depending on the type of ex.backtrace this ended up in a type error
-
As the example in the previous conversation and the testing done with the selenium grid, it did not seem to have the effect we expected in the formatting of the backtrace, I added examples and my reasoning here: [rb] Add backtrace locations and cause to errors #14170 (comment)
Let me know if this doesn't make much sense to you and I will gladly make a PR to update this :) thank you so much for the help!
Co-authored-by: aguspe <[email protected]>
User description
Description
The goal of this PR is to provide backtrace_locations and cause for users that need to consume it
Motivation and Context
A great detail explanation of the motivation is described here #13221 and also more information is provided in #13222
Types of changes
Checklist
PR Type
Enhancement, Tests
Description
WebDriverError
class by addingbacktrace_locations
method to fetch current thread's backtrace locations.WebDriverError
class by addingcause
method to fetch the error information.English
module for improved error handling.NoSuchElementError
.Changes walkthrough 📝
error.rb
Add backtrace locations and cause methods to WebDriverError class
rb/lib/selenium/webdriver/common/error.rb
backtrace_locations
method toWebDriverError
class to fetchcurrent thread's backtrace locations.
cause
method toWebDriverError
class to fetch the errorinformation.
English
module for error handling.error_spec.rb
Add tests for backtrace locations and cause in NoSuchElementError
rb/spec/integration/selenium/webdriver/error_spec.rb
NoSuchElementError
.NoSuchElementError
.