The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
use strict;
use warnings;
use Test::Requires {
    'HTTP::Request::AsCGI' => 1.2,
};
use Test::More;
use FindBin;
use HTTP::Request::AsCGI;
use URI::Escape;
use Plack;
use Plack::Handler::CGI;
use Plack::Test::Suite;

Plack::Test::Suite->runtests(sub {
    my ($name, $test, $handler) = @_;
    local $ENV{PLACK_TEST_HANDLER} = 'CGI';
    local $ENV{PLACK_TEST_SCRIPT_NAME} = '/plack_test.cgi';

    note $name;
    my $cb = sub {
        my $req = shift;

        my $cgi = HTTP::Request::AsCGI->new($req);
        my $c = $cgi->setup;

        # Fix CGI container parameters
        $ENV{SCRIPT_NAME} = '/plack_test.cgi';
        $ENV{REQUEST_URI} = "/plack_test.cgi$ENV{REQUEST_URI}";

        # Apache's CGI implementation does not pass "Authorization" header by untrusted ENV.
        # We bow down to it under this test.
        delete $ENV{HTTP_AUTHORIZATION};

        eval { Plack::Handler::CGI->new->run($handler) };
        my $res = $c->response;
        $res->request($req);

        $res;
    };

    $test->($cb);
});

done_testing;