X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Fstorage%2Fon_connect_do.t;h=6fccbb1ae30fe886d5beed202205018e5d4e93e2;hb=e93fb36285f265657d67a1ee7e8a5859aab2b27c;hp=ca13d6c3e60e6be9bce85489bcde6eb414dc166d;hpb=7c9aa29f7bbd173aa2624880f954057b126beb25;p=dbsrgits%2FDBIx-Class.git diff --git a/t/storage/on_connect_do.t b/t/storage/on_connect_do.t index ca13d6c..6fccbb1 100644 --- a/t/storage/on_connect_do.t +++ b/t/storage/on_connect_do.t @@ -1,10 +1,17 @@ use strict; use warnings; -use Test::More tests => 12; +BEGIN { $ENV{DBICTEST_VIA_REPLICATED} = 0 } + +# !!! do not replace this with done_testing - tests reside in the callbacks +# !!! number of calls is important +use Test::More tests => 13; +# !!! +use Test::Warn; +use Test::Exception; use lib qw(t/lib); -use base 'DBICTest'; +use DBICTest; require DBI; @@ -29,8 +36,13 @@ is_deeply ( $schema->storage->disconnect; ok $schema->connection( - sub { DBI->connect(DBICTest->_database) }, + sub { DBI->connect(DBICTest->_database, undef, undef, { AutoCommit => 0 }) }, { + # DO NOT REMOVE - this seems like an unrelated piece of info, + # but is in fact a test for a bug where setting an accessor-via-option + # would trigger an early connect *bypassing* the on_connect_* pieces + cursor_class => 'DBIx::Class::Storage::Cursor', + on_connect_do => [ 'CREATE TABLE TEST_empty (id INTEGER)', [ 'INSERT INTO TEST_empty VALUES (?)', {}, 2 ], @@ -41,13 +53,19 @@ ok $schema->connection( }, ), 'connection()'; +warnings_exist { + $schema->storage->ensure_connected +} qr/The 'RaiseError' of the externally supplied DBI handle is set to false/, +'Warning on clobbered AutoCommit => 0 fired'; + is_deeply ( $schema->storage->dbh->selectall_arrayref('SELECT * FROM TEST_empty'), [ [ 2 ], [ 3 ], [ 7 ] ], 'on_connect_do() worked' ); -eval { $schema->storage->dbh->do('SELECT 1 FROM TEST_nonexistent'); }; -ok $@, 'Searching for nonexistent table dies'; +dies_ok { + $schema->storage->dbh->do('SELECT 1 FROM TEST_nonexistent'); +} 'Searching for nonexistent table dies'; $schema->storage->disconnect(); @@ -66,6 +84,7 @@ $schema->storage->disconnect(); ok $disconnected, 'on_disconnect_do() called after disconnect()'; isa_ok($cb_args[0], 'DBIx::Class::Storage', 'first arg to on_connect_do hook'); +@cb_args = (); sub check_exists { my $storage = shift; @@ -75,8 +94,10 @@ sub check_exists { sub check_dropped { my $storage = shift; - eval { $storage->dbh->do('SELECT 1 FROM TEST_empty'); }; - ok $@, 'Reading from dropped table fails'; + + dies_ok { + $storage->dbh->do('SELECT 1 FROM TEST_empty'); + } 'Reading from dropped table fails'; return; }