Standardized test incantations
[dbsrgits/DBM-Deep.git] / t / 07_locking.t
CommitLineData
ffed8b01 1##
2# DBM::Deep Test
3##
4use strict;
2120a181 5use Test::More tests => 5;
6use Test::Exception;
fde3db1a 7use t::common qw( new_fh );
ffed8b01 8
bd773913 9use_ok( 'DBM::Deep' );
ffed8b01 10
fde3db1a 11my ($fh, $filename) = new_fh();
bd773913 12my $db = DBM::Deep->new(
45f047f8 13 file => $filename,
45f047f8 14 locking => 1,
ffed8b01 15);
ffed8b01 16
2120a181 17lives_ok {
18 $db->unlock;
19} "Can call unlock on an unlocked DB.";
20
ffed8b01 21##
22# basic put/get
23##
24$db->{key1} = "value1";
bd773913 25is( $db->{key1}, "value1", "key1 is set" );
ffed8b01 26
25369e06 27$db->{key2} = [ 1 .. 3 ];
24012a84 28is( $db->{key2}[1], 2, "The value is set properly" );
25369e06 29
ffed8b01 30##
31# explicit lock
32##
5c0756fc 33$db->lock_exclusive;
ffed8b01 34$db->{key1} = "value2";
35$db->unlock();
bd773913 36is( $db->{key1}, "value2", "key1 is overridden" );