require "spec_helper" require "httpi" describe HTTPI do let(:client) { HTTPI } let(:default_adapter) { HTTPI::Adapter.find(HTTPI::Adapter.use)[1] } let(:curb) { HTTPI::Adapter.find(:curb)[1] } describe ".get(request)" do it "should execute an HTTP GET request using the default adapter" do request = HTTPI::Request.new default_adapter.any_instance.expects(:get).with(request) client.get request end end describe ".get(request, adapter)" do it "should execute an HTTP GET request using the given adapter" do request = HTTPI::Request.new curb.any_instance.expects(:get).with(request) client.get request, :curb end end describe ".get(url)" do it "should execute an HTTP GET request using the default adapter" do HTTPI::Request.any_instance.expects(:url=).with("http://example.com") default_adapter.any_instance.expects(:get).with(instance_of(HTTPI::Request)) client.get "http://example.com" end end describe ".get(url, adapter)" do it "should execute an HTTP GET request using the given adapter" do HTTPI::Request.any_instance.expects(:url=).with("http://example.com") curb.any_instance.expects(:get).with(instance_of(HTTPI::Request)) client.get "http://example.com", :curb end end describe ".post(request)" do it "should execute an HTTP POST request using the default adapter" do request = HTTPI::Request.new default_adapter.any_instance.expects(:post).with(request) client.post request end end describe ".post(request, adapter)" do it "should execute an HTTP POST request using the given adapter" do request = HTTPI::Request.new curb.any_instance.expects(:post).with(request) client.post request, :curb end end describe ".post(url, body)" do it "should execute an HTTP POST request using the default adapter" do HTTPI::Request.any_instance.expects(:url=).with("http://example.com") HTTPI::Request.any_instance.expects(:body=).with("xml") default_adapter.any_instance.expects(:post).with(instance_of(HTTPI::Request)) client.post "http://example.com", "xml" end end describe ".post(url, body, adapter)" do it "should execute an HTTP POST request using the given adapter" do HTTPI::Request.any_instance.expects(:url=).with("http://example.com") HTTPI::Request.any_instance.expects(:body=).with("xml") curb.any_instance.expects(:post).with(instance_of(HTTPI::Request)) client.post "http://example.com", "xml", :curb end end describe ".head(request)" do it "should execute an HTTP HEAD request using the default adapter" do request = HTTPI::Request.new default_adapter.any_instance.expects(:head).with(request) client.head request end end describe ".head(request, adapter)" do it "should execute an HTTP HEAD request using the given adapter" do request = HTTPI::Request.new curb.any_instance.expects(:head).with(request) client.head request, :curb end end describe ".head(url)" do it "should execute an HTTP HEAD request using the default adapter" do HTTPI::Request.any_instance.expects(:url=).with("http://example.com") default_adapter.any_instance.expects(:head).with(instance_of(HTTPI::Request)) client.head "http://example.com" end end describe ".head(url, adapter)" do it "should execute an HTTP HEAD request using the given adapter" do HTTPI::Request.any_instance.expects(:url=).with("http://example.com") curb.any_instance.expects(:head).with(instance_of(HTTPI::Request)) client.head "http://example.com", :curb end end describe ".put(request)" do it "should execute an HTTP PUT request using the default adapter" do request = HTTPI::Request.new default_adapter.any_instance.expects(:put).with(request) client.put request end end describe ".put(request, adapter)" do it "should execute an HTTP PUT request using the given adapter" do request = HTTPI::Request.new curb.any_instance.expects(:put).with(request) client.put request, :curb end end describe ".put(url, body)" do it "should execute an HTTP PUT request using the default adapter" do HTTPI::Request.any_instance.expects(:url=).with("http://example.com") HTTPI::Request.any_instance.expects(:body=).with("xml") default_adapter.any_instance.expects(:put).with(instance_of(HTTPI::Request)) client.put "http://example.com", "xml" end end describe ".put(url, body, adapter)" do it "should execute an HTTP PUT request using the given adapter" do HTTPI::Request.any_instance.expects(:url=).with("http://example.com") HTTPI::Request.any_instance.expects(:body=).with("xml") curb.any_instance.expects(:put).with(instance_of(HTTPI::Request)) client.put "http://example.com", "xml", :curb end end describe ".delete(request)" do it "should execute an HTTP DELETE request using the default adapter" do request = HTTPI::Request.new default_adapter.any_instance.expects(:delete).with(request) client.delete request end end describe ".delete(request, adapter)" do it "should execute an HTTP DELETE request using the given adapter" do request = HTTPI::Request.new curb.any_instance.expects(:delete).with(request) client.delete request, :curb end end describe ".delete(url)" do it "should execute an HTTP DELETE request using the default adapter" do HTTPI::Request.any_instance.expects(:url=).with("http://example.com") default_adapter.any_instance.expects(:delete).with(instance_of(HTTPI::Request)) client.delete "http://example.com" end end describe ".delete(url, adapter)" do it "should execute an HTTP DELETE request using the given adapter" do HTTPI::Request.any_instance.expects(:url=).with("http://example.com") curb.any_instance.expects(:delete).with(instance_of(HTTPI::Request)) client.delete "http://example.com", :curb end end describe ".request" do it "should raise an ArgumentError in case of an invalid request method" do lambda { client.request :invalid, HTTPI::Request.new }.should raise_error(ArgumentError) end end HTTPI::REQUEST_METHODS.each do |method| describe ".request(#{method}, request, adapter)" do it "should delegate to the .#{method} method" do HTTPI.expects(method) client.request method, HTTPI::Request.new end end describe ".#{method}" do let(:request) { HTTPI::Request.new :url => "http://example.com" } it "should raise an ArgumentError in case of an invalid adapter" do lambda { client.request method, request, :invalid }.should raise_error(ArgumentError) end it "should raise an ArgumentError in case of an invalid request" do lambda { client.request method, "invalid" }.should raise_error(ArgumentError) end HTTPI::Adapter.adapters.each do |adapter, values| client_class = { :httpclient => lambda { HTTPClient }, :curb => lambda { Curl::Easy }, :net_http => lambda { Net::HTTP } } context "using #{adapter}" do before { values[:class].any_instance.expects(method) } it "should log that we're executing an HTTP request" do HTTPI.expects(:log).with("HTTPI executes HTTP #{method.to_s.upcase} using the #{adapter} adapter") client.request method, request, adapter end it "should yield the HTTP client instance used for the request" do block = lambda { |http| http.should be_a(client_class[adapter].call) } client.request(method, request, adapter, &block) end end end HTTPI::Adapter.adapters.reject { |key, value| key == HTTPI::Adapter::FALLBACK }.each do |adapter, values| context "when #{adapter} could not be loaded" do before do HTTPI::Adapter.expects(:require).with(values[:require]).raises(LoadError) HTTPI::Adapter.expects(:require).with("net/https") HTTPI::Adapter::NetHTTP.any_instance.expects(method) end it "should fall back to using the FALLBACK adapter" do HTTPI.expects(:log).with( "HTTPI tried to use the #{adapter} adapter, but was unable to find the library in the LOAD_PATH.", "Falling back to using the #{HTTPI::Adapter::FALLBACK} adapter now." ) HTTPI.expects(:log).with("HTTPI executes HTTP #{method.to_s.upcase} using the #{HTTPI::Adapter::FALLBACK} adapter") client.request method, request, adapter end end end end end context "with resetting the defaults" do before { HTTPI.reset_config! } after do HTTPI.reset_config! HTTPI.log = false # disable for specs end describe ".log" do it "should default to true" do HTTPI.log?.should be_true end it "should set whether to log" do HTTPI.log = false HTTPI.log?.should be_false end end describe ".logger" do it "should default to Logger writing to STDOUT" do HTTPI.logger.should be_a(Logger) end it "should set the logger to use" do MyLogger = Class.new HTTPI.logger = MyLogger HTTPI.logger.should == MyLogger end end describe ".log_level" do it "should default to :warn" do HTTPI.log_level.should == :warn end it "should set the log level to use" do HTTPI.log_level = :info HTTPI.log_level.should == :info end end describe ".log" do it "should log given messages" do HTTPI.log_level = :debug HTTPI.logger.expects(:debug).with("Log this") HTTPI.log "Log", "this" end end end end