mirror of
https://github.com/rest-client/rest-client.git
synced 2022-11-09 13:49:40 -05:00
4971d1a6e1
This conversion is done by Transpec 3.2.2 with the following command: transpec * 317 conversions from: obj.should to: expect(obj).to * 160 conversions from: obj.stub(:message) to: allow(obj).to receive(:message) * 100 conversions from: obj.should_receive(:message) to: expect(obj).to receive(:message) * 30 conversions from: lambda { }.should to: expect { }.to * 22 conversions from: obj.should_not_receive(:message) to: expect(obj).not_to receive(:message) * 4 conversions from: obj.should_not to: expect(obj).not_to * 2 conversions from: == expected to: eq(expected) * 1 conversion from: expect(collection).to have_at_least(n).items to: expect(collection.size).to be >= n * 1 conversion from: obj.unstub(:message) to: allow(obj).to receive(:message).and_call_original For more details: https://github.com/yujinakayama/transpec#supported-conversions
108 lines
3.6 KiB
Ruby
108 lines
3.6 KiB
Ruby
require_relative '_lib'
|
|
|
|
describe RestClient::Exception do
|
|
it "returns a 'message' equal to the class name if the message is not set, because 'message' should not be nil" do
|
|
e = RestClient::Exception.new
|
|
expect(e.message).to eq "RestClient::Exception"
|
|
end
|
|
|
|
it "returns the 'message' that was set" do
|
|
e = RestClient::Exception.new
|
|
message = "An explicitly set message"
|
|
e.message = message
|
|
expect(e.message).to eq message
|
|
end
|
|
|
|
it "sets the exception message to ErrorMessage" do
|
|
expect(RestClient::ResourceNotFound.new.message).to eq 'Not Found'
|
|
end
|
|
|
|
it "contains exceptions in RestClient" do
|
|
expect(RestClient::Unauthorized.new).to be_a_kind_of(RestClient::Exception)
|
|
expect(RestClient::ServerBrokeConnection.new).to be_a_kind_of(RestClient::Exception)
|
|
end
|
|
end
|
|
|
|
describe RestClient::ServerBrokeConnection do
|
|
it "should have a default message of 'Server broke connection'" do
|
|
e = RestClient::ServerBrokeConnection.new
|
|
expect(e.message).to eq 'Server broke connection'
|
|
end
|
|
end
|
|
|
|
describe RestClient::RequestFailed do
|
|
before do
|
|
@response = double('HTTP Response', :code => '502')
|
|
end
|
|
|
|
it "stores the http response on the exception" do
|
|
response = "response"
|
|
begin
|
|
raise RestClient::RequestFailed, response
|
|
rescue RestClient::RequestFailed => e
|
|
expect(e.response).to eq response
|
|
end
|
|
end
|
|
|
|
it "http_code convenience method for fetching the code as an integer" do
|
|
expect(RestClient::RequestFailed.new(@response).http_code).to eq 502
|
|
end
|
|
|
|
it "http_body convenience method for fetching the body (decoding when necessary)" do
|
|
expect(RestClient::RequestFailed.new(@response).http_code).to eq 502
|
|
expect(RestClient::RequestFailed.new(@response).message).to eq 'HTTP status code 502'
|
|
end
|
|
|
|
it "shows the status code in the message" do
|
|
expect(RestClient::RequestFailed.new(@response).to_s).to match(/502/)
|
|
end
|
|
end
|
|
|
|
describe RestClient::ResourceNotFound do
|
|
it "also has the http response attached" do
|
|
response = "response"
|
|
begin
|
|
raise RestClient::ResourceNotFound, response
|
|
rescue RestClient::ResourceNotFound => e
|
|
expect(e.response).to eq response
|
|
end
|
|
end
|
|
|
|
it 'stores the body on the response of the exception' do
|
|
body = "body"
|
|
stub_request(:get, "www.example.com").to_return(:body => body, :status => 404)
|
|
begin
|
|
RestClient.get "www.example.com"
|
|
raise
|
|
rescue RestClient::ResourceNotFound => e
|
|
expect(e.response.body).to eq body
|
|
end
|
|
end
|
|
end
|
|
|
|
describe "backwards compatibility" do
|
|
it 'aliases RestClient::NotFound as ResourceNotFound' do
|
|
expect(RestClient::ResourceNotFound).to eq RestClient::NotFound
|
|
end
|
|
|
|
it 'aliases old names for HTTP 413, 414, 416' do
|
|
expect(RestClient::RequestEntityTooLarge).to eq RestClient::PayloadTooLarge
|
|
expect(RestClient::RequestURITooLong).to eq RestClient::URITooLong
|
|
expect(RestClient::RequestedRangeNotSatisfiable).to eq RestClient::RangeNotSatisfiable
|
|
end
|
|
|
|
it 'subclasses NotFound from RequestFailed, ExceptionWithResponse' do
|
|
expect(RestClient::NotFound).to be < RestClient::RequestFailed
|
|
expect(RestClient::NotFound).to be < RestClient::ExceptionWithResponse
|
|
end
|
|
|
|
it 'subclasses timeout from RestClient::RequestTimeout, RequestFailed, EWR' do
|
|
expect(RestClient::Exceptions::OpenTimeout).to be < RestClient::Exceptions::Timeout
|
|
expect(RestClient::Exceptions::ReadTimeout).to be < RestClient::Exceptions::Timeout
|
|
|
|
expect(RestClient::Exceptions::Timeout).to be < RestClient::RequestTimeout
|
|
expect(RestClient::Exceptions::Timeout).to be < RestClient::RequestFailed
|
|
expect(RestClient::Exceptions::Timeout).to be < RestClient::ExceptionWithResponse
|
|
end
|
|
|
|
end
|