new_dbm() added to allow for running the same tests against multiple backends without...
[dbsrgits/DBM-Deep.git] / t / 02_hash.t
CommitLineData
ffed8b01 1##
2# DBM::Deep Test
3##
4use strict;
2120a181 5use Test::More tests => 49;
ffed8b01 6use Test::Exception;
2100f2ae 7use t::common qw( new_dbm );
ffed8b01 8
9use_ok( 'DBM::Deep' );
10
2100f2ae 11my $dbm_factory = new_dbm();
12while ( my $dbm_maker = $dbm_factory->() ) {
13my $db = $dbm_maker->();
ffed8b01 14
15##
16# put/get key
17##
18$db->{key1} = "value1";
19is( $db->get("key1"), "value1", "get() works with hash assignment" );
20is( $db->fetch("key1"), "value1", "... fetch() works with hash assignment" );
21is( $db->{key1}, "value1", "... and hash-access also works" );
2120a181 22
ffed8b01 23$db->put("key2", undef);
24is( $db->get("key2"), undef, "get() works with put()" );
25is( $db->fetch("key2"), undef, "... fetch() works with put()" );
26is( $db->{key2}, undef, "... and hash-access also works" );
27
28$db->store( "key3", "value3" );
29is( $db->get("key3"), "value3", "get() works with store()" );
30is( $db->fetch("key3"), "value3", "... fetch() works with put()" );
31is( $db->{key3}, 'value3', "... and hash-access also works" );
32
2120a181 33# Verify that the keyval pairs are still correct.
34is( $db->{key1}, "value1", "Key1 is still correct" );
35is( $db->{key2}, undef, "Key2 is still correct" );
36is( $db->{key3}, 'value3', "Key3 is still correct" );
37
ffed8b01 38ok( $db->exists("key1"), "exists() function works" );
39ok( exists $db->{key2}, "exists() works against tied hash" );
40
94e8af14 41ok( !exists $db->{key4}, "exists() function works for keys that aren't there" );
42is( $db->{key4}, undef, "Autovivified key4" );
2120a181 43ok( exists $db->{key4}, "Autovivified key4 now exists" );
44
94e8af14 45delete $db->{key4};
46ok( !exists $db->{key4}, "And key4 doesn't exists anymore" );
47
2120a181 48# Keys will be done via an iterator that keeps a breadcrumb trail of the last
49# key it provided. There will also be an "edit revision number" on the
50# reference so that resetting the iterator can be done.
51#
52# Q: How do we make sure that the iterator is unique? Is it supposed to be?
53
ffed8b01 54##
55# count keys
56##
57is( scalar keys %$db, 3, "keys() works against tied hash" );
58
59##
60# step through keys
61##
62my $temphash = {};
63while ( my ($key, $value) = each %$db ) {
ea2f6d67 64 $temphash->{$key} = $value;
ffed8b01 65}
66
67is( $temphash->{key1}, 'value1', "First key copied successfully using tied interface" );
68is( $temphash->{key2}, undef, "Second key copied successfully" );
69is( $temphash->{key3}, 'value3', "Third key copied successfully" );
70
71$temphash = {};
72my $key = $db->first_key();
73while ($key) {
ea2f6d67 74 $temphash->{$key} = $db->get($key);
75 $key = $db->next_key($key);
ffed8b01 76}
77
78is( $temphash->{key1}, 'value1', "First key copied successfully using OO interface" );
79is( $temphash->{key2}, undef, "Second key copied successfully" );
80is( $temphash->{key3}, 'value3', "Third key copied successfully" );
81
82##
83# delete keys
84##
8db25060 85is( delete $db->{key2}, undef, "delete through tied inteface works" );
86is( $db->delete("key1"), 'value1', "delete through OO inteface works" );
87is( $db->{key3}, 'value3', "The other key is still there" );
ea2f6d67 88ok( !exists $db->{key1}, "key1 doesn't exist" );
89ok( !exists $db->{key2}, "key2 doesn't exist" );
ffed8b01 90
91is( scalar keys %$db, 1, "After deleting two keys, 1 remains" );
92
93##
94# delete all keys
95##
96ok( $db->clear(), "clear() returns true" );
97
98is( scalar keys %$db, 0, "After clear(), everything is removed" );
99
100##
101# replace key
102##
103$db->put("key1", "value1");
104is( $db->get("key1"), "value1", "Assignment still works" );
105
106$db->put("key1", "value2");
107is( $db->get("key1"), "value2", "... and replacement works" );
108
109$db->put("key1", "value222222222222222222222222");
ffed8b01 110is( $db->get("key1"), "value222222222222222222222222", "We set a value before closing the file" );
111
112##
113# Make sure DB still works after closing / opening
114##
115undef $db;
2100f2ae 116$db = $dbm_maker->();
ffed8b01 117is( $db->get("key1"), "value222222222222222222222222", "The value we set is still there after closure" );
118
119##
120# Make sure keys are still fetchable after replacing values
121# with smaller ones (bug found by John Cardenas, DBM::Deep 0.93)
122##
123$db->clear();
124$db->put("key1", "long value here");
125$db->put("key2", "longer value here");
126
127$db->put("key1", "short value");
128$db->put("key2", "shorter v");
129
130my $first_key = $db->first_key();
131my $next_key = $db->next_key($first_key);
132
133ok(
ea2f6d67 134 (($first_key eq "key1") || ($first_key eq "key2")) &&
135 (($next_key eq "key1") || ($next_key eq "key2")) &&
136 ($first_key ne $next_key)
ffed8b01 137 ,"keys() still works if you replace long values with shorter ones"
138);
4b603f25 139
140# Test autovivification
4b603f25 141$db->{unknown}{bar} = 1;
2120a181 142ok( $db->{unknown}, 'Autovivified hash exists' );
129ea236 143cmp_ok( $db->{unknown}{bar}, '==', 1, 'And the value stored is there' );
2120a181 144
145# Test failures
146throws_ok {
147 $db->fetch();
148} qr/Cannot use an undefined hash key/, "FETCH fails on an undefined key";
149
150throws_ok {
151 $db->fetch(undef);
152} qr/Cannot use an undefined hash key/, "FETCH fails on an undefined key";
153
154throws_ok {
155 $db->store();
156} qr/Cannot use an undefined hash key/, "STORE fails on an undefined key";
157
158throws_ok {
159 $db->store(undef, undef);
160} qr/Cannot use an undefined hash key/, "STORE fails on an undefined key";
161
162throws_ok {
163 $db->delete();
164} qr/Cannot use an undefined hash key/, "DELETE fails on an undefined key";
165
166throws_ok {
167 $db->delete(undef);
168} qr/Cannot use an undefined hash key/, "DELETE fails on an undefined key";
169
170throws_ok {
171 $db->exists();
172} qr/Cannot use an undefined hash key/, "EXISTS fails on an undefined key";
173
174throws_ok {
175 $db->exists(undef);
176} qr/Cannot use an undefined hash key/, "EXISTS fails on an undefined key";
9c87a079 177
2100f2ae 178}