use strict; use warnings; use Test::More; use lib "t/lib"; use SQLiteTest; my $dbh = connect_ok( PrintError => 0, RaiseError => 0 ); my $sth = $dbh->prepare('CREATE TABLE foo (f)'); $dbh->disconnect; $sth->{PrintError} = 1; # attempt to execute on inactive database handle my @warning = (); SCOPE: { local $SIG{__WARN__} = sub { push @warning, @_; return }; my $ret = eval { $sth->execute; }; # we need PrintError => 1, or warn $@ if $@; ok ! defined $ret; } is( scalar(@warning), 1, 'Got 1 warning' ); like( $warning[0], qr/attempt to execute on inactive database handle/, 'Got the expected warning', ); @warning = (); SCOPE: { local $SIG{__WARN__} = sub { push @warning, @_; return }; my $ret = eval { $sth->{NUM_OF_PARAMS}; }; # we need PrintError => 1, or warn $@ if $@; ok !$ret; } is( scalar(@warning), 1, 'Got 1 warning' ); like( $warning[0], qr/attempt to fetch on inactive database handle/, 'Got the expected warning', ); done_testing;