7 plan skip_all => "You must set \$ENV{LONG_TESTS} to run the long tests"
8 unless $ENV{LONG_TESTS};
11 use t::common qw( new_fh );
15 use_ok( 'DBM::Deep' );
17 diag "This test can take up to a minute to run. Please be patient.";
19 my ($fh, $filename) = new_fh();
20 my $db = DBM::Deep->new(
22 type => DBM::Deep->TYPE_HASH,
33 for ( 0 .. $max_keys ) {
34 $foo->put( "hello $_" => "there " . $_ * 2 );
38 for ( 0 .. $max_keys ) {
40 unless ( $foo->get( "hello $_" ) eq "there " . $_ * 2 ) {
44 is( $count, $max_keys, "We read $count keys" );
46 my @keys = sort keys %$foo;
47 cmp_ok( scalar(@keys), '==', $max_keys + 1, "Number of keys is correct" );
48 my @control = sort map { "hello $_" } 0 .. $max_keys;
49 cmp_deeply( \@keys, \@control, "Correct keys are there" );
51 ok( !exists $foo->{does_not_exist}, "EXISTS works on large hashes for non-existent keys" );
52 is( $foo->{does_not_exist}, undef, "autovivification works on large hashes" );
53 ok( exists $foo->{does_not_exist}, "EXISTS works on large hashes for newly-existent keys" );
54 cmp_ok( scalar(keys %$foo), '==', $max_keys + 2, "Number of keys after autovivify is correct" );
57 cmp_ok( scalar(keys %$db), '==', 0, "Number of keys after clear() is correct" );