Converted to use the intermediate keyloc so that keys work under transactions
[dbsrgits/DBM-Deep.git] / t / 09_deeparray.t
index aa7dcc7..288492b 100644 (file)
@@ -2,41 +2,43 @@
 # DBM::Deep Test
 ##
 use strict;
-use Test::More;
+use Test::More tests => 3;
+use t::common qw( new_fh );
 
-my $max_levels = 1000;
+use_ok( 'DBM::Deep' );
 
-plan tests => $max_levels + 3;
+my ($fh, $filename) = new_fh();
 
-use_ok( 'DBM::Deep' );
+my $max_levels = 1000;
 
-unlink "t/test.db";
-my $db = DBM::Deep->new(
-       file => "t/test.db",
-       type => DBM::Deep->TYPE_ARRAY,
-);
-if ($db->error()) {
-       die "ERROR: " . $db->error();
-}
+{
+    my $db = DBM::Deep->new(
+        file => $filename,
+        type => DBM::Deep->TYPE_ARRAY,
+    );
 
-$db->[0] = [];
-my $temp_db = $db->[0];
-for my $k ( 0 .. $max_levels ) {
-       $temp_db->[$k] = [];
-       $temp_db = $temp_db->[$k];
+    $db->[0] = [];
+    my $temp_db = $db->[0];
+    for my $k ( 0 .. $max_levels ) {
+        $temp_db->[$k] = [];
+        $temp_db = $temp_db->[$k];
+    }
+    $temp_db->[0] = "deepvalue";
 }
-$temp_db->[0] = "deepvalue";
-undef $temp_db;
 
-undef $db;
-$db = DBM::Deep->new(
-       file => "t/test.db",
-       type => DBM::Deep->TYPE_ARRAY,
-);
+{
+    my $db = DBM::Deep->new(
+        file => $filename,
+        type => DBM::Deep->TYPE_ARRAY,
+    );
 
-$temp_db = $db->[0];
-for my $k ( 0 .. $max_levels ) {
-    $temp_db = $temp_db->[$k];
-    isa_ok( $temp_db, 'DBM::Deep' ) || die "Whoops!";
+    my $cur_level = -1;
+    my $temp_db = $db->[0];
+    for my $k ( 0 .. $max_levels ) {
+        $cur_level = $k;
+        $temp_db = $temp_db->[$k];
+        eval { $temp_db->isa( 'DBM::Deep' ) } or last;
+    }
+    is( $cur_level, $max_levels, "We read all the way down to level $cur_level" );
+    is( $temp_db->[0], "deepvalue", "And we retrieved the value at the bottom of the ocean" );
 }
-is( $temp_db->[0], "deepvalue", "And we retrieved the value at the bottom of the ocean" );