NAME

    Test::Mojo::Role::PSGI - Test PSGI apps using Test::Mojo

SYNOPSIS

      use strict;
      use warnings;
    
      use Test::More;
      use Test::Mojo;
    
      my $t = Test::Mojo->with_roles('+PSGI')->new('path/to/app.psgi');
    
      $t->get_ok('/some/path')
        ->status_is(200)
        ->content_type_like(qr/html/)
        ->text_is('.some-class:nth-child(5)' => 'content of 5th some-class');
    
      ...
    
      done_testing;

DESCRIPTION

    Test::Mojo makes testing Mojolicious applications easy and fun.
    Wouldn't it be nice if there was some way to use it for non-Mojolicious
    apps? Test::Mojo::Role::PSGI does just that.

OVERRIDES

 new

    Overrides the "new" in Test::Mojo method to use a PSGI app,
    instantiating a script or class if necessary. This should feel very
    similar to the original behavior except that now PSGI apps are the
    target, rather than Mojolicious apps.

    Acceptable arguments are strings that can be used by "load_psgi" in
    Plack::Util or else instantated PSGI applications, including bare code
    references.

NOTA BENE

    This module previously recommended Test::Mojo::WithRoles and depended
    on it. Since that recommendation, proper role handling was added to
    Mojolicious (see "Extending Test::Mojo" in
    Mojolicious::Guides::Testing). This obviates the need for "WithRoles",
    just use the native one. The translation is as follows:

      use Test::More;
      use Test::Mojo;
    
      my $t = Test::Mojo::WithRoles->new('path/to/app.psgi');

    becomes

      use Test::More;
      use Test::Mojo;
    
      my $t = Test::Mojo->with_roles('+PSGI')->new('path/to/app.psgi');

SEE ALSO

    Test::Mojo

    Mojolicious

    Mojolicious::Plugin::MountPSGI

    Role::Tiny

    Test::Mojo::WithRoles

SOURCE REPOSITORY

    http://github.com/jberger/Test-Mojo-Role-PSGI

AUTHOR

    Joel Berger, <joel.a.berger@gmail.com>

COPYRIGHT AND LICENSE

    Copyright (C) 2015 by Joel Berger

    This library is free software; you can redistribute it and/or modify it
    under the same terms as Perl itself.