use DBICTest;
use Data::Dumper;
-{
- package DBICTest::ExplodingStorage::Sth;
- use strict;
- use warnings;
-
- sub execute { die "Kablammo!" }
-
- sub bind_param {}
-
- package DBICTest::ExplodingStorage;
- use strict;
- use warnings;
- use base 'DBIx::Class::Storage::DBI::SQLite';
-
- my $count = 0;
- sub sth {
- my ($self, $sql) = @_;
- return bless {}, "DBICTest::ExplodingStorage::Sth" unless $count++;
- return $self->next::method($sql);
- }
-
- sub connected {
- return 0 if $count == 1;
- return shift->next::method(@_);
- }
-}
-
my $schema = DBICTest->init_schema( sqlite_use_file => 1 );
is( ref($schema->storage), 'DBIx::Class::Storage::DBI::SQLite',
$schema->resultset('CD')->search_literal('broken +%$#$1')->all;
} qr/prepare_cached failed/, 'exception via DBI->HandleError, etc';
-bless $storage, "DBICTest::ExplodingStorage";
-$schema->storage($storage);
-
-lives_ok {
- $schema->resultset('Artist')->create({ name => "Exploding Sheep" });
-} 'Exploding $sth->execute was caught';
-
-is(1, $schema->resultset('Artist')->search({name => "Exploding Sheep" })->count,
- "And the STH was retired");
-
# testing various invocations of connect_info ([ ... ])
};
for my $type (keys %$invocations) {
+ local $ENV{DBIC_UNSAFE_AUTOCOMMIT_OK};
# we can not use a cloner portably because of the coderef
# so compare dumps instead
warnings_exist (
sub { $storage->connect_info ($invocations->{$type}{args}) },
- $invocations->{$type}{warn} || (),
+ $invocations->{$type}{warn} || [],
'Warned about ignored attributes',
);
);
}
+# make sure connection-less storages do not throw on _determine_driver
+{
+ my $s = DBICTest::Schema->connect;
+ is_deeply (
+ $s->storage->connect_info,
+ [],
+ 'Starting with no connection info',
+ );
+
+ isa_ok(
+ $s->storage->sql_maker,
+ 'DBIx::Class::SQLMaker',
+ 'Getting back an SQLMaker succesfully',
+ );
+
+ ok (! $s->storage->_driver_determined, 'Driver undetermined');
+
+ ok (! $s->storage->connected, 'Storage does not appear connected');
+
+ throws_ok {
+ $s->storage->ensure_connected
+ } qr/You did not provide any connection_info/,
+ 'sensible exception on empty conninfo connect'
+}
+
done_testing;
1;