X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Fcdbi%2F18-has_a.t;h=6304b2c930f70cb9b399da7c39db52dec0a2a5c5;hb=d8cf3aa31fb3d6ff7813f021fcc002663725fc41;hp=1dacd6c8a0ddd848d9e59ba6838a592751138f3e;hpb=4a233f3019d2baa4bf2abee0c873c74d5cdf3a11;p=dbsrgits%2FDBIx-Class.git diff --git a/t/cdbi/18-has_a.t b/t/cdbi/18-has_a.t index 1dacd6c..6304b2c 100644 --- a/t/cdbi/18-has_a.t +++ b/t/cdbi/18-has_a.t @@ -1,6 +1,12 @@ +BEGIN { do "./t/lib/ANFANG.pm" or die ( $@ || $! ) } +use DBIx::Class::Optional::Dependencies -skip_all_without => 'cdbicompat'; + use strict; use warnings; + use Test::More; +use Test::Exception; +use DBIx::Class::_Util 'sigwarn_silencer'; use lib 't/cdbi/testlib'; use Film; @@ -45,8 +51,8 @@ my $sj = Director->create({ }); { - eval { $btaste->Director($btaste) }; - like $@, qr/Director/, "Can't set film as director"; + throws_ok { $btaste->Director($btaste) } + qr/isn't a Director/, "Can't set film as director"; is $btaste->Director->id, $pj->id, "PJ still the director"; # drop from cache so that next retrieve() is from db @@ -69,8 +75,7 @@ my $sj = Director->create({ is $sj->id, 'Skippy Jackson', 'Create new director - Skippy'; Film->has_a('CoDirector' => 'Director'); { - eval { $btaste->CoDirector("Skippy Jackson") }; - is $@, "", "Auto inflates"; + lives_ok { $btaste->CoDirector("Skippy Jackson") }; isa_ok $btaste->CoDirector, "Director"; is $btaste->CoDirector->id, $sj->id, "To skippy"; } @@ -96,7 +101,8 @@ is( $pj = Director->retrieve('Peter Jackson'); my $fail; - eval { + throws_ok { + local $SIG{__WARN__} = sigwarn_silencer( qr/\Qusually should inherit from the related ResultClass ('Director')/ ); $fail = YA::Film->create({ Title => 'Tastes Bad', Director => $sj, @@ -104,8 +110,7 @@ is( Rating => 'R', NumExplodingSheep => 23 }); - }; - ok $@, "Can't have film as codirector: $@"; + } qr/is not a column on related source 'Director'/, "Can't have film as codirector"; is $fail, undef, "We didn't get anything"; my $tastes_bad = YA::Film->create({ @@ -226,8 +231,10 @@ SKIP: { } { # Broken has_a declaration - eval { Film->has_a(driector => "Director") }; - like $@, qr/driector/, "Sensible error from has_a with incorrect column: $@"; + throws_ok{ Film->has_a(driector => "Director") } + qr/No such column driector/, + "Sensible error from has_a with incorrect column" + ; } done_testing;