require 'spec_helper' describe "HTTP" do before do @web_port = test_server.http_port @client = Riak::Client.new(:http_port => @web_port) end [:ExconBackend, :NetHTTPBackend].each do |klass| bklass = Riak::Client.const_get(klass) if bklass.configured? describe klass.to_s do before do @backend = bklass.new(@client, @client.node) end it_should_behave_like "Unified backend API" describe "searching fulltext indexes (1.1 and earlier)", :version => "< 1.2.0" do include_context "search corpus setup" it 'should find indexed documents, returning ids' do results = @backend.search 'search_test', 'fearless elephant rushed', :fl => 'id' results.should have_key 'docs' results.should have_key 'max_score' results.should have_key 'num_found' results['docs'].should include({"id" => "munchausen-605"}) end it 'should find indexed documents, returning documents' do # For now use '*' until #122 is merged into riak_search results = @backend.search 'search_test', 'fearless elephant rushed', :fl => '*' results.should have_key 'docs' results.should have_key 'max_score' results.should have_key 'num_found' results['docs'].should include({"id" => "munchausen-605", "value" => "Fearless I advanced against the elephant, desirous to take alive the haughty Tippoo Sahib; but he drew a pistol from his belt, and discharged it full in my face as I rushed upon him, which did me no further harm than wound my cheek-bone, which disfigures me somewhat under my left eye. I could not withstand the rage and impulse of that moment, and with one blow of my sword separated his head from his body.\n"}) end end context "clearing bucket properties" do it "should return false when unsupported", :version => "< 1.3.0" do @backend.clear_bucket_props('foo').should be_false end it "should reset a previously set property to the default", :version => ">= 1.3.0" do bucket = @client['bucketpropscleartest'] original_n = @backend.get_bucket_props(bucket)['n_val'] @backend.set_bucket_props(bucket, {'n_val' => 2}) @backend.get_bucket_props(bucket)['n_val'].should == 2 @backend.clear_bucket_props(bucket) @backend.get_bucket_props(bucket)['n_val'].should == original_n end end context "using Luwak", :version => "< 1.1.0" do let(:file) { File.open(__FILE__) } let(:key) { "spec.rb" } let(:string) { file.read } def retry_400 begin yield rescue Riak::HTTPFailedRequest => e # Riak 1.0.x (and possibly earlier) has a bug in # mochiweb that will sometimes leave dangling 400 # responses on the wire between requests when the # connection is left open. This will happen sometimes # immediately after a store_file request. if e.code == 400 retry else raise end end end it "should store an IO with a given key" do @backend.store_file(key, 'text/plain', file) stored_file = retry_400 { @backend.get_file(key) } stored_file.content_type.should == 'text/plain' stored_file.size.should == file.size end it "should store a String with a given key" do @backend.store_file(key, 'text/plain', string) stored_file = retry_400 { @backend.get_file(key) } stored_file.content_type.should == 'text/plain' stored_file.size.should == string.bytesize end it "should store an IO with a server-defined key" do key = @backend.store_file('text/plain', file) stored_file = retry_400 { @backend.get_file(key) } stored_file.content_type.should == 'text/plain' stored_file.size.should == file.size end it "should store a String with a server-defined key" do key = @backend.store_file('text/plain', string) stored_file = retry_400 { @backend.get_file(key) } stored_file.content_type.should == 'text/plain' stored_file.size.should == string.bytesize end end end end end class Reader < Array def read(*args) shift end def size join.size end end class SizelessReader < Reader undef :size end describe 'NetHTTPBackend' do subject { Riak::Client::NetHTTPBackend.new(@client, @client.node) } let(:file) { File.open(__FILE__) } let(:sized) { Reader.new(["foo", "bar", "baz"]) } let(:sizeless) { SizelessReader.new(["foo", "bar", "baz"]) } it "should set the content-length or transfer-encoding properly on IO uploads" do lambda { subject.put(204, subject.object_path('nethttp', 'test-file'), file, {"Content-Type" => "text/plain"}) }.should_not raise_error lambda { subject.put(204, subject.object_path('nethttp', 'test-sized'), sized, {"Content-Type" => "text/plain"}) }.should_not raise_error lambda { subject.put(204, subject.object_path('nethttp', 'test-sizeless'), sizeless, {"Content-Type" => "text/plain"}) }.should_not raise_error end end end