spec/jruby_memcache_spec.rb in jruby-memcache-client-1.7.0 vs spec/jruby_memcache_spec.rb in jruby-memcache-client-1.7.1

- old
+ new

@@ -1,268 +1,272 @@ require 'java' require File.dirname(__FILE__) + '/../lib/memcache' describe MemCache do - before :all do - @server = "127.0.0.1:11211" - @client = MemCache.new @server - end - before :each do - @client.flush_all - end - after :each do - @client.flush_all - end + hostname = `hostname`.strip - it "should return nil for a non-existent key" do - @client.get('non-existent-key').should be_nil - end + ["127.0.0.1:11211", "127.0.0.1", "localhost:11211", "localhost"].each do |server| + before :all do + @server = server + @normalized_server = @server =~ /(.+):(\d+)/ ? @server : "#{@server}:11211" + end - describe "setting servers" do - it "should work if the instance is created with a single String argument" do + before :each do @client = MemCache.new @server - @client.servers.should == [@server] + @client.should_not be_nil + @client.flush_all end - it "should work if the instance is created with an Array" do - @client = MemCache.new [ @server ] - @client.servers.should == [ @server ] + after :each do + @client.flush_all end - it "should work if the instance is created with a Hash" do - @client = MemCache.new [ @server ], :namespace => 'test' - @client.servers.should == [ @server ] + it "should return nil for a non-existent key" do + @client.get('non-existent-key').should be_nil end - it "should work with an explicit pool name" do - @client = MemCache.new([@server], :pool_name => 'new_pool') - @client.pool_name.should == 'new_pool' - end + describe "setting servers" do + it "should work if the instance is created with a single String argument" do + @client = MemCache.new @server + @client.servers.should == [@normalized_server] + end - it "should work with an error handler" do - include_class 'com.meetup.memcached.MemcachedClient' - java_memcache_client = mock.as_null_object - MemcachedClient.stub!(:new => java_memcache_client) - error_handler = Object.new - java_memcache_client.should_receive(:error_handler=).with(error_handler) - @client = MemCache.new([@server], :error_handler => error_handler) - end - end + it "should work if the instance is created with an Array" do + @client = MemCache.new [ @server ] + @client.servers.should == [@normalized_server] + end - describe "namespacing" do - before(:each) do - @ns = 'namespace' - @nsclient = MemCache.new [ @server ] , :namespace => @ns - @nsclient.flush_all - @nsclient.set "test", 333, 0 - end + it "should work if the instance is created with a Hash" do + @client = MemCache.new [ @server ], :namespace => 'test' + @client.servers.should == [@normalized_server] + end - it "should set and get values transparently" do - @nsclient.get("test").to_i.should == 333 - end + it "should work with an explicit pool name" do + @client = MemCache.new([@server], :pool_name => 'new_pool') + @client.pool_name.should == 'new_pool' + end - it "should set values to the given namespace" do - @client.get("#{@ns}:test").to_i.should == 333 + it "should work with an error handler" do + java_import 'com.danga.MemCached.MemCachedClient' + java_memcache_client = mock.as_null_object + MemCachedClient.stub!(:new => java_memcache_client) + error_handler = Object.new + java_memcache_client.should_receive(:error_handler=).with(error_handler) + @client = MemCache.new([@server], :error_handler => error_handler) + end end - it "should not set a value without the given namespace" do - @client.get("test").to_i.should_not == 333 - end + describe "namespacing" do + before(:each) do + @ns = 'namespace' + @nsclient = MemCache.new [ @server ] , :namespace => @ns + @nsclient.flush_all + @nsclient.set "test", 333, 0 + end - it "should delete values in the given namespace" do - @nsclient.delete "test" - @nsclient.get("test").should be_nil - end + it "should set and get values transparently" do + @nsclient.get("test").should == 333 + end - it "should increment in the given namespace" do - @nsclient.incr("test").to_i.should == 334 - end + it "should set values to the given namespace" do + @nsclient.get("test").to_i.should == 333 + end - it "should decrement values in the given namespace" do - @nsclient.decr("test").should == 332 - end - end + it "should not set a value without the given namespace" do + @client.get("test").to_i.should_not == 333 + end - describe "after setting a value to MemCache" do - before(:each) do - @client.set 'key', 'value' - end + it "should delete values in the given namespace" do + @nsclient.delete "test" + @nsclient.get("test").should be_nil + end - it "should be able to retrieve the value" do - @client.get('key').should == 'value' - end + it "should increment in the given namespace" do + @nsclient.incr("test").to_i.should == 334 + end - it "should not be able to retrieve the value after deleting" do - @client.delete('key') - @client.get('key').should be_nil + it "should decrement values in the given namespace" do + @nsclient.decr("test").should == 332 + end end - it "should not be able to retrieve the value after flushing everything" do - @client.flush_all - @client.get("key").should be_nil - end + describe "after setting a value to MemCache" do + before(:each) do + @client.set 'key', 'value' + end - it "should work exactly the same if the []= operator were used" do - @client['key'] = 'val' - @client.get('key').should == 'val' - end - end + it "should be able to retrieve the value" do + @client.get('key').should == 'value' + end - describe "replacing values from the cache." do - before :each do - @client['key'] = 'value' - end + it "should not be able to retrieve the value after deleting" do + @client.delete('key') + @client.get('key').should be_nil + end - it "should be able to replace the stored value." do - @client.replace('key', 'new value').should be_true - @client['key'].should == 'new value' - end + it "should not be able to retrieve the value after flushing everything" do + @client.flush_all + @client.get("key").should be_nil + end - it "should not replace values that are not in the cache." do - @client.replace('notthere', 'value').should be_false + it "should work exactly the same if the []= operator were used" do + @client['key'] = 'val' + @client.get('key').should == 'val' + end end - end - describe "using the Hash notation" do - before :each do - @client['key'] = 'value' - end + describe "replacing values from the cache." do + before :each do + @client['key'] = 'value' + end - it "should be able to retrieve the value using []" do - @client['key'].should == 'value' - end + it "should be able to replace the stored value." do + @client.replace('key', 'new value').should be_true + @client['key'].should == 'new value' + end - it "should be able to retrieve the value using get" do - @client.get('key').should == 'value' + it "should not replace values that are not in the cache." do + @client.replace('notthere', 'value').should be_false + end end - end - describe "#stats" do - it "should return a hash" do - @client.stats.should be_instance_of(Hash) - end + describe "using the Hash notation" do + before :each do + @client['key'] = 'value' + end - # it "should return 0 for curr_items" do - # @client.stats[@server]['curr_items'].should == 0 - # end + it "should be able to retrieve the value using []" do + @client['key'].should == 'value' + end - it "should return a float for rusage_system and rusage_user" do - @client.stats[@server]['rusage_system'].should be_instance_of(Float) - @client.stats[@server]['rusage_user'].should be_instance_of(Float) + it "should be able to retrieve the value using get" do + @client.get('key').should == 'value' + end end - it "should return a String for version" do - @client.stats[@server]['version'].should be_instance_of(String) - end + describe "#stats" do + it "should return a hash" do + @client.stats.should be_instance_of(Hash) + end - end + it "should return a float for rusage_system and rusage_user" do + @client.stats[@normalized_server]['rusage_system'].should be_instance_of(Float) + @client.stats[@normalized_server]['rusage_user'].should be_instance_of(Float) + end - describe "#incr" do + it "should return a String for version" do + @client.stats[@normalized_server]['version'].should be_instance_of(String) + end - it "should increment a value by 1 without a second parameter" do - @client.set 'incr', 100, 0 - @client.incr 'incr' - @client.get('incr').to_i.should == 101 end - it "should increment a value by a given second parameter" do - @client.set 'incr', 100, 0 - @client.incr 'incr', 20 - @client.get('incr').to_i.should == 120 - end - end + describe "#incr" do - describe "#decr" do + it "should increment a value by 1 without a second parameter" do + @client.set 'incr', 100, 0 + @client.incr 'incr' + @client.get('incr').to_i.should == 101 + end - it "should decrement a value by 1 without a second parameter" do - @client.set 'decr', 100, 0 - @client.decr 'decr' - @client.get('decr').to_i.should == 99 + it "should increment a value by a given second parameter" do + @client.set 'incr', 100, 0 + @client.incr 'incr', 20 + @client.get('incr').to_i.should == 120 + end end - it "should decrement a value by a given second parameter" do - @client.set 'decr', 100, 0 - @client.decr 'decr', 20 - @client.get('decr').to_i.should == 80 - end - end + describe "#decr" do - describe "with Ruby Objects" do - it "should be able to transparently set and get equivalent Ruby objects" do - obj = { :test => :hi } - @client.set('obj', obj) - @client.get('obj').should == obj - end + it "should decrement a value by 1 without a second parameter" do + @client.set 'decr', 100, 0 + @client.decr 'decr' + @client.get('decr').to_i.should == 99 + end - it %[should work with those whose marshalled stream contains invalid UTF8 byte sequences] do - # this test fails w/o the Base64 encoding step - obj = { :foo => 900 } - @client.set('obj', obj) - @client.get('obj').should == obj + it "should decrement a value by a given second parameter" do + @client.set 'decr', 100, 0 + @client.decr 'decr', 20 + @client.get('decr').to_i.should == 80 + end end - it %[should work with binary blobs] do - # this test fails w/o the Base64 encoding step - blob = "\377\330\377\340\000\020JFIF\000\001\001\000\000\001\000\001\000\000\377" - @client.set('blob', blob) - @client.get('blob').should == blob - end - end + describe "with Ruby Objects" do + it "should be able to transparently set and get equivalent Ruby objects" do + obj = { :test => :hi } + @client.set('obj', obj) + @client.get('obj').should == obj + end - describe "using set with an expiration" do - it "should make a value unretrievable if the expiry is set to a negative value" do - @client.set('key', 'val', -1) - @client.get('key').should be_nil - end + it %[should work with those whose marshalled stream contains invalid UTF8 byte sequences] do + # this test fails w/o the Base64 encoding step + obj = { :foo => 900 } + @client.set('obj', obj) + @client.get('obj').should == obj + end - it "should make a value retrievable for only the amount of time if a value is given" do - @client.set('key', 'val', 2) - @client.get('key').should == 'val' - sleep(3) - @client.get('key').should be_nil + it %[should work with binary blobs] do + # this test fails w/o the Base64 encoding step + blob = "\377\330\377\340\000\020JFIF\000\001\001\000\000\001\000\001\000\000\377" + @client.set('blob', blob) + @client.get('blob').should == blob + end end - end - describe "#get_multi" do - it "should get 2 keys" do - @client.set('key', 'val') - @client.set('key2', 'val2') - @client.get_multi(%w/key key2/).should == {'key' => 'val', 'key2' => 'val2'} - end + describe "using set with an expiration" do + it "should make a value unretrievable if the expiry is set to a negative value" do + @client.set('key', 'val', -1) + @client.get('key').should be_nil + end - it "should ignore nil values" do - @client.set('key', 'val') - @client.set('key2', 'val2') - @client.get_multi(%w/key key2 key3/).should == {'key' => 'val', 'key2' => 'val2'} + it "should make a value retrievable for only the amount of time if a value is given" do + @client.set('key', 'val', 2) + @client.get('key').should == 'val' + sleep(3) + @client.get('key').should be_nil + end end - it "should not marshall if requested" do - @client.set('key', 'val', 0, true) - @client.set('key2', 'val2', 0, true) - @client.get_multi(%w/key key2/, true).should == {'key' => 'val', 'key2' => 'val2'} - end - end + describe "#get_multi" do + it "should get 2 keys" do + @client.set('key', 'val') + @client.set('key2', 'val2') + @client.get_multi(%w/key key2/).should == {'key' => 'val', 'key2' => 'val2'} + end - describe "aliveness of the MemCache server." do - before :each do - @servers = ["localhost:11211", "localhost:11212", {:pool_name => "test"}] - @client = MemCache.new @servers - @client.flush_all - end + it "should ignore nil values" do + @client.set('key', 'val') + @client.set('key2', 'val2') + @client.get_multi(%w/key key2 key3/).should == {'key' => 'val', 'key2' => 'val2'} + end - it "should report the client as being alive." do - @client.should be_alive + it "should not marshall if requested" do + @client.set('key', 'val', 0, true) + @client.set('key2', 'val2', 0, true) + @client.get_multi(%w/key key2/, true).should == {'key' => 'val', 'key2' => 'val2'} + end end - it "should report localhost:11211 as being alive." do - servers = @client.servers - servers.first.should be_alive - end + describe "aliveness of the MemCache server." do + before :each do + @servers = ["localhost:11211", "localhost:11212", {:pool_name => "test"}] + @client = MemCache.new @servers + @client.flush_all + end - it "should report localhost:11212 as not being alive." do - servers = @client.servers - servers.find {|s| s.to_s == "localhost:11212"}.should be_nil + it "should report the client as being alive." do + @client.should be_alive + end + + it "should report localhost:11211 as being alive." do + servers = @client.servers + servers.first.should be_alive + end + + it "should report localhost:11212 as not being alive." do + servers = @client.servers + servers.find {|s| s.to_s == "localhost:11212"}.should be_nil + end end end end