my $schema = DBICTest->init_schema( sqlite_use_file => 1 );
-is( ref($schema->storage), 'DBIx::Class::Storage::DBI::SQLite',
- 'Storage reblessed correctly into DBIx::Class::Storage::DBI::SQLite' );
-
my $storage = $schema->storage;
-$storage->ensure_connected;
+
+is(
+ ref($storage),
+ 'DBIx::Class::Storage::DBI::SQLite',
+ 'Storage reblessed correctly into DBIx::Class::Storage::DBI::SQLite'
+) unless $ENV{DBICTEST_VIA_REPLICATED};
throws_ok {
$schema->storage->throw_exception('test_exception_42');
} qr/prepare_cached failed/, 'exception via DBI->HandleError, etc';
+# make sure repeated disconnection works
+{
+ my $fn = DBICTest->_sqlite_dbfilename;
+
+ lives_ok {
+ $schema->storage->ensure_connected;
+ my $dbh = $schema->storage->dbh;
+ $schema->storage->disconnect for 1,2;
+ unlink $fn;
+ $dbh->disconnect;
+ };
+
+ lives_ok {
+ $schema->storage->ensure_connected;
+ $schema->storage->disconnect for 1,2;
+ unlink $fn;
+ $schema->storage->disconnect for 1,2;
+ };
+
+ lives_ok {
+ $schema->storage->ensure_connected;
+ $schema->storage->_dbh->disconnect;
+ unlink $fn;
+ $schema->storage->disconnect for 1,2;
+ };
+}
+
+
# testing various invocations of connect_info ([ ... ])
my $coderef = sub { 42 };
skip 'Subtest relies on being connected to SQLite', 1
if $env_dsn and $env_dsn !~ /\:SQLite\:/;
- local $ENV{DBI_DSN} = $env_dsn;
+ local $ENV{DBI_DSN} = $env_dsn || '';
my $s = DBICTest::Schema->connect();
is_deeply (
my $sm = $s->storage->sql_maker;
- ok (! $s->storage->connected, 'Storage does not appear connected (SQLite determined by DSN-only analysis)');
+ ok (! $s->storage->connected, 'Storage does not appear connected after SQLMaker instance is taken');
if ($env_dsn) {
isa_ok($sm, 'DBIx::Class::SQLMaker');