X-Git-Url: http://git.rot13.org/?p=perl-Redis.git;a=blobdiff_plain;f=t%2F01-Redis.t;h=85e9c9372cf77d30a499077b94a89eda97af24c2;hp=714c898c80315fe5231ec500f0afd42d8eeae2af;hb=b8ff672c10960796e47cb49ff17473f2bb136375;hpb=d83b94045bd5ac5764d26319e03d1ee6c4266e63 diff --git a/t/01-Redis.t b/t/01-Redis.t index 714c898..85e9c93 100755 --- a/t/01-Redis.t +++ b/t/01-Redis.t @@ -3,7 +3,7 @@ use warnings; use strict; -use Test::More tests => 62; +use Test::More tests => 94; use lib 'lib'; @@ -15,6 +15,8 @@ ok( my $o = Redis->new(), 'new' ); ok( $o->ping, 'ping' ); +diag "Commands operating on string values"; + ok( $o->set( foo => 'bar' ), 'set foo => bar' ); eval { $o->set( foo => 'bar', 1 ) }; @@ -26,6 +28,12 @@ ok( $o->set( foo => 'baz' ), 'set foo => baz' ); cmp_ok( $o->get( 'foo' ), 'eq', 'baz', 'get foo = baz' ); +ok( $o->set( 'test-undef' => 42 ), 'set test-undef' ); +ok( $o->set( 'test-undef' => undef ), 'set undef' ); +ok( ! defined $o->get( 'test-undef' ), 'get undef' ); +diag $o->exists( 'test-undef' ); +ok( $o->exists( 'test-undef' ), 'exists undef' ); + $o->del('non-existant'); ok( ! $o->exists( 'non-existant' ), 'exists non-existant' ); @@ -88,11 +96,70 @@ ok( $o->rpush( $list => "r$_" ), 'rpush' ) foreach ( 1 .. 3 ); ok( $o->lpush( $list => "l$_" ), 'lpush' ) foreach ( 1 .. 2 ); +cmp_ok( $o->type($list), 'eq', 'list', 'type' ); cmp_ok( $o->llen($list), '==', 5, 'llen' ); is_deeply( [ $o->lrange( $list, 0, 1 ) ], [ 'l2', 'l1' ], 'lrange' ); -ok( $o->ltrim( $list, 2, 3 ), 'ltrim' ); +ok( $o->ltrim( $list, 1, 2 ), 'ltrim' ); cmp_ok( $o->llen($list), '==', 2, 'llen after ltrim' ); +cmp_ok( $o->lindex( $list, 0 ), 'eq', 'l1', 'lindex' ); +cmp_ok( $o->lindex( $list, 1 ), 'eq', 'r1', 'lindex' ); + +ok( $o->lset( $list, 0, 'foo' ), 'lset' ); +cmp_ok( $o->lindex( $list, 0 ), 'eq', 'foo', 'verified' ); + +ok( $o->lrem( $list, 1, 'foo' ), 'lrem' ); +cmp_ok( $o->llen( $list ), '==', 1, 'llen after lrem' ); + +cmp_ok( $o->lpop( $list ), 'eq', 'r1', 'lpop' ); + +ok( ! $o->rpop( $list ), 'rpop' ); + + +diag "Commands operating on sets"; + +my $set = 'test-set'; +$o->del($set); + +ok( $o->sadd( $set, 'foo' ), 'sadd' ); +ok( ! $o->sadd( $set, 'foo' ), 'sadd' ); +cmp_ok( $o->scard( $set ), '==', 1, 'scard' ); +ok( $o->sismember( $set, 'foo' ), 'sismember' ); + +cmp_ok( $o->type( $set ), 'eq', 'set', 'type is set' ); + +ok( $o->srem( $set, 'foo' ), 'srem' ); +ok( ! $o->srem( $set, 'foo' ), 'srem again' ); +cmp_ok( $o->scard( $set ), '==', 0, 'scard' ); + +$o->sadd( 'test-set1', $_ ) foreach ( 'foo', 'bar', 'baz' ); +$o->sadd( 'test-set2', $_ ) foreach ( 'foo', 'baz', 'xxx' ); + +my $inter = [ 'baz', 'foo' ]; + +is_deeply( [ $o->sinter( 'test-set1', 'test-set2' ) ], $inter, 'siter' ); + +ok( $o->sinterstore( 'test-set-inter', 'test-set1', 'test-set2' ), 'sinterstore' ); + +cmp_ok( $o->scard( 'test-set-inter' ), '==', $#$inter + 1, 'cardinality of intersection' ); + + +diag "Multiple databases handling commands"; + +ok( $o->select( 1 ), 'select' ); +ok( $o->select( 0 ), 'select' ); + +ok( $o->move( 'foo', 1 ), 'move' ); +ok( ! $o->exists( 'foo' ), 'gone' ); + +ok( $o->select( 1 ), 'select' ); +ok( $o->exists( 'foo' ), 'exists' ); + +ok( $o->flushdb, 'flushdb' ); +cmp_ok( $o->dbsize, '==', 0, 'empty' ); + +diag "Connection handling"; + ok( $o->quit, 'quit' );