1
0
Fork 0
mirror of https://github.com/DBD-SQLite/DBD-SQLite synced 2025-06-07 14:19:10 -04:00
DBD-SQLite-SQLcipher/t/32_inactive_error.t
Kenichi Ishigaki 11c2f4e70f use warnings
2019-01-02 21:17:30 +09:00

44 lines
964 B
Perl

use strict;
use warnings;
use Test::More tests => 7;
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',
);