Commit | Line | Data |
ffed8b01 |
1 | ## |
2 | # DBM::Deep Test |
3 | ## |
4 | use strict; |
535203b1 |
5 | use Test::More; |
6 | |
7 | plan skip_all => "You must set \$ENV{LONG_TESTS} to run the long tests" |
8 | unless $ENV{LONG_TESTS}; |
9 | |
86867f3a |
10 | use Test::Deep; |
fde3db1a |
11 | use t::common qw( new_fh ); |
ffed8b01 |
12 | |
2120a181 |
13 | plan tests => 9; |
535203b1 |
14 | |
40963fba |
15 | my $locked = 0; |
16 | |
ffed8b01 |
17 | use_ok( 'DBM::Deep' ); |
18 | |
eff6a245 |
19 | diag "This test can take up to a minute to run. Please be patient."; |
20 | |
fde3db1a |
21 | my ($fh, $filename) = new_fh(); |
ffed8b01 |
22 | my $db = DBM::Deep->new( |
2a81bf9e |
23 | file => $filename, |
86867f3a |
24 | type => DBM::Deep->TYPE_HASH, |
ffed8b01 |
25 | ); |
ffed8b01 |
26 | |
40963fba |
27 | $db->lock_exclusive if $locked; |
68e37b51 |
28 | |
2120a181 |
29 | $db->{foo} = {}; |
30 | my $foo = $db->{foo}; |
31 | |
ffed8b01 |
32 | ## |
33 | # put/get many keys |
34 | ## |
a4e2db58 |
35 | my $max_keys = 4000; |
36 | |
00d9bd0b |
37 | warn localtime(time) . ": before put\n"; |
ffed8b01 |
38 | for ( 0 .. $max_keys ) { |
2120a181 |
39 | $foo->put( "hello $_" => "there " . $_ * 2 ); |
ffed8b01 |
40 | } |
00d9bd0b |
41 | warn localtime(time) . ": after put\n"; |
ffed8b01 |
42 | |
30029562 |
43 | my $count = -1; |
ffed8b01 |
44 | for ( 0 .. $max_keys ) { |
30029562 |
45 | $count = $_; |
2120a181 |
46 | unless ( $foo->get( "hello $_" ) eq "there " . $_ * 2 ) { |
30029562 |
47 | last; |
48 | }; |
ffed8b01 |
49 | } |
30029562 |
50 | is( $count, $max_keys, "We read $count keys" ); |
00d9bd0b |
51 | warn localtime(time) . ": after read\n"; |
bee3661a |
52 | |
2120a181 |
53 | my @keys = sort keys %$foo; |
00d9bd0b |
54 | warn localtime(time) . ": after keys\n"; |
86867f3a |
55 | cmp_ok( scalar(@keys), '==', $max_keys + 1, "Number of keys is correct" ); |
56 | my @control = sort map { "hello $_" } 0 .. $max_keys; |
57 | cmp_deeply( \@keys, \@control, "Correct keys are there" ); |
58 | |
40963fba |
59 | warn localtime(time) . ": before exists\n"; |
2120a181 |
60 | ok( !exists $foo->{does_not_exist}, "EXISTS works on large hashes for non-existent keys" ); |
61 | is( $foo->{does_not_exist}, undef, "autovivification works on large hashes" ); |
62 | ok( exists $foo->{does_not_exist}, "EXISTS works on large hashes for newly-existent keys" ); |
63 | cmp_ok( scalar(keys %$foo), '==', $max_keys + 2, "Number of keys after autovivify is correct" ); |
64 | |
00d9bd0b |
65 | warn localtime(time) . ": before clear\n"; |
bee3661a |
66 | $db->clear; |
00d9bd0b |
67 | warn localtime(time) . ": after clear\n"; |
bee3661a |
68 | cmp_ok( scalar(keys %$db), '==', 0, "Number of keys after clear() is correct" ); |
68e37b51 |
69 | |
40963fba |
70 | $db->unlock if $locked; |