mirror of
https://github.com/DBD-SQLite/DBD-SQLite
synced 2025-06-07 06:08:38 -04:00
36 lines
1.1 KiB
Perl
36 lines
1.1 KiB
Perl
use strict;
|
|
use warnings;
|
|
use lib "t/lib";
|
|
use SQLiteTest;
|
|
use Test::More;
|
|
use if -d ".git", "Test::FailWarnings";
|
|
|
|
my $dbh = connect_ok( RaiseError => 1, PrintError => 0 );
|
|
eval {
|
|
$dbh->do('ssdfsdf sdf sd sdfsdfdsf sdfsdf');
|
|
};
|
|
ok($@, 'Statement 1 generated an error');
|
|
is( $DBI::err, 1, '$DBI::err ok' );
|
|
is( $DBI::errstr, 'near "ssdfsdf": syntax error', '$DBI::errstr ok' );
|
|
|
|
$dbh->do('create table testerror (a, b)');
|
|
$dbh->do('insert into testerror values (1, 2)');
|
|
$dbh->do('insert into testerror values (3, 4)');
|
|
|
|
$dbh->do('create unique index testerror_idx on testerror (a)');
|
|
eval {
|
|
$dbh->do('insert into testerror values (1, 5)');
|
|
};
|
|
ok($@, 'Statement 2 generated an error');
|
|
is( $DBI::err, 19, '$DBI::err ok' );
|
|
like( $DBI::errstr, qr/column a is not unique|UNIQUE constraint failed/, '$DBI::errstr ok' );
|
|
|
|
if ($DBD::SQLite::sqlite_version_number && $DBD::SQLite::sqlite_version_number >= 3038000) {
|
|
my $sql = 'insert testerror values (1, 5)';
|
|
eval { $dbh->do($sql) };
|
|
my $offset = $dbh->sqlite_error_offset;
|
|
ok $offset != -1, "error offset: $offset";
|
|
note substr($sql, 0, $offset) . '<*error*>' . substr($sql, $offset);
|
|
}
|
|
|
|
done_testing;
|