The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
#!perl

BEGIN {
  unless ($ENV{AUTHOR_TESTING}) {
    require Test::More;
    Test::More::plan(skip_all => 'these tests are for testing by the author');
  }
}


use strict;
use warnings;

use FindBin;
use lib "$FindBin::Bin/lib";

our $iters;

BEGIN { $iters = $ENV{CAT_BENCH_ITERS} || 1; }

use Test::More tests => 21*$iters;
use Catalyst::Test 'TestApp';

if ( $ENV{CAT_BENCHMARK} ) {
    require Benchmark;
    Benchmark::timethis( $iters, \&run_tests );
}
else {
    for ( 1 .. $iters ) {
        run_tests();
    }
}

sub run_tests {
    {
        my @expected = qw[
          TestApp::Controller::Action::Inheritance->begin
          TestApp::Controller::Action::Inheritance->auto
          TestApp::Controller::Action::Inheritance->default
          TestApp::View::Dump::Request->process
          TestApp::Controller::Action::Inheritance->end
        ];

        my $expected = join( ", ", @expected );

        ok( my $response = request('http://localhost/action/inheritance'),
            'Request' );
        ok( $response->is_success, 'Response Successful 2xx' );
        is( $response->content_type, 'text/plain', 'Response Content-Type' );
        is( $response->header('X-Catalyst-Action'), 'default', 'Test Action' );
        is(
            $response->header('X-Test-Class'),
            'TestApp::Controller::Action::Inheritance',
            'Test Class'
        );
        is( $response->header('X-Catalyst-Executed'),
            $expected, 'Executed actions' );
        like(
            $response->content,
            qr/^bless\( .* 'Catalyst::Request' \)$/s,
            'Content is a serialized Catalyst::Request'
        );
    }

    {
        my @expected = qw[
          TestApp::Controller::Action::Inheritance::A->begin
          TestApp::Controller::Action::Inheritance->auto
          TestApp::Controller::Action::Inheritance::A->auto
          TestApp::Controller::Action::Inheritance::A->default
          TestApp::View::Dump::Request->process
          TestApp::Controller::Action::Inheritance::A->end
        ];

        my $expected = join( ", ", @expected );

        ok( my $response = request('http://localhost/action/inheritance/a'),
            'Request' );
        ok( $response->is_success, 'Response Successful 2xx' );
        is( $response->content_type, 'text/plain', 'Response Content-Type' );
        is( $response->header('X-Catalyst-Action'), 'default', 'Test Action' );
        is(
            $response->header('X-Test-Class'),
            'TestApp::Controller::Action::Inheritance::A',
            'Test Class'
        );
        is( $response->header('X-Catalyst-Executed'),
            $expected, 'Executed actions' );
        like(
            $response->content,
            qr/^bless\( .* 'Catalyst::Request' \)$/s,
            'Content is a serialized Catalyst::Request'
        );
    }

    {
        my @expected = qw[
          TestApp::Controller::Action::Inheritance::A::B->begin
          TestApp::Controller::Action::Inheritance->auto
          TestApp::Controller::Action::Inheritance::A->auto
          TestApp::Controller::Action::Inheritance::A::B->auto
          TestApp::Controller::Action::Inheritance::A::B->default
          TestApp::View::Dump::Request->process
          TestApp::Controller::Action::Inheritance::A::B->end
        ];

        my $expected = join( ", ", @expected );

        ok( my $response = request('http://localhost/action/inheritance/a/b'),
            'Request' );
        ok( $response->is_success, 'Response Successful 2xx' );
        is( $response->content_type, 'text/plain', 'Response Content-Type' );
        is( $response->header('X-Catalyst-Action'), 'default', 'Test Action' );
        is(
            $response->header('X-Test-Class'),
            'TestApp::Controller::Action::Inheritance::A::B',
            'Test Class'
        );
        is( $response->header('X-Catalyst-Executed'),
            $expected, 'Executed actions' );
        like(
            $response->content,
            qr/^bless\( .* 'Catalyst::Request' \)$/s,
            'Content is a serialized Catalyst::Request'
        );
    }
}