Run the entire test suite under replicated SQLite on DBICTEST_VIA_REPLICATED
[dbsrgits/DBIx-Class.git] / t / lib / DBICTest / SQLTracerObj.pm
CommitLineData
4faaf174 1package # moar hide
2 DBICTest::SQLTracerObj;
3
4use strict;
5use warnings;
6
7use base 'DBIx::Class::Storage::Statistics';
8
8b60b921 9sub query_start {
10 my ($self, $sql, $bind) = @_;
11
12 my $op = ($sql =~ /^\s*(\S+)/)[0];
13
14 $sql =~ s/^ \s* \Q$op\E \s+ \[ .+? \]/$op/x
15 if $ENV{DBICTEST_VIA_REPLICATED};
16
17 push @{$self->{sqlbinds}}, [ $op, [ $sql, @{ $bind || [] } ] ];
18}
4faaf174 19
20# who the hell came up with this API >:(
21for my $txn (qw(begin rollback commit)) {
22 no strict 'refs';
23 *{"txn_$txn"} = sub { push @{$_[0]{sqlbinds}}, [ uc $txn => [ uc $txn ] ] };
24}
25
26sub svp_begin { push @{$_[0]{sqlbinds}}, [ SAVEPOINT => [ "SAVEPOINT $_[1]" ] ] }
27sub svp_release { push @{$_[0]{sqlbinds}}, [ RELEASE_SAVEPOINT => [ "RELEASE $_[1]" ] ] }
28sub svp_rollback { push @{$_[0]{sqlbinds}}, [ ROLLBACK_TO_SAVEPOINT => [ "ROLLBACK TO $_[1]" ] ] }
29
301;