6 use Test::More tests => 86;
14 ok( my $o = Redis->new(), 'new' );
16 ok( $o->ping, 'ping' );
18 ok( $o->set( foo => 'bar' ), 'set foo => bar' );
20 eval { $o->set( foo => 'bar', 1 ) };
21 ok( $@, 'set foo => bar new again failed' );
23 cmp_ok( $o->get( 'foo' ), 'eq', 'bar', 'get foo = bar' );
25 ok( $o->set( foo => 'baz' ), 'set foo => baz' );
27 cmp_ok( $o->get( 'foo' ), 'eq', 'baz', 'get foo = baz' );
29 ok( $o->set( 'test-undef' => 42 ), 'set test-undef' );
30 ok( $o->set( 'test-undef' => undef ), 'set undef' );
31 ok( ! defined $o->get( 'test-undef' ), 'get undef' );
32 diag $o->exists( 'test-undef' );
33 ok( $o->exists( 'test-undef' ), 'exists undef' );
35 $o->del('non-existant');
37 ok( ! $o->exists( 'non-existant' ), 'exists non-existant' );
38 ok( ! $o->get( 'non-existant' ), 'get non-existant' );
40 ok( $o->set('key-next' => 0), 'key-next = 0' );
44 ok( $o->set('key-left' => $key_next), 'key-left' );
48 foreach ( 0 .. $key_next ) {
49 my $key = 'key-' . $_;
51 ok( $o->set( $key => $_ ), "set $key" );
52 ok( $o->exists( $key ), "exists $key" );
53 cmp_ok( $o->get( $key ), 'eq', $_, "get $key" );
54 cmp_ok( $o->incr( 'key-next' ), '==', $_ + 1, 'incr' );
55 cmp_ok( $o->decr( 'key-left' ), '==', $key_next - $_ - 1, 'decr' );
58 cmp_ok( $o->get( 'key-next' ), '==', $key_next + 1, 'key-next' );
60 ok( $o->set('test-incrby', 0), 'test-incrby' );
61 ok( $o->set('test-decrby', 0), 'test-decry' );
63 cmp_ok( $o->incr('test-incrby', 3), '==', $_ * 3, 'incrby 3' );
64 cmp_ok( $o->decr('test-decrby', 7), '==', -( $_ * 7 ), 'decrby 7' );
67 ok( $o->del( $_ ), "del $_" ) foreach map { "key-$_" } ( 'next', 'left' );
68 ok( ! $o->del('non-existing' ), 'del non-existing' );
70 cmp_ok( $o->type('foo'), 'eq', 'string', 'type' );
72 cmp_ok( $o->keys('key-*'), '==', $key_next + 1, 'key-*' );
73 is_deeply( [ $o->keys('key-*') ], [ @keys ], 'keys' );
75 ok( my $key = $o->randomkey, 'randomkey' );
78 ok( $o->rename( 'test-incrby', 'test-renamed' ), 'rename' );
79 ok( $o->exists( 'test-renamed' ), 'exists test-renamed' );
81 eval { $o->rename( 'test-decrby', 'test-renamed', 1 ) };
82 ok( $@, 'rename to existing key' );
84 ok( my $nr_keys = $o->dbsize, 'dbsize' );
85 diag "dbsize: $nr_keys";
87 diag "Commands operating on lists";
89 my $list = 'test-list';
91 $o->del($list) && diag "cleanup $list from last run";
93 ok( $o->rpush( $list => "r$_" ), 'rpush' ) foreach ( 1 .. 3 );
95 ok( $o->lpush( $list => "l$_" ), 'lpush' ) foreach ( 1 .. 2 );
97 cmp_ok( $o->type($list), 'eq', 'list', 'type' );
98 cmp_ok( $o->llen($list), '==', 5, 'llen' );
100 is_deeply( [ $o->lrange( $list, 0, 1 ) ], [ 'l2', 'l1' ], 'lrange' );
102 ok( $o->ltrim( $list, 1, 2 ), 'ltrim' );
103 cmp_ok( $o->llen($list), '==', 2, 'llen after ltrim' );
105 cmp_ok( $o->lindex( $list, 0 ), 'eq', 'l1', 'lindex' );
106 cmp_ok( $o->lindex( $list, 1 ), 'eq', 'r1', 'lindex' );
108 ok( $o->lset( $list, 0, 'foo' ), 'lset' );
109 cmp_ok( $o->lindex( $list, 0 ), 'eq', 'foo', 'verified' );
111 ok( $o->lrem( $list, 1, 'foo' ), 'lrem' );
112 cmp_ok( $o->llen( $list ), '==', 1, 'llen after lrem' );
114 cmp_ok( $o->lpop( $list ), 'eq', 'r1', 'lpop' );
116 ok( ! $o->rpop( $list ), 'rpop' );
118 # Commands operating on sets
120 my $set = 'test-set';
123 ok( $o->sadd( $set, 'foo' ), 'sadd' );
124 ok( ! $o->sadd( $set, 'foo' ), 'sadd' );
125 cmp_ok( $o->scard( $set ), '==', 1, 'scard' );
126 ok( $o->sismember( $set, 'foo' ), 'sismember' );
128 cmp_ok( $o->type( $set ), 'eq', 'set', 'type is set' );
130 ok( $o->srem( $set, 'foo' ), 'srem' );
131 ok( ! $o->srem( $set, 'foo' ), 'srem again' );
132 cmp_ok( $o->scard( $set ), '==', 0, 'scard' );
134 $o->sadd( 'test-set1', $_ ) foreach ( 'foo', 'bar', 'baz' );
135 $o->sadd( 'test-set2', $_ ) foreach ( 'foo', 'baz', 'xxx' );
137 my $inter = [ 'baz', 'foo' ];
139 is_deeply( [ $o->sinter( 'test-set1', 'test-set2' ) ], $inter, 'siter' );
141 ok( $o->sinterstore( 'test-set-inter', 'test-set1', 'test-set2' ), 'sinterstore' );
143 cmp_ok( $o->scard( 'test-set-inter' ), '==', $#$inter + 1, 'cardinality of intersection' );
145 ok( $o->quit, 'quit' );