X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2F103many_to_many_warning.t;h=37a0472851feb360158617f9dc900aa7021d0ee4;hb=a33d2444e0981129eb060521de27c5e2104f37ba;hp=f98024c4f7bc123ca808600aac821576128d6375;hpb=ed0bdca2a188efd94f4a441b946aa9716b3bcbe6;p=dbsrgits%2FDBIx-Class.git diff --git a/t/103many_to_many_warning.t b/t/103many_to_many_warning.t index f98024c..37a0472 100644 --- a/t/103many_to_many_warning.t +++ b/t/103many_to_many_warning.t @@ -5,41 +5,38 @@ use Test::More; use lib qw(t/lib); use Data::Dumper; -plan ( ($] >= 5.009000 and $] < 5.010001) - ? (skip_all => 'warnings::register broken under 5.10: http://rt.perl.org/rt3/Public/Bug/Display.html?id=62522') - : (tests => 2) -); +plan tests => 4; +my $exp_warn = qr/The many-to-many relationship 'bars' is trying to create/; { my @w; - local $SIG{__WARN__} = sub { push @w, @_ }; - + local $SIG{__WARN__} = sub { $_[0] =~ $exp_warn ? push @w, $_[0] : warn $_[0] }; my $code = gen_code ( suffix => 1 ); eval "$code"; + ok (! $@, 'Eval code without warnings suppression') + || diag $@; - ok ( (grep { $_ =~ /The many-to-many relationship bars is trying to create/ } @w), "Warning triggered without relevant 'no warnings'"); + ok (@w, "Warning triggered without DBIC_OVERWRITE_HELPER_METHODS_OK"); } { my @w; - local $SIG{__WARN__} = sub { push @w, @_ }; + local $SIG{__WARN__} = sub { $_[0] =~ $exp_warn ? push @w, $_[0] : warn $_[0] }; - my $code = gen_code ( suffix => 2, no_warn => 1 ); - eval "$code"; + my $code = gen_code ( suffix => 2 ); -diag Dumper \@w; + local $ENV{DBIC_OVERWRITE_HELPER_METHODS_OK} = 1; + eval "$code"; + ok (! $@, 'Eval code with warnings suppression') + || diag $@; - ok ( (not grep { $_ =~ /The many-to-many relationship bars is trying to create/ } @w), "No warning triggered with relevant 'no warnings'"); + ok (! @w, "No warning triggered with DBIC_OVERWRITE_HELPER_METHODS_OK"); } sub gen_code { my $args = { @_ }; my $suffix = $args->{suffix}; - my $no_warn = ( $args->{no_warn} - ? "no warnings 'DBIx::Class::Relationship::ManyToMany';" - : '', - ); return <table('foo'); __PACKAGE__->add_columns( 'fooid' => { @@ -84,6 +82,7 @@ use warnings; DBICTest::Schema::Bar${suffix}; use base 'DBIx::Class::Core'; + __PACKAGE__->table('bar'); __PACKAGE__->add_columns( 'barid' => { @@ -92,7 +91,6 @@ use warnings; }, ); - ${no_warn} __PACKAGE__->set_primary_key('barid'); __PACKAGE__->has_many('foo_to_bar' => 'DBICTest::Schema::FooToBar${suffix}' => 'foo');