rename, renamenx
[perl-Redis.git] / t / 01-Redis.t
index 6d876f5..cd92633 100755 (executable)
@@ -3,7 +3,7 @@
 use warnings;
 use strict;
 
-use Test::More tests => 28;
+use Test::More tests => 52;
 
 use lib 'lib';
 
@@ -26,23 +26,53 @@ ok( $o->set( foo => 'baz' ), 'set foo => baz' );
 
 cmp_ok( $o->get( 'foo' ), 'eq', 'baz', 'get foo = baz' );
 
+$o->del('non-existant');
+
+ok( ! $o->exists( 'non-existant' ), 'exists non-existant' );
 ok( ! $o->get( 'non-existant' ), 'get non-existant' );
 
 ok( $o->set('key-next' => 0), 'key-next = 0' );
 
 my $key_next = 3;
 
+ok( $o->set('key-left' => $key_next), 'key-left' );
+
+my @keys;
+
 foreach ( 0 .. $key_next ) {
-       ok(     $o->set( "key-$_" => $_ ),           "set key-$_" );
-       cmp_ok( $o->get( "key-$_"       ), 'eq', $_, "get key-$_" );
+       my $key = 'key-' . $_;
+       push @keys, $key;
+       ok(     $o->set( $key => $_ ),           "set $key" );
+       ok(  $o->exists( $key       ),           "exists $key" );
+       cmp_ok( $o->get( $key       ), 'eq', $_, "get $key" );
        cmp_ok( $o->incr( 'key-next' ), '==', $_ + 1, 'incr' );
+       cmp_ok( $o->decr( 'key-left' ), '==', $key_next - $_ - 1, 'decr' );
 }
 
 cmp_ok( $o->get( 'key-next' ), '==', $key_next + 1, 'key-next' );
 
 ok( $o->set('test-incrby', 0), 'test-incrby' );
+ok( $o->set('test-decrby', 0), 'test-decry' );
 foreach ( 1 .. 3 ) {
        cmp_ok( $o->incr('test-incrby', 3), '==', $_ * 3, 'incrby 3' );
+       cmp_ok( $o->decr('test-decrby', 7), '==', -( $_ * 7 ), 'decrby 7' );
 }
 
+ok( $o->del( $_ ), "del $_" ) foreach map { "key-$_" } ( 'next', 'left' );
+ok( ! $o->del('non-existing' ), 'del non-existing' );
+
+cmp_ok( $o->type('foo'), 'eq', 'string', 'type' );
+
+cmp_ok( $o->keys('key-*'), '==', $key_next + 1, 'key-*' );
+is_deeply( [ $o->keys('key-*') ], [ @keys ], 'keys' );
+
+ok( my $key = $o->randomkey, 'randomkey' );
+diag "key: $key";
+
+ok( $o->rename( $key, 'test-renamed' ), 'rename' );
+ok( $o->exists( 'test-renamed' ), 'exists test-renamed' );
+
+eval { $o->rename( $o->randomkey, 'test-renamed', 1 ) };
+ok( $@, 'rename to existing key' );
+
 ok( $o->quit, 'quit' );