mirror of
https://github.com/rest-client/rest-client.git
synced 2022-11-09 13:49:40 -05:00

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
130 lines
5.4 KiB
Ruby
130 lines
5.4 KiB
Ruby
require_relative '_lib'
|
|
|
|
describe RestClient::Resource do
|
|
before do
|
|
@resource = RestClient::Resource.new('http://some/resource', :user => 'jane', :password => 'mypass', :headers => {'X-Something' => '1'})
|
|
end
|
|
|
|
context "Resource delegation" do
|
|
it "GET" do
|
|
expect(RestClient::Request).to receive(:execute).with(:method => :get, :url => 'http://some/resource', :headers => {'X-Something' => '1'}, :user => 'jane', :password => 'mypass')
|
|
@resource.get
|
|
end
|
|
|
|
it "HEAD" do
|
|
expect(RestClient::Request).to receive(:execute).with(:method => :head, :url => 'http://some/resource', :headers => {'X-Something' => '1'}, :user => 'jane', :password => 'mypass')
|
|
@resource.head
|
|
end
|
|
|
|
it "POST" do
|
|
expect(RestClient::Request).to receive(:execute).with(:method => :post, :url => 'http://some/resource', :payload => 'abc', :headers => {:content_type => 'image/jpg', 'X-Something' => '1'}, :user => 'jane', :password => 'mypass')
|
|
@resource.post 'abc', :content_type => 'image/jpg'
|
|
end
|
|
|
|
it "PUT" do
|
|
expect(RestClient::Request).to receive(:execute).with(:method => :put, :url => 'http://some/resource', :payload => 'abc', :headers => {:content_type => 'image/jpg', 'X-Something' => '1'}, :user => 'jane', :password => 'mypass')
|
|
@resource.put 'abc', :content_type => 'image/jpg'
|
|
end
|
|
|
|
it "PATCH" do
|
|
expect(RestClient::Request).to receive(:execute).with(:method => :patch, :url => 'http://some/resource', :payload => 'abc', :headers => {:content_type => 'image/jpg', 'X-Something' => '1'}, :user => 'jane', :password => 'mypass')
|
|
@resource.patch 'abc', :content_type => 'image/jpg'
|
|
end
|
|
|
|
it "DELETE" do
|
|
expect(RestClient::Request).to receive(:execute).with(:method => :delete, :url => 'http://some/resource', :headers => {'X-Something' => '1'}, :user => 'jane', :password => 'mypass')
|
|
@resource.delete
|
|
end
|
|
|
|
it "overrides resource headers" do
|
|
expect(RestClient::Request).to receive(:execute).with(:method => :get, :url => 'http://some/resource', :headers => {'X-Something' => '2'}, :user => 'jane', :password => 'mypass')
|
|
@resource.get 'X-Something' => '2'
|
|
end
|
|
end
|
|
|
|
it "can instantiate with no user/password" do
|
|
@resource = RestClient::Resource.new('http://some/resource')
|
|
end
|
|
|
|
it "is backwards compatible with previous constructor" do
|
|
@resource = RestClient::Resource.new('http://some/resource', 'user', 'pass')
|
|
expect(@resource.user).to eq 'user'
|
|
expect(@resource.password).to eq 'pass'
|
|
end
|
|
|
|
it "concatenates urls, inserting a slash when it needs one" do
|
|
expect(@resource.concat_urls('http://example.com', 'resource')).to eq 'http://example.com/resource'
|
|
end
|
|
|
|
it "concatenates urls, using no slash if the first url ends with a slash" do
|
|
expect(@resource.concat_urls('http://example.com/', 'resource')).to eq 'http://example.com/resource'
|
|
end
|
|
|
|
it "concatenates urls, using no slash if the second url starts with a slash" do
|
|
expect(@resource.concat_urls('http://example.com', '/resource')).to eq 'http://example.com/resource'
|
|
end
|
|
|
|
it "concatenates even non-string urls, :posts + 1 => 'posts/1'" do
|
|
expect(@resource.concat_urls(:posts, 1)).to eq 'posts/1'
|
|
end
|
|
|
|
it "offers subresources via []" do
|
|
parent = RestClient::Resource.new('http://example.com')
|
|
expect(parent['posts'].url).to eq 'http://example.com/posts'
|
|
end
|
|
|
|
it "transports options to subresources" do
|
|
parent = RestClient::Resource.new('http://example.com', :user => 'user', :password => 'password')
|
|
expect(parent['posts'].user).to eq 'user'
|
|
expect(parent['posts'].password).to eq 'password'
|
|
end
|
|
|
|
it "passes a given block to subresources" do
|
|
block = proc {|r| r}
|
|
parent = RestClient::Resource.new('http://example.com', &block)
|
|
expect(parent['posts'].block).to eq block
|
|
end
|
|
|
|
it "the block should be overrideable" do
|
|
block1 = proc {|r| r}
|
|
block2 = proc {|r| }
|
|
parent = RestClient::Resource.new('http://example.com', &block1)
|
|
# parent['posts', &block2].block.should eq block2 # ruby 1.9 syntax
|
|
expect(parent.send(:[], 'posts', &block2).block).to eq block2
|
|
expect(parent.send(:[], 'posts', &block2).block).not_to eq block1
|
|
end
|
|
|
|
it "the block should be overrideable in ruby 1.9 syntax" do
|
|
block1 = proc {|r| r}
|
|
block2 = ->(r) {}
|
|
|
|
parent = RestClient::Resource.new('http://example.com', &block1)
|
|
expect(parent['posts', &block2].block).to eq block2
|
|
expect(parent['posts', &block2].block).not_to eq block1
|
|
end
|
|
|
|
it "prints its url with to_s" do
|
|
expect(RestClient::Resource.new('x').to_s).to eq 'x'
|
|
end
|
|
|
|
describe 'block' do
|
|
it 'can use block when creating the resource' do
|
|
stub_request(:get, 'www.example.com').to_return(:body => '', :status => 404)
|
|
resource = RestClient::Resource.new('www.example.com') { |response, request| 'foo' }
|
|
expect(resource.get).to eq 'foo'
|
|
end
|
|
|
|
it 'can use block when executing the resource' do
|
|
stub_request(:get, 'www.example.com').to_return(:body => '', :status => 404)
|
|
resource = RestClient::Resource.new('www.example.com')
|
|
expect(resource.get { |response, request| 'foo' }).to eq 'foo'
|
|
end
|
|
|
|
it 'execution block override resource block' do
|
|
stub_request(:get, 'www.example.com').to_return(:body => '', :status => 404)
|
|
resource = RestClient::Resource.new('www.example.com') { |response, request| 'foo' }
|
|
expect(resource.get { |response, request| 'bar' }).to eq 'bar'
|
|
end
|
|
|
|
end
|
|
end
|