Methods
- A
- D
- H
- S
- T
-
- test_accept_http_header,
- test_auth_type_can_be_string,
- test_auth_type_defaults_to_basic,
- test_auth_type_ignores_nonsensical_values,
- test_delete,
- test_delete_with_header,
- test_get,
- test_get_collection,
- test_get_collection_empty,
- test_get_collection_single,
- test_get_with_header,
- test_handle_response,
- test_head,
- test_initialize_raises_argument_error_on_missing_site,
- test_post,
- test_post_with_header,
- test_proxy_accessor_accepts_uri_or_string_argument,
- test_put,
- test_put_with_header,
- test_setting_timeout,
- test_should_return_allowed_methods_for_method_no_allowed_exception,
- test_site_accessor_accepts_uri_or_string_argument,
- test_ssl_error,
- test_ssl_options_get_applied_to_http,
- test_timeout,
- test_timeout_accessor
Constants
| ResponseCodeStub | = | Struct.new(:code) |
| RedirectResponseStub | = | Struct.new(:code, :Location) |
| ResponseHeaderStub | = | Struct.new(:code, :message, 'Allow') |
Instance Public methods
setup()
Link
# File activeresource/test/cases/connection_test.rb, line 7 def setup @conn = ActiveResource::Connection.new('http://localhost') matz = { :person => { :id => 1, :name => 'Matz' } } david = { :person => { :id => 2, :name => 'David' } } @people = { :people => [ matz, david ] }.to_json @people_single = { 'people-single-elements' => [ matz ] }.to_json @people_empty = { 'people-empty-elements' => [ ] }.to_json @matz = matz.to_json @david = david.to_json @header = { 'key' => 'value' }.freeze @default_request_headers = { 'Content-Type' => 'application/json' } ActiveResource::HttpMock.respond_to do |mock| mock.get "/people/2.json", @header, @david mock.get "/people.json", {}, @people mock.get "/people_single_elements.json", {}, @people_single mock.get "/people_empty_elements.json", {}, @people_empty mock.get "/people/1.json", {}, @matz mock.put "/people/1.json", {}, nil, 204 mock.put "/people/2.json", {}, @header, 204 mock.delete "/people/1.json", {}, nil, 200 mock.delete "/people/2.json", @header, nil, 200 mock.post "/people.json", {}, nil, 201, 'Location' => '/people/5.json' mock.post "/members.json", {}, @header, 201, 'Location' => '/people/6.json' mock.head "/people/1.json", {}, nil, 200 end end
test_accept_http_header()
Link
# File activeresource/test/cases/connection_test.rb, line 215 def test_accept_http_header @http = mock('new Net::HTTP') @conn.expects(:http).returns(@http) path = '/people/1.xml' @http.expects(:get).with(path, { 'Accept' => 'application/xhtml+xml' }).returns(ActiveResource::Response.new(@matz, 200, { 'Content-Type' => 'text/xhtml' })) assert_nothing_raised(Mocha::ExpectationError) { @conn.get(path, { 'Accept' => 'application/xhtml+xml' }) } end
test_auth_type_can_be_string()
Link
test_auth_type_defaults_to_basic()
Link
test_auth_type_ignores_nonsensical_values()
Link
test_delete()
Link
test_delete_with_header()
Link
test_get()
Link
test_get_collection()
Link
test_get_collection_empty()
Link
test_get_collection_single()
Link
test_get_with_header()
Link
test_handle_response()
Link
# File activeresource/test/cases/connection_test.rb, line 35 def test_handle_response # 2xx and 3xx are valid responses. [200, 299, 300, 399].each do |code| expected = ResponseCodeStub.new(code) assert_equal expected, handle_response(expected) end # 301 is moved permanently (redirect) assert_redirect_raises 301 # 302 is found (redirect) assert_redirect_raises 302 # 303 is see other (redirect) assert_redirect_raises 303 # 307 is temporary redirect assert_redirect_raises 307 # 400 is a bad request (e.g. malformed URI or missing request parameter) assert_response_raises ActiveResource::BadRequest, 400 # 401 is an unauthorized request assert_response_raises ActiveResource::UnauthorizedAccess, 401 # 403 is a forbidden request (and authorizing will not help) assert_response_raises ActiveResource::ForbiddenAccess, 403 # 404 is a missing resource. assert_response_raises ActiveResource::ResourceNotFound, 404 # 405 is a method not allowed error assert_response_raises ActiveResource::MethodNotAllowed, 405 # 409 is an optimistic locking error assert_response_raises ActiveResource::ResourceConflict, 409 # 410 is a removed resource assert_response_raises ActiveResource::ResourceGone, 410 # 422 is a validation error assert_response_raises ActiveResource::ResourceInvalid, 422 # 4xx are client errors. [402, 499].each do |code| assert_response_raises ActiveResource::ClientError, code end # 5xx are server errors. [500, 599].each do |code| assert_response_raises ActiveResource::ServerError, code end # Others are unknown. [199, 600].each do |code| assert_response_raises ActiveResource::ConnectionError, code end end
test_head()
Link
test_initialize_raises_argument_error_on_missing_site()
Link
test_post()
Link
test_post_with_header()
Link
test_proxy_accessor_accepts_uri_or_string_argument()
Link
# File activeresource/test/cases/connection_test.rb, line 120 def test_proxy_accessor_accepts_uri_or_string_argument proxy = URI.parse("http://proxy_user:proxy_password@proxy.local:4242") assert_nothing_raised { @conn.proxy = "http://proxy_user:proxy_password@proxy.local:4242" } assert_equal proxy, @conn.proxy assert_nothing_raised { @conn.proxy = proxy } assert_equal proxy, @conn.proxy end
test_put()
Link
test_put_with_header()
Link
test_setting_timeout()
Link
# File activeresource/test/cases/connection_test.rb, line 204 def test_setting_timeout http = Net::HTTP.new('') [10, 20].each do |timeout| @conn.timeout = timeout @conn.send(:configure_http, http) assert_equal timeout, http.open_timeout assert_equal timeout, http.read_timeout end end
test_should_return_allowed_methods_for_method_no_allowed_exception()
Link
# File activeresource/test/cases/connection_test.rb, line 95 def test_should_return_allowed_methods_for_method_no_allowed_exception begin handle_response ResponseHeaderStub.new(405, "HTTP Failed...", "GET, POST") rescue ActiveResource::MethodNotAllowed => e assert_equal "Failed. Response code = 405. Response message = HTTP Failed....", e.message assert_equal [:get, :post], e.allowed_methods end end
test_site_accessor_accepts_uri_or_string_argument()
Link
# File activeresource/test/cases/connection_test.rb, line 108 def test_site_accessor_accepts_uri_or_string_argument site = URI.parse("http://localhost") assert_raise(URI::InvalidURIError) { @conn.site = nil } assert_nothing_raised { @conn.site = "http://localhost" } assert_equal site, @conn.site assert_nothing_raised { @conn.site = site } assert_equal site, @conn.site end
test_ssl_error()
Link
# File activeresource/test/cases/connection_test.rb, line 234 def test_ssl_error http = Net::HTTP.new('') @conn.expects(:http).returns(http) http.expects(:get).raises(OpenSSL::SSL::SSLError, 'Expired certificate') assert_raise(ActiveResource::SSLError) { @conn.get('/people/1.json') } end
test_ssl_options_get_applied_to_http()
Link
# File activeresource/test/cases/connection_test.rb, line 223 def test_ssl_options_get_applied_to_http http = Net::HTTP.new('') @conn.site="https://secure" @conn.ssl_options={:verify_mode => OpenSSL::SSL::VERIFY_PEER} @conn.timeout = 10 # prevent warning about uninitialized. @conn.send(:configure_http, http) assert http.use_ssl? assert_equal http.verify_mode, OpenSSL::SSL::VERIFY_PEER end
test_timeout()
Link
# File activeresource/test/cases/connection_test.rb, line 197 def test_timeout @http = mock('new Net::HTTP') @conn.expects(:http).returns(@http) @http.expects(:get).raises(Timeout::Error, 'execution expired') assert_raise(ActiveResource::TimeoutError) { @conn.get('/people_timeout.json') } end
test_timeout_accessor()
Link
Instance Protected methods
assert_redirect_raises(code)
Link
# File activeresource/test/cases/connection_test.rb, line 263 def assert_redirect_raises(code) assert_raise(ActiveResource::Redirection, "Expected response code #{code} to raise ActiveResource::Redirection") do handle_response RedirectResponseStub.new(code, 'http://example.com/') end end
assert_response_raises(klass, code)
Link
decode(response)
Link