--- t/10-xs.t 2008/08/17 23:53:11 10 +++ t/10-xs.t 2008/08/18 18:55:38 23 @@ -5,7 +5,7 @@ use blib; -use Test::More tests => 11; +use Test::More tests => 28; use Test::Exception; use Data::Dump qw/dump/; @@ -13,6 +13,8 @@ use_ok( 'Search::TokyoDystopia' ); } +my $path = 'casket'; + cmp_ok( $Search::TokyoDystopia::debug, '==', 0, '$debug' ); cmp_ok( tcidberrmsg(0), 'eq', 'success', 'tcidberrmsg' ); @@ -25,12 +27,46 @@ is( tcidbecode( $idb ), 0, 'tcidbecode' ); -ok( tcidbtune( $idb, 0, 0, 0, IDBTLARGE || IDBTDEFLATE ), 'tcidbtune' ); +ok( tcidbtune( $idb, 0, 0, 0, IDBTLARGE | IDBTDEFLATE ), 'tcidbtune' ); ok( tcidbsetcache( $idb, 0, 0 ), 'tcidbsetcache' ); ok( tcidbsetfwmmax( $idb, 0 ), 'tcidbsetfwmmax' ); -my $path = '/tmp/casket'; -ok( tcidbopen( $idb, $path, IDBOWRITER || IDBOCREAT ), "tcidbopen $path" ); +ok( tcidbopen( $idb, $path, IDBOWRITER | IDBOCREAT | IDBOTRUNC ), "tcidbopen $path" ); + +ok( tcidbclose( $idb ), 'tcidbclose' ); + +ok( tcidbopen( $idb, $path, IDBOWRITER | IDBOCREAT ), "tcidbopen $path again" ); + +ok( tcidbput( $idb, 1, 'foobar' ), 'tcidbput' ); + +ok( tcidbout( $idb, 1, ), 'tcidbout' ); + +ok( tcidbput( $idb, 42, 'some data' ), 'tcidbput again' ); +is( tcidbget( $idb, 42 ), 'some data', 'tcidbget' ); +ok( ! tcidbget( $idb, 1 ), 'tcidbget non-existing' ); + +is_deeply( tcidbsearch( $idb, 'some', IDBSSUBSTR ), [ 42 ], 'tcidbsearch' ); +ok( tcidbput( $idb, 65536, 'some more data' ), 'tcidbput more data' ); +is_deeply( tcidbsearch( $idb, 'some', IDBSSUBSTR ), [ 42, 65536 ], 'tcidbsearch' ); + +is_deeply( tcidbsearch2( $idb, 'some' ), [ 42, 65536 ], 'tcidbsearch2' ); + +ok( tcidbiterinit( $idb ), 'tcidbiterinit' ); + +my @ids; + +while ( my $id = tcidbiternext( $idb ) ) { + ok( $id, "tcidbiternext $id" ); + push @ids, $id; +} + +# order is not defined, so we need to sort it +is_deeply( [ sort @ids ], [ 42, 65536 ], 'all records' ); + +ok( tcidbsync( $idb ), 'tcidbsync' ); + +ok( tcidboptimize( $idb ), 'tcidboptimize' ); +diag tcidberrmsg( tcidbecode( $idb ) );