2 DBICTest::SQLTracerObj;
7 use base 'DBIx::Class::Storage::Statistics';
10 my ($self, $sql, $bind) = @_;
12 my $op = ($sql =~ /^\s*(\S+)/)[0];
14 $sql =~ s/^ \s* \Q$op\E \s+ \[ .+? \]/$op/x
15 if $ENV{DBICTEST_VIA_REPLICATED};
17 push @{$self->{sqlbinds}}, [ $op, [ $sql, @{ $bind || [] } ] ];
20 # who the hell came up with this API >:(
21 for my $txn (qw(begin rollback commit)) {
23 *{"txn_$txn"} = sub { push @{$_[0]{sqlbinds}}, [ uc $txn => [ uc $txn ] ] };
26 sub svp_begin { push @{$_[0]{sqlbinds}}, [ SAVEPOINT => [ "SAVEPOINT $_[1]" ] ] }
27 sub svp_release { push @{$_[0]{sqlbinds}}, [ RELEASE_SAVEPOINT => [ "RELEASE $_[1]" ] ] }
28 sub svp_rollback { push @{$_[0]{sqlbinds}}, [ ROLLBACK_TO_SAVEPOINT => [ "ROLLBACK TO $_[1]" ] ] }