Converted to use the intermediate keyloc so that keys work under transactions
[dbsrgits/DBM-Deep.git] / t / 05_bigarray.t
index c729c8d..93a3db9 100644 (file)
@@ -2,18 +2,16 @@
 # DBM::Deep Test
 ##
 use strict;
-use Test::More tests => 2;
+use Test::More tests => 4;
+use t::common qw( new_fh );
 
 use_ok( 'DBM::Deep' );
 
-unlink "t/test.db";
+my ($fh, $filename) = new_fh();
 my $db = DBM::Deep->new(
-       file => "t/test.db",
-       type => DBM::Deep->TYPE_ARRAY
+       file => $filename,
+       type => DBM::Deep->TYPE_ARRAY,
 );
-if ($db->error()) {
-       die "ERROR: " . $db->error();
-}
 
 ##
 # put/get many keys
@@ -27,8 +25,12 @@ for ( 0 .. $max_keys ) {
 my $count = -1;
 for ( 0 .. $max_keys ) {
     $count = $_;
-    unless( $db->get( $_ ) == $_ * 2 ) {
+    unless ( $db->get( $_ ) == $_ * 2 ) {
         last;
     };
 }
 is( $count, $max_keys, "We read $count keys" );
+
+cmp_ok( scalar(@$db), '==', $max_keys + 1, "Number of elements is correct" );
+$db->clear;
+cmp_ok( scalar(@$db), '==', 0, "Number of elements after clear() is correct" );