66b901a6f45789305c8249552f942765bdf09f0c
[dbsrgits/DBIx-Class.git] / t / storage / error.t
1 use strict;
2 use warnings;
3
4 use Test::More;
5 use Test::Warn;
6 use Test::Exception;
7
8 use lib qw(t/lib);
9 use_ok( 'DBICTest' );
10 use_ok( 'DBICTest::Schema' );
11
12 my $schema = DBICTest->init_schema;
13
14 my $e_start = quotemeta('DBIx::Class::');
15
16 warnings_are ( sub {
17   throws_ok (
18     sub {
19       $schema->resultset('CD')->create({ title => 'vacation in antarctica' })
20     },
21     qr/$e_start.+constraint failed.+NULL/s
22   );  # as opposed to some other error
23 }, [], 'No warnings besides exception' );
24
25 my $dbh = $schema->storage->dbh;
26
27 throws_ok (
28   sub {
29     $dbh->do ('INSERT INTO nonexistent_table VALUES (1)')
30   },
31   qr/$e_start.+DBI Exception.+no such table/,
32   'DBI exceptions properly handled by dbic-installed callback'
33 );
34
35 # This usage is a bit unusual but it was actually seen in the wild
36 # destruction of everything except the $dbh should use the proper
37 # exception fallback:
38
39 # FIXME
40 # These explicit disconnections on loss of $storage don't seem
41 # right... disable it here for the test anyway
42 {
43   local $dbh->{Callbacks}{disconnect} = sub { 1 };
44
45   undef ($schema);
46   throws_ok (
47     sub {
48       $dbh->do ('INSERT INTO nonexistent_table VALUES (1)')
49     },
50     qr/DBI Exception.+unhandled by DBIC.+no such table/,
51     'callback works after $schema is gone'
52   );
53 }
54
55 done_testing;