X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Fstorage%2Fbase.t;h=ab7e89ccf3fbffedfc23e36b152de2e3e90f51f0;hb=410a6bced6035333d48c2b92ad968a722a0a0b09;hp=c8a0bba76f46764e649f8b1b44f350bd76c9bcc1;hpb=2dc8d9618fd296ecdd4484d3686832de0592e747;p=dbsrgits%2FDBIx-Class-Historic.git diff --git a/t/storage/base.t b/t/storage/base.t index c8a0bba..ab7e89c 100644 --- a/t/storage/base.t +++ b/t/storage/base.t @@ -1,40 +1,13 @@ use strict; -use warnings; +use warnings; use Test::More; +use Test::Warn; +use Test::Exception; use lib qw(t/lib); 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(@_); - } -} - -plan tests => 17; - my $schema = DBICTest->init_schema( sqlite_use_file => 1 ); is( ref($schema->storage), 'DBIx::Class::Storage::DBI::SQLite', @@ -43,27 +16,13 @@ is( ref($schema->storage), 'DBIx::Class::Storage::DBI::SQLite', my $storage = $schema->storage; $storage->ensure_connected; -eval { +throws_ok { $schema->storage->throw_exception('test_exception_42'); -}; -like($@, qr/\btest_exception_42\b/, 'basic exception'); +} qr/\btest_exception_42\b/, 'basic exception'; -eval { +throws_ok { $schema->resultset('CD')->search_literal('broken +%$#$1')->all; -}; -like($@, qr/prepare_cached failed/, 'exception via DBI->HandleError, etc'); - -bless $storage, "DBICTest::ExplodingStorage"; -$schema->storage($storage); - -eval { - $schema->resultset('Artist')->create({ name => "Exploding Sheep" }); -}; - -is($@, "", "Exploding \$sth->execute was caught"); - -is(1, $schema->resultset('Artist')->search({name => "Exploding Sheep" })->count, - "And the STH was retired"); +} qr/prepare_cached failed/, 'exception via DBI->HandleError, etc'; # testing various invocations of connect_info ([ ... ]) @@ -144,21 +103,39 @@ my $invocations = { AutoCommit => 0, }, ], + warn => qr/\QYou provided explicit AutoCommit => 0 in your connection_info/, + }, + 'connect_info ([ \%attr_with_coderef ])' => { + args => [ { + dbh_maker => $coderef, + dsn => 'blah', + user => 'bleh', + on_connect_do => [qw/a b c/], + on_disconnect_do => [qw/d e f/], + } ], + dbi_connect_info => [ + $coderef + ], + warn => qr/Attribute\(s\) 'dsn', 'user' in connect_info were ignored/, }, }; 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 local $Data::Dumper::Sortkeys = 1; my $arg_dump = Dumper ($invocations->{$type}{args}); - $storage->connect_info ($invocations->{$type}{args}); + warnings_exist ( + sub { $storage->connect_info ($invocations->{$type}{args}) }, + $invocations->{$type}{warn} || [], + 'Warned about ignored attributes', + ); is ($arg_dump, Dumper ($invocations->{$type}{args}), "$type didn't modify passed arguments"); - is_deeply ($storage->_dbi_connect_info, $invocations->{$type}{dbi_connect_info}, "$type produced correct _dbi_connect_info"); ok ( (not $storage->auto_savepoint and not $storage->unsafe), "$type correctly ignored extra hashref"); @@ -169,4 +146,34 @@ for my $type (keys %$invocations) { ); } +# make sure connection-less storages do not throw on _determine_driver +{ + local $ENV{DBI_DSN}; + local $ENV{DBI_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;