X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=catagits%2FCatalyst-Runtime.git;a=blobdiff_plain;f=t%2Flib%2FTestApp.pm;h=d1d8797d423e08b506c5ff05d75fd95122bca81d;hp=9ee303d3c4d4bbcd7b6409ece5740a13a06e1891;hb=258733f15e1e1ec4b4d92eda4b4471833890aced;hpb=081ea9220deb31273cc4e778d6debdb96256beda diff --git a/t/lib/TestApp.pm b/t/lib/TestApp.pm index 9ee303d..d1d8797 100644 --- a/t/lib/TestApp.pm +++ b/t/lib/TestApp.pm @@ -1,5 +1,4 @@ package TestApp; - use strict; use Catalyst qw/ Test::MangleDollarUnderScore @@ -16,9 +15,47 @@ use Catalyst::Utils; use Moose; use namespace::autoclean; +# ----------- +# t/aggregate/unit_core_ctx_attr.t pukes until lazy is true +package Greeting; +use Moose; +sub hello_notlazy { 'hello there' } +sub hello_lazy { 'hello there' } + +package TestApp; +has 'my_greeting_obj_notlazy' => ( + is => 'ro', + isa => 'Greeting', + default => sub { Greeting->new() }, + handles => [ qw( hello_notlazy ) ], + lazy => 0, +); +has 'my_greeting_obj_lazy' => ( + is => 'ro', + isa => 'Greeting', + default => sub { Greeting->new() }, + handles => [ qw( hello_lazy ) ], + lazy => 1, +); +# ----------- + our $VERSION = '0.01'; -TestApp->config( name => 'TestApp', root => '/some/dir', rfc3875_paths => 1 ); +TestApp->config( + name => 'TestApp', + root => '/some/dir', + use_request_uri_for_path => 1, + 'Controller::Action::Action' => { + action_args => { + action_action_nine => { another_extra_arg => 13 } + } + } +); + +# Test bug found when re-adjusting the metaclass compat code in Moose +# in 292360. Test added to Moose in 4b760d6, but leave this attribute +# above ->setup so we have some generated methods to be double sure. +has an_attribute_before_we_change_base_classes => ( is => 'ro'); if ($::setup_leakchecker && eval { Class::MOP::load_class('CatalystX::LeakChecker'); 1 }) { with 'CatalystX::LeakChecker'; @@ -87,6 +124,16 @@ sub finalize_error { sub Catalyst::Log::error { } } +# Pretend to be Plugin::Session and hook finalize_headers to send a header + +sub finalize_headers { + my $c = shift; + + $c->res->header('X-Test-Header', 'valid'); + + return $c->maybe::next::method(@_); +} + # Make sure we can load Inline plugins. package Catalyst::Plugin::Test::Inline;