All tests pass except for the transaction tests under MySQL. InnoDB sucks
[dbsrgits/DBM-Deep.git] / t / 41_transaction_multilevel.t
CommitLineData
2120a181 1use strict;
350896ee 2use Test::More;
2120a181 3use Test::Deep;
0e3e3555 4use t::common qw( new_dbm );
2120a181 5
6use_ok( 'DBM::Deep' );
7
4f034d8f 8if ( $ENV{NO_TEST_TRANSACTIONS} ) {
9 done_testing;
10 exit;
11}
12
0e3e3555 13my $dbm_factory = new_dbm(
14 locking => 1,
2120a181 15 autoflush => 1,
c57b19c6 16 num_txns => 2,
2120a181 17);
0e3e3555 18while ( my $dbm_maker = $dbm_factory->() ) {
19 my $db1 = $dbm_maker->();
20 my $db2 = $dbm_maker->();
2120a181 21
0e3e3555 22 $db1->{x} = { xy => { foo => 'y' } };
23 is( $db1->{x}{xy}{foo}, 'y', "Before transaction, DB1's X is Y" );
24 is( $db2->{x}{xy}{foo}, 'y', "Before transaction, DB2's X is Y" );
25
26 $db1->begin_work;
27
28 cmp_bag( [ keys %$db1 ], [qw( x )], "DB1 keys correct" );
29 cmp_bag( [ keys %$db2 ], [qw( x )], "DB2 keys correct" );
30
31 cmp_bag( [ keys %{$db1->{x}} ], [qw( xy )], "DB1->X keys correct" );
32 cmp_bag( [ keys %{$db2->{x}} ], [qw( xy )], "DB2->X keys correct" );
2120a181 33
0e3e3555 34 cmp_bag( [ keys %{$db1->{x}{xy}} ], [qw( foo )], "DB1->X->XY keys correct" );
35 cmp_bag( [ keys %{$db2->{x}{xy}} ], [qw( foo )], "DB2->X->XY keys correct" );
2120a181 36
0e3e3555 37 is( $db1->{x}{xy}{foo}, 'y', "After transaction, DB1's X is Y" );
38 is( $db2->{x}{xy}{foo}, 'y', "After transaction, DB2's X is Y" );
39
40 $db1->{x} = { yz => { bar => 30 } };
41 ok( !exists $db1->{x}{xy}, "DB1: After reassignment of X, X->XY is gone" );
42 is( $db2->{x}{xy}{foo}, 'y', "DB2: After reassignment of DB1 X, X is Y" );
43
44 cmp_bag( [ keys %{$db1->{x}} ], [qw( yz )], "DB1->X keys correct" );
45 cmp_bag( [ keys %{$db2->{x}} ], [qw( xy )], "DB2->X keys correct" );
46
47 $db1->rollback;
2120a181 48
49 cmp_bag( [ keys %$db1 ], [qw( x )], "DB1 keys correct" );
50 cmp_bag( [ keys %$db2 ], [qw( x )], "DB2 keys correct" );
51
45f047f8 52 cmp_bag( [ keys %{$db1->{x}} ], [qw( xy )], "DB1->X keys correct" );
53 cmp_bag( [ keys %{$db2->{x}} ], [qw( xy )], "DB2->X keys correct" );
2120a181 54
45f047f8 55 cmp_bag( [ keys %{$db1->{x}{xy}} ], [qw( foo )], "DB1->X->XY keys correct" );
56 cmp_bag( [ keys %{$db2->{x}{xy}} ], [qw( foo )], "DB2->X->XY keys correct" );
2120a181 57
0e3e3555 58 is( $db1->{x}{xy}{foo}, 'y', "Before transaction, DB1's X is Y" );
59 is( $db2->{x}{xy}{foo}, 'y', "Before transaction, DB2's X is Y" );
2120a181 60
0e3e3555 61 $db1->begin_work;
45f047f8 62
0e3e3555 63 cmp_bag( [ keys %$db1 ], [qw( x )], "DB1 keys correct" );
64 cmp_bag( [ keys %$db2 ], [qw( x )], "DB2 keys correct" );
2120a181 65
0e3e3555 66 cmp_bag( [ keys %{$db1->{x}} ], [qw( xy )], "DB1->X keys correct" );
67 cmp_bag( [ keys %{$db2->{x}} ], [qw( xy )], "DB2->X keys correct" );
9c87a079 68
0e3e3555 69 cmp_bag( [ keys %{$db1->{x}{xy}} ], [qw( foo )], "DB1->X->XY keys correct" );
70 cmp_bag( [ keys %{$db2->{x}{xy}} ], [qw( foo )], "DB2->X->XY keys correct" );
2120a181 71
0e3e3555 72 is( $db1->{x}{xy}{foo}, 'y', "After transaction, DB1's X is Y" );
73 is( $db2->{x}{xy}{foo}, 'y', "After transaction, DB2's X is Y" );
45f047f8 74
0e3e3555 75 $db1->{x} = { yz => { bar => 30 } };
76 ok( !exists $db1->{x}{xy}, "DB1: After reassignment of X, X->XY is gone" );
77 is( $db2->{x}{xy}{foo}, 'y', "DB2: After reassignment of DB1 X, X->YZ is Y" );
2120a181 78
0e3e3555 79 cmp_bag( [ keys %{$db1->{x}} ], [qw( yz )], "DB1->X keys correct" );
80 cmp_bag( [ keys %{$db2->{x}} ], [qw( xy )], "DB2->X keys correct" );
2120a181 81
0e3e3555 82 $db1->commit;
2120a181 83
84 cmp_bag( [ keys %$db1 ], [qw( x )], "DB1 keys correct" );
85 cmp_bag( [ keys %$db2 ], [qw( x )], "DB2 keys correct" );
86
45f047f8 87 cmp_bag( [ keys %{$db1->{x}} ], [qw( yz )], "DB1->X keys correct" );
0e3e3555 88 cmp_bag( [ keys %{$db2->{x}} ], [qw( yz )], "DB2->X keys correct" );
45f047f8 89
0e3e3555 90 cmp_bag( [ keys %{$db1->{x}{yz}} ], [qw( bar )], "DB1->X->XY keys correct" );
91 cmp_bag( [ keys %{$db2->{x}{yz}} ], [qw( bar )], "DB2->X->XY keys correct" );
92}
45f047f8 93
0e3e3555 94done_testing;