summaryrefslogtreecommitdiff
path: root/t/07_error.t
diff options
context:
space:
mode:
Diffstat (limited to 't/07_error.t')
-rw-r--r--t/07_error.t31
1 files changed, 31 insertions, 0 deletions
diff --git a/t/07_error.t b/t/07_error.t
new file mode 100644
index 0000000..68ea9ca
--- /dev/null
+++ b/t/07_error.t
@@ -0,0 +1,31 @@
+#!/usr/bin/perl
+
+use strict;
+BEGIN {
+ $| = 1;
+ $^W = 1;
+}
+
+use t::lib::Test;
+use Test::More tests => 8;
+use Test::NoWarnings;
+
+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/, '$DBI::errstr ok' );