with 'Web::Dispatch::ToApp';
-has app => (is => 'ro', required => 1);
+has dispatch_app => (
+ is => 'lazy', builder => sub { shift->dispatch_object->to_app }
+);
+has dispatch_object => (is => 'ro', required => 0);
has parser_class => (
is => 'ro', default => quote_sub q{ 'Web::Dispatch::Parser' }
);
has node_args => (is => 'ro', default => quote_sub q{ {} });
has _parser => (is => 'lazy');
+after BUILDARGS => sub {
+ my ( $self, %args ) = @_;
+ die "Either dispatch_app or dispatch_object need to be supplied."
+ if !$args{dispatch_app} and !$args{dispatch_object}
+};
+
sub _build__parser {
my ($self) = @_;
$self->parser_class->new;
sub call {
my ($self, $env) = @_;
- my $res = $self->_dispatch($env, $self->app);
+ my $res = $self->_dispatch($env, $self->dispatch_app);
return $res->[0] if ref($res) eq 'ARRAY' and @{$res} == 1 and ref($res->[0]) eq 'CODE';
return $res;
}
my $node_args = { app_object => $self };
weaken($node_args->{app_object});
Web::Dispatch->new(
- app => sub { $self->dispatch_request(@_), $final },
+ dispatch_app => sub { $self->dispatch_request(@_), $final },
node_class => 'Web::Simple::DispatchNode',
node_args => $node_args
);
sub run_request { $app->run_test_request( @_ ); }
app_is_non_plack();
+app_is_object();
plack_app_return();
broken_route_def();
invalid_psgi_responses();
my $r = HTTP::Response->new( 999 );
- my $d = Web::Dispatch->new( app => $r );
+ my $d = Web::Dispatch->new( dispatch_app => $r );
eval { $d->call };
like $@, qr/No idea how we got here with HTTP::Response/,
undef $@;
}
+sub app_is_object {
+ {
+
+ package ObjectApp;
+ use Moo;
+ sub to_app { [ 999, [], ["ok"] ] }
+ }
+
+ my $d = Web::Dispatch->new( dispatch_object => ObjectApp->new );
+ my $res = $d->call;
+
+ cmp_ok $res->[0], '==', 999, "Web::Dispatch can dispatch properly, given only an object with to_app method";
+}
+
sub plack_app_return {
{