X-Git-Url: http://git.rot13.org/?p=perl-Redis.git;a=blobdiff_plain;f=t%2F01-Redis.t;h=7c9ec64fe64791741a4d8bd08b2a2566512732c2;hp=96f143cb87604c0fb26eb43c55ba46022d6bbe1d;hb=3957dcfecc1628ff65b686a2444765c4ebeef05b;hpb=5a3c0198879093b421c664c381d4bdc6a68eb1e8 diff --git a/t/01-Redis.t b/t/01-Redis.t index 96f143c..7c9ec64 100755 --- a/t/01-Redis.t +++ b/t/01-Redis.t @@ -3,7 +3,7 @@ use warnings; use strict; -use Test::More tests => 83; +use Test::More tests => 95; 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 ) }; @@ -43,6 +45,8 @@ my $key_next = 3; ok( $o->set('key-left' => $key_next), 'key-left' ); +is_deeply( [ $o->mget( 'foo', 'key-next', 'key-left' ) ], [ 'baz', 0, 3 ], 'mget' ); + my @keys; foreach ( 0 .. $key_next ) { @@ -115,7 +119,8 @@ cmp_ok( $o->lpop( $list ), 'eq', 'r1', 'lpop' ); ok( ! $o->rpop( $list ), 'rpop' ); -# Commands operating on sets + +diag "Commands operating on sets"; my $set = 'test-set'; $o->del($set); @@ -131,4 +136,32 @@ 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' );