Refactored to _descend to fix the recursion bug
[dbsrgits/DBM-Deep.git] / t / 09_deeparray.t
CommitLineData
ffed8b01 1use strict;
0e3e3555 2use warnings FATAL => 'all';
3
535203b1 4use Test::More;
5
6plan skip_all => "You must set \$ENV{LONG_TESTS} to run the long tests"
7 unless $ENV{LONG_TESTS};
8
0e3e3555 9use t::common qw( new_dbm );
ffed8b01 10
0e3e3555 11diag "This test can take up to several minutes to run. Please be patient.";
13ff93d5 12
2a81bf9e 13use_ok( 'DBM::Deep' );
ffed8b01 14
0e3e3555 15my $dbm_factory = new_dbm( type => DBM::Deep->TYPE_ARRAY );
16while ( my $dbm_maker = $dbm_factory->() ) {
17 my $max_levels = 1000;
ffed8b01 18
0e3e3555 19 {
20 my $db = $dbm_maker->();
ffed8b01 21
0e3e3555 22 $db->[0] = [];
23 my $temp_db = $db->[0];
24 for my $k ( 0 .. $max_levels ) {
25 $temp_db->[$k] = [];
26 $temp_db = $temp_db->[$k];
27 }
28 $temp_db->[0] = "deepvalue";
2a81bf9e 29 }
ffed8b01 30
0e3e3555 31 {
32 my $db = $dbm_maker->();
33
34 my $cur_level = -1;
35 my $temp_db = $db->[0];
36 for my $k ( 0 .. $max_levels ) {
37 $cur_level = $k;
38 $temp_db = $temp_db->[$k];
39 eval { $temp_db->isa( 'DBM::Deep' ) } or last;
40 }
41 is( $cur_level, $max_levels, "We read all the way down to level $cur_level" );
42 is( $temp_db->[0], "deepvalue", "And we retrieved the value at the bottom of the ocean" );
2a81bf9e 43 }
ffed8b01 44}
0e3e3555 45done_testing;