All tests pass except for the transaction tests under MySQL. InnoDB sucks
[dbsrgits/DBM-Deep.git] / t / 35_transaction_multiple.t
1 use strict;
2 use warnings FATAL => 'all';
3
4 use Test::More;
5 use Test::Deep;
6 use t::common qw( new_dbm );
7
8 use_ok( 'DBM::Deep' );
9
10 if ( $ENV{NO_TEST_TRANSACTIONS} ) {
11     done_testing;
12     exit;
13 }
14
15 my $dbm_factory = new_dbm(
16     locking => 1,
17     autoflush => 1,
18     num_txns  => 16,
19 );
20
21 while ( my $dbm_maker = $dbm_factory->() ) {
22     my $db1 = $dbm_maker->();
23     my $db2 = $dbm_maker->();
24     my $db3 = $dbm_maker->();
25
26     $db1->{foo} = 'bar';
27     is( $db1->{foo}, 'bar', "Before transaction, DB1's foo is bar" );
28     is( $db2->{foo}, 'bar', "Before transaction, DB2's foo is bar" );
29     is( $db3->{foo}, 'bar', "Before transaction, DB3's foo is bar" );
30
31     $db1->begin_work;
32
33     is( $db1->{foo}, 'bar', "Before transaction work, DB1's foo is bar" );
34     is( $db2->{foo}, 'bar', "Before transaction work, DB2's foo is bar" );
35     is( $db3->{foo}, 'bar', "Before transaction work, DB3's foo is bar" );
36
37     $db1->{foo} = 'bar2';
38
39     is( $db1->{foo}, 'bar2', "After DB1 foo to bar2, DB1's foo is bar2" );
40     is( $db2->{foo}, 'bar', "After DB1 foo to bar2, DB2's foo is bar" );
41     is( $db3->{foo}, 'bar', "After DB1 foo to bar2, DB3's foo is bar" );
42
43     $db1->{bar} = 'foo';
44
45     ok(  exists $db1->{bar}, "After DB1 set bar to foo, DB1's bar exists" );
46     ok( !exists $db2->{bar}, "After DB1 set bar to foo, DB2's bar doesn't exist" );
47     ok( !exists $db3->{bar}, "After DB1 set bar to foo, DB3's bar doesn't exist" );
48      
49     $db2->begin_work;
50
51     is( $db1->{foo}, 'bar2', "After DB2 transaction begin, DB1's foo is still bar2" );
52     is( $db2->{foo}, 'bar', "After DB2 transaction begin, DB2's foo is still bar" );
53     is( $db3->{foo}, 'bar', "After DB2 transaction begin, DB3's foo is still bar" );
54
55     ok(  exists $db1->{bar}, "After DB2 transaction begin, DB1's bar exists" );
56     ok( !exists $db2->{bar}, "After DB2 transaction begin, DB2's bar doesn't exist" );
57     ok( !exists $db3->{bar}, "After DB2 transaction begin, DB3's bar doesn't exist" );
58
59     $db2->{foo} = 'bar333';
60
61     is( $db1->{foo}, 'bar2', "After DB2 foo to bar2, DB1's foo is bar2" );
62     is( $db2->{foo}, 'bar333', "After DB2 foo to bar2, DB2's foo is bar333" );
63     is( $db3->{foo}, 'bar', "After DB2 foo to bar2, DB3's foo is bar" );
64
65     $db2->{bar} = 'mybar';
66
67     ok(  exists $db1->{bar}, "After DB2 set bar to mybar, DB1's bar exists" );
68     ok(  exists $db2->{bar}, "After DB2 set bar to mybar, DB2's bar exists" );
69     ok( !exists $db3->{bar}, "After DB2 set bar to mybar, DB3's bar doesn't exist" );
70
71     is( $db1->{bar}, 'foo', "DB1's bar is still foo" );
72     is( $db2->{bar}, 'mybar', "DB2's bar is now mybar" );
73
74     $db2->{mykey} = 'myval';
75
76     ok( !exists $db1->{mykey}, "After DB2 set mykey to myval, DB1's mykey doesn't exist" );
77     ok(  exists $db2->{mykey}, "After DB2 set mykey to myval, DB2's mykey exists" );
78     ok( !exists $db3->{mykey}, "After DB2 set mykey to myval, DB3's mykey doesn't exist" );
79
80     cmp_bag( [ keys %$db1 ], [qw( foo bar )], "DB1 keys correct" );
81     cmp_bag( [ keys %$db2 ], [qw( foo bar mykey )], "DB2 keys correct" );
82     cmp_bag( [ keys %$db3 ], [qw( foo )], "DB3 keys correct" );
83
84     $db1->commit;
85
86     is( $db1->{foo}, 'bar2', "After DB1 commit, DB1's foo is bar2" );
87     is( $db2->{foo}, 'bar333', "After DB1 commit, DB2's foo is bar333" );
88     is( $db3->{foo}, 'bar2', "After DB1 commit, DB3's foo is bar2" );
89
90     is( $db1->{bar}, 'foo', "DB1's bar is still foo" );
91     is( $db2->{bar}, 'mybar', "DB2's bar is still mybar" );
92     is( $db3->{bar}, 'foo', "DB3's bar is now foo" );
93
94     cmp_bag( [ keys %$db1 ], [qw( foo bar )], "DB1 keys correct" );
95     cmp_bag( [ keys %$db2 ], [qw( foo bar mykey )], "DB2 keys correct" );
96     cmp_bag( [ keys %$db3 ], [qw( foo bar )], "DB3 keys correct" );
97
98     $db2->commit;
99
100     is( $db1->{foo}, 'bar333', "After DB2 commit, DB1's foo is bar333" );
101     is( $db2->{foo}, 'bar333', "After DB2 commit, DB2's foo is bar333" );
102     is( $db3->{foo}, 'bar333', "After DB2 commit, DB3's foo is bar333" );
103
104     is( $db1->{bar}, 'mybar', "DB1's bar is now mybar" );
105     is( $db2->{bar}, 'mybar', "DB2's bar is still mybar" );
106     is( $db3->{bar}, 'mybar', "DB3's bar is now mybar" );
107
108     cmp_bag( [ keys %$db1 ], [qw( foo bar mykey )], "DB1 keys correct" );
109     cmp_bag( [ keys %$db2 ], [qw( foo bar mykey )], "DB2 keys correct" );
110     cmp_bag( [ keys %$db3 ], [qw( foo bar mykey )], "DB3 keys correct" );
111 }
112
113 done_testing;