mirror of
https://github.com/jnunemaker/httparty
synced 2023-03-27 23:23:07 -04:00
Adding option to throw exceptions on some HTTP statuses
This commit is contained in:
parent
880a2d575c
commit
fc02683c8f
4 changed files with 61 additions and 0 deletions
|
@ -72,6 +72,16 @@ module HTTParty
|
||||||
default_options[:log_format] = format
|
default_options[:log_format] = format
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Raises HTTParty::ResponseError if response's code matches this statuses
|
||||||
|
#
|
||||||
|
# class Foo
|
||||||
|
# include HTTParty
|
||||||
|
# raise_on [404, 500]
|
||||||
|
# end
|
||||||
|
def raise_on(codes = [])
|
||||||
|
default_options[:raise_on] = *codes
|
||||||
|
end
|
||||||
|
|
||||||
# Allows setting http proxy information to be used
|
# Allows setting http proxy information to be used
|
||||||
#
|
#
|
||||||
# class Foo
|
# class Foo
|
||||||
|
|
|
@ -17,6 +17,8 @@ module HTTParty
|
||||||
logger = ::HTTParty::Logger.build(request.options[:logger], request.options[:log_level], request.options[:log_format])
|
logger = ::HTTParty::Logger.build(request.options[:logger], request.options[:log_level], request.options[:log_format])
|
||||||
logger.format(request, self)
|
logger.format(request, self)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
throw_exception
|
||||||
end
|
end
|
||||||
|
|
||||||
def parsed_response
|
def parsed_response
|
||||||
|
@ -77,6 +79,12 @@ module HTTParty
|
||||||
super
|
super
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def throw_exception
|
||||||
|
if @request.options[:raise_on] && @request.options[:raise_on].include?(code)
|
||||||
|
::Kernel.raise ::HTTParty::ResponseError.new(@response), "Code #{code} - #{body}"
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -43,6 +43,33 @@ RSpec.describe HTTParty::Response do
|
||||||
it "should set code as a Fixnum" do
|
it "should set code as a Fixnum" do
|
||||||
expect(@response.code).to be_an_instance_of(Fixnum)
|
expect(@response.code).to be_an_instance_of(Fixnum)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context 'when raise_on is supplied' do
|
||||||
|
let(:request) { HTTParty::Request.new(Net::HTTP::Get, '/', raise_on: [404]) }
|
||||||
|
|
||||||
|
context "and response's status code is in range" do
|
||||||
|
let(:body) { 'Not Found' }
|
||||||
|
let(:response) { Net::HTTPNotFound.new('1.1', 404, body) }
|
||||||
|
|
||||||
|
before do
|
||||||
|
allow(response).to receive(:body).and_return(body)
|
||||||
|
end
|
||||||
|
|
||||||
|
subject { described_class.new(request, response, @parsed_response) }
|
||||||
|
|
||||||
|
it 'throws exception' do
|
||||||
|
expect{ subject }.to raise_error(HTTParty::ResponseError, "Code 404 - #{body}")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context "and response's status code is not in range" do
|
||||||
|
subject { described_class.new(request, @response_object, @parsed_response) }
|
||||||
|
|
||||||
|
it 'does not throw exception' do
|
||||||
|
expect{ subject }.not_to raise_error(HTTParty::ResponseError)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
it "returns response headers" do
|
it "returns response headers" do
|
||||||
|
|
|
@ -525,6 +525,22 @@ RSpec.describe HTTParty do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe ".raise_on" do
|
||||||
|
context 'when parameters is an array' do
|
||||||
|
it 'sets raise_on option' do
|
||||||
|
@klass.raise_on [500, 404]
|
||||||
|
expect(@klass.default_options[:raise_on]).to contain_exactly(404, 500)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'when parameters is a fixnum' do
|
||||||
|
it 'sets raise_on option' do
|
||||||
|
@klass.raise_on 404
|
||||||
|
expect(@klass.default_options[:raise_on]).to contain_exactly(404)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
describe "with explicit override of automatic redirect handling" do
|
describe "with explicit override of automatic redirect handling" do
|
||||||
before do
|
before do
|
||||||
@request = HTTParty::Request.new(Net::HTTP::Get, 'http://api.foo.com/v1', format: :xml, no_follow: true)
|
@request = HTTParty::Request.new(Net::HTTP::Get, 'http://api.foo.com/v1', format: :xml, no_follow: true)
|
||||||
|
|
Loading…
Reference in a new issue