diff options
author | Mikel Lindsaar <raasdnil@gmail.com> | 2010-08-30 15:35:36 +1000 |
---|---|---|
committer | Jeremy Kemper <jeremy@bitsweat.net> | 2010-08-29 22:54:19 -0700 |
commit | 58d0e2c23c0c5578f23a4f4c639db5c0009b80c2 (patch) | |
tree | a8b5477b66ffa9afb51f8a315bd2d1e8656202ac /activeresource/test | |
parent | a2996422935e46f68087b6bb11f70919b086c35f (diff) | |
download | rails-58d0e2c23c0c5578f23a4f4c639db5c0009b80c2.tar.gz rails-58d0e2c23c0c5578f23a4f4c639db5c0009b80c2.tar.bz2 rails-58d0e2c23c0c5578f23a4f4c639db5c0009b80c2.zip |
Adding option to ActiveResource to allow you to not reset the previously stored requests and responses by passing false to respond_to
Diffstat (limited to 'activeresource/test')
-rw-r--r-- | activeresource/test/cases/http_mock_test.rb | 42 |
1 files changed, 41 insertions, 1 deletions
diff --git a/activeresource/test/cases/http_mock_test.rb b/activeresource/test/cases/http_mock_test.rb index be0568b1a9..d90d1e01b8 100644 --- a/activeresource/test/cases/http_mock_test.rb +++ b/activeresource/test/cases/http_mock_test.rb @@ -88,7 +88,7 @@ class HttpMockTest < ActiveSupport::TestCase assert_equal matz, ActiveResource::HttpMock.responses.assoc(get_matz)[1].body end - test "resets all mocked responses on each call to respond_to by default" do + test "resets all mocked responses on each call to respond_to with a block by default" do ActiveResource::HttpMock.respond_to do |mock| mock.send(:get, "/people/1", {}, "XML1") end @@ -100,6 +100,46 @@ class HttpMockTest < ActiveSupport::TestCase assert_equal 1, ActiveResource::HttpMock.responses.length end + test "resets all mocked responses on each call to respond_to by passing pairs by default" do + ActiveResource::HttpMock.respond_to do |mock| + mock.send(:get, "/people/1", {}, "XML1") + end + assert_equal 1, ActiveResource::HttpMock.responses.length + + matz = { :id => 1, :name => "Matz" }.to_xml(:root => "person") + get_matz = ActiveResource::Request.new(:get, '/people/1.xml', nil) + ok_response = ActiveResource::Response.new(matz, 200, {}) + ActiveResource::HttpMock.respond_to({get_matz => ok_response}) + + assert_equal 1, ActiveResource::HttpMock.responses.length + end + + test "allows you to add new responses to the existing responses by calling a block" do + ActiveResource::HttpMock.respond_to do |mock| + mock.send(:get, "/people/1", {}, "XML1") + end + assert_equal 1, ActiveResource::HttpMock.responses.length + + ActiveResource::HttpMock.respond_to(false) do |mock| + mock.send(:get, "/people/2", {}, "XML2") + end + assert_equal 2, ActiveResource::HttpMock.responses.length + end + + test "allows you to add new responses to the existing responses by passing pairs" do + ActiveResource::HttpMock.respond_to do |mock| + mock.send(:get, "/people/1", {}, "XML1") + end + assert_equal 1, ActiveResource::HttpMock.responses.length + + matz = { :id => 1, :name => "Matz" }.to_xml(:root => "person") + get_matz = ActiveResource::Request.new(:get, '/people/1.xml', nil) + ok_response = ActiveResource::Response.new(matz, 200, {}) + ActiveResource::HttpMock.respond_to({get_matz => ok_response}, false) + + assert_equal 2, ActiveResource::HttpMock.responses.length + end + def request(method, path, headers = {}, body = nil) if [:put, :post].include? method @http.send(method, path, body, headers) |