class HTTPX::ErrorResponse

  1. lib/httpx/response.rb
Superclass: Object

Wraps an error which has happened while processing an HTTP Request. It has partial public API parity with HTTPX::Response, so users should rely on it to infer whether the returned response is one or the other.

response = HTTPX.get("https://some-domain/path") #=> response is HTTPX::Response or HTTPX::ErrorResponse
response.raise_for_status #=> raises if it wraps an error

Methods

Public Class

  1. new

Public Instance

  1. <<
  2. close
  3. error
  4. finished?
  5. raise_for_status
  6. request
  7. response
  8. to_s

Included modules

  1. Loggable

Attributes

error [R]

the wrapped exception.

request [R]

the corresponding HTTPX::Request instance.

response [R]

the HTTPX::Response instance, when there is one (i.e. error happens fetching the response).

Public Class methods

new(request, error)
[show source]
    # File lib/httpx/response.rb
252 def initialize(request, error)
253   @request = request
254   @response = request.response if request.response.is_a?(Response)
255   @error = error
256   @options = request.options
257   log_exception(@error)
258 end

Public Instance methods

<<(data)

buffers lost chunks to error response

[show source]
    # File lib/httpx/response.rb
281 def <<(data)
282   @response << data
283 end
close()

closes the error resources.

[show source]
    # File lib/httpx/response.rb
266 def close
267   @response.close if @response && @response.respond_to?(:close)
268 end
finished?()

always true for error responses.

[show source]
    # File lib/httpx/response.rb
271 def finished?
272   true
273 end
raise_for_status()

raises the wrapped exception.

[show source]
    # File lib/httpx/response.rb
276 def raise_for_status
277   raise @error
278 end
to_s()

returns the exception full message.

[show source]
    # File lib/httpx/response.rb
261 def to_s
262   @error.full_message(highlight: false)
263 end