From: Tomas Doran Date: Thu, 12 Nov 2009 01:39:56 +0000 (+0000) Subject: Patch up changes to tests into new location. This merges parts of the following commi... X-Git-Tag: 5.80014~15^2~1 X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=catagits%2FCatalyst-Runtime.git;a=commitdiff_plain;h=02fee6c690aa8c2a8ccd2d862928ec4c64e63712 Patch up changes to tests into new location. This merges parts of the following commits which were missed by svk: -r11456:11457 http://dev.catalyst.perl.org/repos/Catalyst/Catalyst-Runtime/5.80/trunk -r11467:11468 http://dev.catalyst.perl.org/repos/Catalyst/Catalyst-Runtime/5.80/trunk --- 02fee6c690aa8c2a8ccd2d862928ec4c64e63712 diff --cc t/aggregate/unit_core_mvc.t index 876d31a,0000000,0000000..b04c3a3 mode 100644,000000,000000..100644 --- a/t/aggregate/unit_core_mvc.t +++ b/t/aggregate/unit_core_mvc.t @@@@ -1,183 -1,0 -1,0 +1,227 @@@@ - use Test::More tests => 46; +++use Test::More tests => 51; ++use strict; ++use warnings; ++ ++use_ok('Catalyst'); ++ ++my @complist = ++ map { "MyMVCTestApp::$_"; } ++ qw/C::Controller M::Model V::View Controller::C Model::M View::V Controller::Model::Dummy::Model Model::Dummy::Model/; ++ ++{ ++ ++ package MyMVCTestApp; ++ ++ use base qw/Catalyst/; ++ ++ __PACKAGE__->components( { map { ( ref($_)||$_ , $_ ) } @complist } ); ++ ++ my $thingie={}; ++ bless $thingie, 'Some::Test::Object'; ++ __PACKAGE__->components->{'MyMVCTestApp::Model::Test::Object'} = $thingie; ++ ++ # allow $c->log->warn to work ++ __PACKAGE__->setup_log; ++} ++ ++is( MyMVCTestApp->view('View'), 'MyMVCTestApp::V::View', 'V::View ok' ); ++ ++is( MyMVCTestApp->controller('Controller'), ++ 'MyMVCTestApp::C::Controller', 'C::Controller ok' ); ++ ++is( MyMVCTestApp->model('Model'), 'MyMVCTestApp::M::Model', 'M::Model ok' ); ++ ++is( MyMVCTestApp->model('Dummy::Model'), 'MyMVCTestApp::Model::Dummy::Model', 'Model::Dummy::Model ok' ); ++ ++isa_ok( MyMVCTestApp->model('Test::Object'), 'Some::Test::Object', 'Test::Object ok' ); ++ ++is( MyMVCTestApp->controller('Model::Dummy::Model'), 'MyMVCTestApp::Controller::Model::Dummy::Model', 'Controller::Model::Dummy::Model ok' ); ++ ++is( MyMVCTestApp->view('V'), 'MyMVCTestApp::View::V', 'View::V ok' ); ++ ++is( MyMVCTestApp->controller('C'), 'MyMVCTestApp::Controller::C', 'Controller::C ok' ); ++ ++is( MyMVCTestApp->model('M'), 'MyMVCTestApp::Model::M', 'Model::M ok' ); ++ ++# failed search ++{ ++ is( MyMVCTestApp->model('DNE'), undef, 'undef for invalid search' ); ++} ++ ++is_deeply( [ sort MyMVCTestApp->views ], ++ [ qw/V View/ ], ++ 'views ok' ); ++ ++is_deeply( [ sort MyMVCTestApp->controllers ], ++ [ qw/C Controller Model::Dummy::Model/ ], ++ 'controllers ok'); ++ ++is_deeply( [ sort MyMVCTestApp->models ], ++ [ qw/Dummy::Model M Model Test::Object/ ], ++ 'models ok'); ++ ++{ ++ my $warnings = 0; ++ no warnings 'redefine'; ++ local *Catalyst::Log::warn = sub { $warnings++ }; ++ ++ like (MyMVCTestApp->view , qr/^MyMVCTestApp\::(V|View)\::/ , 'view() with no defaults returns *something*'); ++ ok( $warnings, 'view() w/o a default is random, warnings thrown' ); ++} ++ ++is ( bless ({stash=>{current_view=>'V'}}, 'MyMVCTestApp')->view , 'MyMVCTestApp::View::V', 'current_view ok'); ++ ++my $view = bless {} , 'MyMVCTestApp::View::V'; ++is ( bless ({stash=>{current_view_instance=> $view }}, 'MyMVCTestApp')->view , $view, 'current_view_instance ok'); ++ ++is ( bless ({stash=>{current_view_instance=> $view, current_view=>'MyMVCTestApp::V::View' }}, 'MyMVCTestApp')->view , $view, ++ 'current_view_instance precedes current_view ok'); ++ ++{ ++ my $warnings = 0; ++ no warnings 'redefine'; ++ local *Catalyst::Log::warn = sub { $warnings++ }; ++ ++ ok( my $model = MyMVCTestApp->model ); ++ ++ ok( (($model =~ /^MyMVCTestApp\::(M|Model)\::/) || ++ $model->isa('Some::Test::Object')), ++ 'model() with no defaults returns *something*' ); ++ ++ ok( $warnings, 'model() w/o a default is random, warnings thrown' ); ++} ++ ++is ( bless ({stash=>{current_model=>'M'}}, 'MyMVCTestApp')->model , 'MyMVCTestApp::Model::M', 'current_model ok'); ++ ++my $model = bless {} , 'MyMVCTestApp::Model::M'; ++is ( bless ({stash=>{current_model_instance=> $model }}, 'MyMVCTestApp')->model , $model, 'current_model_instance ok'); ++ ++is ( bless ({stash=>{current_model_instance=> $model, current_model=>'MyMVCTestApp::M::Model' }}, 'MyMVCTestApp')->model , $model, ++ 'current_model_instance precedes current_model ok'); ++ ++MyMVCTestApp->config->{default_view} = 'V'; ++is ( bless ({stash=>{}}, 'MyMVCTestApp')->view , 'MyMVCTestApp::View::V', 'default_view ok'); ++is ( MyMVCTestApp->view , 'MyMVCTestApp::View::V', 'default_view in class method ok'); ++ ++MyMVCTestApp->config->{default_model} = 'M'; ++is ( bless ({stash=>{}}, 'MyMVCTestApp')->model , 'MyMVCTestApp::Model::M', 'default_model ok'); ++is ( MyMVCTestApp->model , 'MyMVCTestApp::Model::M', 'default_model in class method ok'); ++ ++# regexp behavior tests ++{ ++ # is_deeply is used because regexp behavior means list context ++ is_deeply( [ MyMVCTestApp->view( qr{^V[ie]+w$} ) ], [ 'MyMVCTestApp::V::View' ], 'regexp view ok' ); ++ is_deeply( [ MyMVCTestApp->controller( qr{Dummy\::Model$} ) ], [ 'MyMVCTestApp::Controller::Model::Dummy::Model' ], 'regexp controller ok' ); ++ is_deeply( [ MyMVCTestApp->model( qr{Dum{2}y} ) ], [ 'MyMVCTestApp::Model::Dummy::Model' ], 'regexp model ok' ); ++ ++ # object w/ qr{} ++ is_deeply( [ MyMVCTestApp->model( qr{Test} ) ], [ MyMVCTestApp->components->{'MyMVCTestApp::Model::Test::Object'} ], 'Object returned' ); ++ ++ { ++ my $warnings = 0; ++ no warnings 'redefine'; ++ local *Catalyst::Log::warn = sub { $warnings++ }; ++ ++ # object w/ regexp fallback ++ is_deeply( [ MyMVCTestApp->model( 'Test' ) ], [ MyMVCTestApp->components->{'MyMVCTestApp::Model::Test::Object'} ], 'Object returned' ); ++ ok( $warnings, 'regexp fallback warnings' ); ++ } ++ ++ is_deeply( [ MyMVCTestApp->view('MyMVCTestApp::V::View$') ], [ 'MyMVCTestApp::V::View' ], 'Explicit return ok'); ++ is_deeply( [ MyMVCTestApp->controller('MyMVCTestApp::C::Controller$') ], [ 'MyMVCTestApp::C::Controller' ], 'Explicit return ok'); ++ is_deeply( [ MyMVCTestApp->model('MyMVCTestApp::M::Model$') ], [ 'MyMVCTestApp::M::Model' ], 'Explicit return ok'); ++} ++ ++{ ++ my @expected = qw( MyMVCTestApp::C::Controller MyMVCTestApp::Controller::C ); ++ is_deeply( [ sort MyMVCTestApp->controller( qr{^C} ) ], \@expected, 'multiple controller returns from regexp search' ); ++} ++ ++{ ++ my @expected = qw( MyMVCTestApp::V::View MyMVCTestApp::View::V ); ++ is_deeply( [ sort MyMVCTestApp->view( qr{^V} ) ], \@expected, 'multiple view returns from regexp search' ); ++} ++ ++{ ++ my @expected = qw( MyMVCTestApp::M::Model MyMVCTestApp::Model::M ); ++ is_deeply( [ sort MyMVCTestApp->model( qr{^M} ) ], \@expected, 'multiple model returns from regexp search' ); ++} ++ ++# failed search ++{ ++ is( scalar MyMVCTestApp->controller( qr{DNE} ), 0, '0 results for failed search' ); ++} ++ ++#checking @args passed to ACCEPT_CONTEXT ++{ ++ my $args; ++ ++ { ++ no warnings 'once'; ++ *MyMVCTestApp::Model::M::ACCEPT_CONTEXT = sub { my ($self, $c, @args) = @_; $args= \@args}; ++ *MyMVCTestApp::View::V::ACCEPT_CONTEXT = sub { my ($self, $c, @args) = @_; $args= \@args}; ++ } ++ ++ my $c = bless {}, 'MyMVCTestApp'; ++ ++ # test accept-context with class rather than instance ++ MyMVCTestApp->model('M', qw/foo bar/); ++ is_deeply($args, [qw/foo bar/], 'MyMVCTestApp->model args passed to ACCEPT_CONTEXT ok'); ++ ++ ++ $c->model('M', qw/foo bar/); ++ is_deeply($args, [qw/foo bar/], '$c->model args passed to ACCEPT_CONTEXT ok'); ++ ++ my $x = $c->view('V', qw/foo2 bar2/); ++ is_deeply($args, [qw/foo2 bar2/], '$c->view args passed to ACCEPT_CONTEXT ok'); ++ ++ # regexp fallback ++ $c->view('::View::V', qw/foo3 bar3/); ++ is_deeply($args, [qw/foo3 bar3/], 'args passed to ACCEPT_CONTEXT ok'); ++ ++ ++} +++ +++{ +++ my $warn = ''; +++ no warnings 'redefine'; +++ local *Catalyst::Log::warn = sub { $warn .= $_[1] }; +++ +++ is_deeply (MyMVCTestApp->controller('MyMVCTestApp::Controller::C'), +++ MyMVCTestApp->components->{'MyMVCTestApp::Controller::C'}, +++ 'controller by fully qualified name ok'); +++ +++ # You probably meant $c->controller('C') instead of $c->controller({'MyMVCTestApp::Controller::C'}) +++ my ($suggested_comp_name, $orig_comp_name) = $warn =~ /You probably meant (.*) instead of (.*) /; +++ isnt($suggested_comp_name, $orig_comp_name, 'suggested fix in warning for fully qualified component names makes sense' ); +++} +++ +++{ +++ package MyApp::WithoutRegexFallback; +++ +++ use base qw/Catalyst/; +++ +++ __PACKAGE__->config( { disable_component_resolution_regex_fallback => 1 } ); +++ +++ __PACKAGE__->components( { map { ( ref($_)||$_ , $_ ) } +++ qw/MyApp::WithoutRegexFallback::Controller::Another::Foo/ } ); +++ +++ # allow $c->log->warn to work +++ __PACKAGE__->setup_log; +++} +++ +++{ +++ # test if non-regex component retrieval still works +++ is( MyApp::WithoutRegexFallback->controller('Another::Foo'), +++ 'MyApp::WithoutRegexFallback::Controller::Another::Foo', 'controller Another::Foo found'); +++} +++ +++{ +++ my $warnings = 0; +++ no warnings 'redefine'; +++ local *Catalyst::Log::warn = sub { $warnings++ }; +++ +++ # try to get nonexisting object w/o regexp fallback +++ is( MyApp::WithoutRegexFallback->controller('Foo'), undef, 'no controller Foo found'); +++ ok( !$warnings, 'no regexp fallback warnings' ); +++} diff --cc t/aggregate/unit_load_catalyst_test.t index d3f30ee,7688380,ffa5655..fa8144c --- a/t/aggregate/unit_load_catalyst_test.t +++ b/t/aggregate/unit_load_catalyst_test.t @@@@ -4,10 -4,10 -4,10 +4,10 @@@@ use strict use warnings; use FindBin; ---use lib "$FindBin::Bin/lib"; - -use Test::More tests => 59; +++use lib "$FindBin::Bin/../lib"; + +use Test::More tests => 61; use FindBin qw/$Bin/; --use lib "$Bin/lib"; ++use lib "$Bin/../lib"; use Catalyst::Utils; use HTTP::Request::Common; use Test::Exception;