File: 35_transaction_multiple.t

package info (click to toggle)
libdbm-deep-perl 2.0008-1
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 884 kB
  • sloc: perl: 7,383; sql: 36
file content (108 lines) | stat: -rw-r--r-- 4,376 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
use strict;
use warnings FATAL => 'all';

use Test::More;
use Test::Deep;
use t::common qw( new_dbm );

use_ok( 'DBM::Deep' );

my $dbm_factory = new_dbm(
    locking => 1,
    autoflush => 1,
    num_txns  => 16,
);
while ( my $dbm_maker = $dbm_factory->() ) {
    my $db1 = $dbm_maker->();
    next unless $db1->supports( 'transactions' );
    my $db2 = $dbm_maker->();
    my $db3 = $dbm_maker->();

    $db1->{foo} = 'bar';
    is( $db1->{foo}, 'bar', "Before transaction, DB1's foo is bar" );
    is( $db2->{foo}, 'bar', "Before transaction, DB2's foo is bar" );
    is( $db3->{foo}, 'bar', "Before transaction, DB3's foo is bar" );

    $db1->begin_work;

    is( $db1->{foo}, 'bar', "Before transaction work, DB1's foo is bar" );
    is( $db2->{foo}, 'bar', "Before transaction work, DB2's foo is bar" );
    is( $db3->{foo}, 'bar', "Before transaction work, DB3's foo is bar" );

    $db1->{foo} = 'bar2';

    is( $db1->{foo}, 'bar2', "After DB1 foo to bar2, DB1's foo is bar2" );
    is( $db2->{foo}, 'bar', "After DB1 foo to bar2, DB2's foo is bar" );
    is( $db3->{foo}, 'bar', "After DB1 foo to bar2, DB3's foo is bar" );

    $db1->{bar} = 'foo';

    ok(  exists $db1->{bar}, "After DB1 set bar to foo, DB1's bar exists" );
    ok( !exists $db2->{bar}, "After DB1 set bar to foo, DB2's bar doesn't exist" );
    ok( !exists $db3->{bar}, "After DB1 set bar to foo, DB3's bar doesn't exist" );
     
    $db2->begin_work;

    is( $db1->{foo}, 'bar2', "After DB2 transaction begin, DB1's foo is still bar2" );
    is( $db2->{foo}, 'bar', "After DB2 transaction begin, DB2's foo is still bar" );
    is( $db3->{foo}, 'bar', "After DB2 transaction begin, DB3's foo is still bar" );

    ok(  exists $db1->{bar}, "After DB2 transaction begin, DB1's bar exists" );
    ok( !exists $db2->{bar}, "After DB2 transaction begin, DB2's bar doesn't exist" );
    ok( !exists $db3->{bar}, "After DB2 transaction begin, DB3's bar doesn't exist" );

    $db2->{foo} = 'bar333';

    is( $db1->{foo}, 'bar2', "After DB2 foo to bar2, DB1's foo is bar2" );
    is( $db2->{foo}, 'bar333', "After DB2 foo to bar2, DB2's foo is bar333" );
    is( $db3->{foo}, 'bar', "After DB2 foo to bar2, DB3's foo is bar" );

    $db2->{bar} = 'mybar';

    ok(  exists $db1->{bar}, "After DB2 set bar to mybar, DB1's bar exists" );
    ok(  exists $db2->{bar}, "After DB2 set bar to mybar, DB2's bar exists" );
    ok( !exists $db3->{bar}, "After DB2 set bar to mybar, DB3's bar doesn't exist" );

    is( $db1->{bar}, 'foo', "DB1's bar is still foo" );
    is( $db2->{bar}, 'mybar', "DB2's bar is now mybar" );

    $db2->{mykey} = 'myval';

    ok( !exists $db1->{mykey}, "After DB2 set mykey to myval, DB1's mykey doesn't exist" );
    ok(  exists $db2->{mykey}, "After DB2 set mykey to myval, DB2's mykey exists" );
    ok( !exists $db3->{mykey}, "After DB2 set mykey to myval, DB3's mykey doesn't exist" );

    cmp_bag( [ keys %$db1 ], [qw( foo bar )], "DB1 keys correct" );
    cmp_bag( [ keys %$db2 ], [qw( foo bar mykey )], "DB2 keys correct" );
    cmp_bag( [ keys %$db3 ], [qw( foo )], "DB3 keys correct" );

    $db1->commit;

    is( $db1->{foo}, 'bar2', "After DB1 commit, DB1's foo is bar2" );
    is( $db2->{foo}, 'bar333', "After DB1 commit, DB2's foo is bar333" );
    is( $db3->{foo}, 'bar2', "After DB1 commit, DB3's foo is bar2" );

    is( $db1->{bar}, 'foo', "DB1's bar is still foo" );
    is( $db2->{bar}, 'mybar', "DB2's bar is still mybar" );
    is( $db3->{bar}, 'foo', "DB3's bar is now foo" );

    cmp_bag( [ keys %$db1 ], [qw( foo bar )], "DB1 keys correct" );
    cmp_bag( [ keys %$db2 ], [qw( foo bar mykey )], "DB2 keys correct" );
    cmp_bag( [ keys %$db3 ], [qw( foo bar )], "DB3 keys correct" );

    $db2->commit;

    is( $db1->{foo}, 'bar333', "After DB2 commit, DB1's foo is bar333" );
    is( $db2->{foo}, 'bar333', "After DB2 commit, DB2's foo is bar333" );
    is( $db3->{foo}, 'bar333', "After DB2 commit, DB3's foo is bar333" );

    is( $db1->{bar}, 'mybar', "DB1's bar is now mybar" );
    is( $db2->{bar}, 'mybar', "DB2's bar is still mybar" );
    is( $db3->{bar}, 'mybar', "DB3's bar is now mybar" );

    cmp_bag( [ keys %$db1 ], [qw( foo bar mykey )], "DB1 keys correct" );
    cmp_bag( [ keys %$db2 ], [qw( foo bar mykey )], "DB2 keys correct" );
    cmp_bag( [ keys %$db3 ], [qw( foo bar mykey )], "DB3 keys correct" );
}

done_testing;