X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2F20invocations.t;h=fe52379601dec013c9c9054b5a606eb9631cd43c;hb=772b79e2a50a9f211b9e8a148a85e89225aeb68e;hp=3c59d9d8e321b6df95e5217fb3e106f089700ed1;hpb=fdd8ff1628c48e9c540958039b5bc1f490af8d88;p=dbsrgits%2FDBIx-Class-Schema-Loader.git diff --git a/t/20invocations.t b/t/20invocations.t index 3c59d9d..fe52379 100644 --- a/t/20invocations.t +++ b/t/20invocations.t @@ -28,6 +28,7 @@ my @invocations = ( 'hardcode' => sub { package DBICTest::Schema::5; use base qw/ DBIx::Class::Schema::Loader /; + __PACKAGE__->naming('current'); __PACKAGE__->connection($make_dbictest_db::dsn); __PACKAGE__; }, @@ -35,13 +36,14 @@ my @invocations = ( package DBICTest::Schema::6; use base qw/ DBIx::Class::Schema::Loader /; __PACKAGE__->loader_options(); + __PACKAGE__->naming('current'); __PACKAGE__->connect($make_dbictest_db::dsn); }, 'make_schema_at' => sub { use DBIx::Class::Schema::Loader qw/ make_schema_at /; make_schema_at( 'DBICTest::Schema::7', - { really_erase_my_files => 1 }, + { really_erase_my_files => 1, naming => 'current' }, [ $make_dbictest_db::dsn ], ); DBICTest::Schema::7->clone; @@ -49,6 +51,7 @@ my @invocations = ( 'embedded_options' => sub { package DBICTest::Schema::8; use base qw/ DBIx::Class::Schema::Loader /; + __PACKAGE__->naming('current'); __PACKAGE__->connect( $make_dbictest_db::dsn, { loader_options => { really_erase_my_files => 1 } } @@ -57,6 +60,7 @@ my @invocations = ( 'embedded_options_in_attrs' => sub { package DBICTest::Schema::9; use base qw/ DBIx::Class::Schema::Loader /; + __PACKAGE__->naming('current'); __PACKAGE__->connect( $make_dbictest_db::dsn, undef, @@ -71,7 +75,10 @@ my @invocations = ( { }, [ $make_dbictest_db::dsn, - { loader_options => { really_erase_my_files => 1 } }, + { loader_options => { + really_erase_my_files => 1, + naming => 'current' + } }, ], ); "DBICTest::Schema::10"; @@ -79,7 +86,10 @@ my @invocations = ( 'almost_embedded' => sub { package DBICTest::Schema::11; use base qw/ DBIx::Class::Schema::Loader /; - __PACKAGE__->loader_options( really_erase_my_files => 1 ); + __PACKAGE__->loader_options( + really_erase_my_files => 1, + naming => 'current' + ); __PACKAGE__->connect( $make_dbictest_db::dsn, undef, undef, { AutoCommit => 1 } @@ -89,18 +99,56 @@ my @invocations = ( use DBIx::Class::Schema::Loader; DBIx::Class::Schema::Loader::make_schema_at( 'DBICTest::Schema::12', - { really_erase_my_files => 1 }, + { really_erase_my_files => 1, naming => 'current' }, [ $make_dbictest_db::dsn ], ); DBICTest::Schema::12->clone; - } + }, + 'no_skip_load_external' => sub { + # By default we should pull in t/lib/DBICTest/Schema/13/Foo.pm $skip_me since t/lib is in @INC + use DBIx::Class::Schema::Loader; + DBIx::Class::Schema::Loader::make_schema_at( + 'DBICTest::Schema::13', + { really_erase_my_files => 1, naming => 'current' }, + [ $make_dbictest_db::dsn ], + ); + DBICTest::Schema::13->clone; + }, + 'skip_load_external' => sub { + # When we explicitly skip_load_external t/lib/DBICTest/Schema/14/Foo.pm should be ignored + use DBIx::Class::Schema::Loader; + DBIx::Class::Schema::Loader::make_schema_at( + 'DBICTest::Schema::14', + { really_erase_my_files => 1, naming => 'current', skip_load_external => 1 }, + [ $make_dbictest_db::dsn ], + ); + DBICTest::Schema::14->clone; + }, + 'moose' => sub { + package DBICTest::Schema::8; + use base qw/ DBIx::Class::Schema::Loader /; + __PACKAGE__->naming('current'); + __PACKAGE__->connect( + $make_dbictest_db::dsn, + { loader_options => { use_moose => 1 } } + ); + }, ); # 4 tests per k/v pair -plan tests => 2 * @invocations; +plan tests => 2 * @invocations + 2; # + 2 more manual ones below. while(@invocations >= 2) { my $style = shift @invocations; my $subref = shift @invocations; test_schema($style, &$subref); } + +{ + no warnings 'once'; + + is($DBICTest::Schema::13::Foo::skip_me, "bad mojo", + "external content loaded"); + is($DBICTest::Schema::14::Foo::skip_me, undef, + "external content not loaded with skip_load_external => 1"); +}