5 use Test::More tests => 17;
10 my $db = DBM::Deep->new(
14 die "ERROR: " . $db->error();
17 ok( !$db->set_filter( 'floober', sub {} ), "floober isn't a value filter key" );
20 # First try store filters only (values will be unfiltered)
22 ok( $db->set_filter( 'store_key', \&my_filter_store_key ), "set the store_key filter" );
23 ok( $db->set_filter( 'store_value', \&my_filter_store_value ), "set the store_value filter" );
25 $db->{key1} = "value1";
26 $db->{key2} = "value2";
28 is($db->{key1}, "MYFILTERvalue1", "The value for key1 was filtered correctly" );
29 is($db->{key2}, "MYFILTERvalue2", "The value for key2 was filtered correctly" );
32 # Now try fetch filters as well
34 ok( $db->set_filter( 'fetch_key', \&my_filter_fetch_key ), "Set the fetch_key filter" );
35 ok( $db->set_filter( 'fetch_value', \&my_filter_fetch_value), "Set the fetch_value filter" );
37 is($db->{key1}, "value1", "Fetchfilters worked right");
38 is($db->{key2}, "value2", "Fetchfilters worked right");
41 # Try fetching keys as well as values
43 my $first_key = $db->first_key();
44 my $next_key = $db->next_key($first_key);
47 (($first_key eq "key1") || ($first_key eq "key2")) &&
48 (($next_key eq "key1") || ($next_key eq "key2"))
52 # Now clear all filters, and make sure all is unfiltered
54 ok( $db->set_filter( 'store_key', undef ), "Unset store_key filter" );
55 ok( $db->set_filter( 'store_value', undef ), "Unset store_value filter" );
56 ok( $db->set_filter( 'fetch_key', undef ), "Unset fetch_key filter" );
57 ok( $db->set_filter( 'fetch_value', undef ), "Unset fetch_value filter" );
59 is($db->{MYFILTERkey1}, "MYFILTERvalue1");
60 is($db->{MYFILTERkey2}, "MYFILTERvalue2");
62 sub my_filter_store_key { return 'MYFILTER' . $_[0]; }
63 sub my_filter_store_value { return 'MYFILTER' . $_[0]; }
65 sub my_filter_fetch_key { $_[0] =~ s/^MYFILTER//; return $_[0]; }
66 sub my_filter_fetch_value { $_[0] =~ s/^MYFILTER//; return $_[0]; }