begin_work, rollback, and commit now properly lock the database
[dbsrgits/DBM-Deep.git] / t / 41_transaction_multilevel.t
1 use strict;
2 use Test::More tests => 41;
3 use Test::Deep;
4 use t::common qw( new_fh );
5
6 use_ok( 'DBM::Deep' );
7
8 my ($fh, $filename) = new_fh();
9 my $db1 = DBM::Deep->new(
10     file => $filename,
11     fh => $fh,
12     locking => 1,
13     autoflush => 1,
14     num_txns  => 2,
15 );
16 seek $db1->_get_self->_engine->storage->{fh}, 0, 0;
17
18 my $db2 = DBM::Deep->new(
19     file => $filename,
20     fh => $fh,
21     locking => 1,
22     autoflush => 1,
23     num_txns  => 2,
24 );
25
26 $db1->{x} = { xy => { foo => 'y' } };
27 is( $db1->{x}{xy}{foo}, 'y', "Before transaction, DB1's X is Y" );
28 is( $db2->{x}{xy}{foo}, 'y', "Before transaction, DB2's X is Y" );
29
30 #warn $db1->_dump_file;
31 $db1->begin_work;
32
33     cmp_bag( [ keys %$db1 ], [qw( x )], "DB1 keys correct" );
34     cmp_bag( [ keys %$db2 ], [qw( x )], "DB2 keys correct" );
35
36     cmp_bag( [ keys %{$db1->{x}} ], [qw( xy )], "DB1->X keys correct" );
37     cmp_bag( [ keys %{$db2->{x}} ], [qw( xy )], "DB2->X keys correct" );
38
39     cmp_bag( [ keys %{$db1->{x}{xy}} ], [qw( foo )], "DB1->X->XY keys correct" );
40     cmp_bag( [ keys %{$db2->{x}{xy}} ], [qw( foo )], "DB2->X->XY keys correct" );
41
42     is( $db1->{x}{xy}{foo}, 'y', "After transaction, DB1's X is Y" );
43     is( $db2->{x}{xy}{foo}, 'y', "After transaction, DB2's X is Y" );
44
45     $db1->{x} = { yz => { bar => 30 } };
46     ok( !exists $db1->{x}{xy}, "DB1: After reassignment of X, X->XY is gone" );
47     is( $db2->{x}{xy}{foo}, 'y', "DB2: After reassignment of DB1 X, X is Y" );
48
49     cmp_bag( [ keys %{$db1->{x}} ], [qw( yz )], "DB1->X keys correct" );
50     cmp_bag( [ keys %{$db2->{x}} ], [qw( xy )], "DB2->X keys correct" );
51
52 #warn $db1->_dump_file;
53 $db1->rollback;
54 __END__
55 cmp_bag( [ keys %$db1 ], [qw( x )], "DB1 keys correct" );
56 cmp_bag( [ keys %$db2 ], [qw( x )], "DB2 keys correct" );
57
58 cmp_bag( [ keys %{$db1->{x}} ], [qw( xy )], "DB1->X keys correct" );
59 cmp_bag( [ keys %{$db2->{x}} ], [qw( xy )], "DB2->X keys correct" );
60
61 cmp_bag( [ keys %{$db1->{x}{xy}} ], [qw( foo )], "DB1->X->XY keys correct" );
62 cmp_bag( [ keys %{$db2->{x}{xy}} ], [qw( foo )], "DB2->X->XY keys correct" );
63
64 is( $db1->{x}{xy}{foo}, 'y', "Before transaction, DB1's X is Y" );
65 is( $db2->{x}{xy}{foo}, 'y', "Before transaction, DB2's X is Y" );
66
67 $db1->begin_work;
68
69     cmp_bag( [ keys %$db1 ], [qw( x )], "DB1 keys correct" );
70     cmp_bag( [ keys %$db2 ], [qw( x )], "DB2 keys correct" );
71
72     cmp_bag( [ keys %{$db1->{x}} ], [qw( xy )], "DB1->X keys correct" );
73     cmp_bag( [ keys %{$db2->{x}} ], [qw( xy )], "DB2->X keys correct" );
74
75     cmp_bag( [ keys %{$db1->{x}{xy}} ], [qw( foo )], "DB1->X->XY keys correct" );
76     cmp_bag( [ keys %{$db2->{x}{xy}} ], [qw( foo )], "DB2->X->XY keys correct" );
77
78     is( $db1->{x}{xy}{foo}, 'y', "After transaction, DB1's X is Y" );
79     is( $db2->{x}{xy}{foo}, 'y', "After transaction, DB2's X is Y" );
80
81     $db1->{x} = { yz => { bar => 30 } };
82     ok( !exists $db1->{x}{xy}, "DB1: After reassignment of X, X->XY is gone" );
83     is( $db2->{x}{xy}{foo}, 'y', "DB2: After reassignment of DB1 X, X->YZ is Y" );
84
85     cmp_bag( [ keys %{$db1->{x}} ], [qw( yz )], "DB1->X keys correct" );
86     cmp_bag( [ keys %{$db2->{x}} ], [qw( xy )], "DB2->X keys correct" );
87
88 $db1->commit;
89
90 cmp_bag( [ keys %$db1 ], [qw( x )], "DB1 keys correct" );
91 cmp_bag( [ keys %$db2 ], [qw( x )], "DB2 keys correct" );
92
93 cmp_bag( [ keys %{$db1->{x}} ], [qw( yz )], "DB1->X keys correct" );
94 cmp_bag( [ keys %{$db2->{x}} ], [qw( yz )], "DB2->X keys correct" );
95
96 cmp_bag( [ keys %{$db1->{x}{yz}} ], [qw( bar )], "DB1->X->XY keys correct" );
97 cmp_bag( [ keys %{$db2->{x}{yz}} ], [qw( bar )], "DB2->X->XY keys correct" );
98
99 $db1->_get_self->_engine->storage->close( $db1->_get_self );
100 $db2->_get_self->_engine->storage->close( $db2->_get_self );