Define object in case of Net::HTTPBadRequest #149
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
First, some background.
I have a Rails app which has a
config/initializers/twilio.rb
:I can successfully use this code to send an SMS:
That works nicely.
Today, I wanted to validate phone numbers and I saw that Twilio now has a lookups API for that. There's no documentation in the README for this gem wrt to lookups, so I had to piece together how to use this. I guessed this (running in a
rails console
):When this request is made, Twilio returns a "400 Bad Request" error. Unfortunately for the Twilio gem, the response body is empty, and so
object
isn't set at all.Net::HTTPBadRequest
is indeed a kind ofNet::HTTPClientError
, which you can check with:Alternatively, you could look through the docs for a couple of minutes. Back on track: because
object
isn't set, the code inside this finalif
isn't able toraise
the exception becauseobject
is nil. Instead what happens, is this:So either:
Please advise.