Plack-Middleware-TrafficLog

 view release on metacpan or  search on metacpan

t/100_trafficlog.t  view on Meta::CPAN

        my $res = $test->($app_static, with_date => 0, with_body => 1, eol => '!', body_eol => ',')->($req);
        is $res->code, 200, 'response code';
        is $res->content, "OK\nOK\n", 'response content';
        is @Log, 2, 'with body_eol [lines]';
        like $Log[0],
            qr{^\[\d+\] \[127.0.0.1:\d+ -> example.com:80\] \[Request \] !POST / HTTP/1.1!Host: example.com!Content-Length: 10!Content-Type: text/plain!!TEST,TEST,$},
            'with body_eol [0]';
        like $Log[1],
            qr{^\[\d+\] \[127.0.0.1:\d+ <- example.com:80\] \[Response\] !HTTP/1.0 200 OK!Content-Type: text/plain!!OK,OK,$},
            'with body_eol [1]';
    }

    {
        my $req_empty = GET 'http://example.com/';

        my $app_static_empty = sub {
            [200, ['Content-Type' => 'text/plain'], []]
        };

        {
            local @Log;
            my $res = $test->($app_static_empty, with_body => 1)->($req_empty);
            is $res->code, 200, 'response code';
            is $res->content, '', 'response content';
            is @Log, 2, 'empty [lines]';
            like $Log[0],
                qr{^\[\d{2}/\S+/\d{4}:\d{2}:\d{2}:\d{2} \S+\] \[\d+\] \[127.0.0.1:\d+ -> example.com:80\] \[Request \] \|GET / HTTP/1.1\|Host: example.com\|Content-Length: 0\|\|$},
                'empty [0]';
            like $Log[1],
                qr{^\[\d{2}/\S+/\d{4}:\d{2}:\d{2}:\d{2} \S+\] \[\d+\] \[127.0.0.1:\d+ <- example.com:80\] \[Response\] \|HTTP/1.0 200 OK\|Content-Type: text/plain\|\|$},
                'empty [1]';
        }
    }

    {
        my $app_delayed = sub {
            my ($app) = @_;
            return sub {
                my ($env) = @_;
                return sub {
                    my ($responder) = @_;
                    $responder->($app->());
                };
            };
        };

        local @Log;
        my $res = $test->($app_delayed->($app_static), with_body => 1)->($req);
        is $res->code, 200, 'response code';
        is $res->content, "OK\nOK\n", 'response content';
        is @Log, 2, 'delayed [lines]';
        like $Log[0],
            qr{^\[\d{2}/\S+/\d{4}:\d{2}:\d{2}:\d{2} \S+\] \[\d+\] \[127.0.0.1:\d+ -> example.com:80\] \[Request \] \|POST / HTTP/1.1\|Host: example.com\|Content-Length: 10\|Content-Type: text/plain\|\|TEST TEST $},
            'delayed [0]';
        like $Log[1],
            qr{^\[\d{2}/\S+/\d{4}:\d{2}:\d{2}:\d{2} \S+\] \[\d+\] \[127.0.0.1:\d+ <- example.com:80\] \[Response\] \|HTTP/1.0 200 OK\|Content-Type: text/plain\|\|OK OK $},
            'delayed [1]';
    }

    {
        my $app_streaming = sub {
            return sub {
                my ($responder) = @_;
                my $writer = $responder->([200, ['Content-Type' => 'text/plain']]);
                $writer->write("OK\n");
                $writer->write("OK\n");
                $writer->close;
                return;
            };
        };

        local @Log;
        my $res = $test->($app_streaming, with_body => 1)->($req);
        is $res->code, 200, 'response code';
        is $res->content, "OK\nOK\n", 'response content';
        is @Log, 2, 'streaming [lines]';
        like $Log[0],
            qr{^\[\d{2}/\S+/\d{4}:\d{2}:\d{2}:\d{2} \S+\] \[\d+\] \[127.0.0.1:\d+ -> example.com:80\] \[Request \] \|POST / HTTP/1.1\|Host: example.com\|Content-Length: 10\|Content-Type: text/plain\|\|TEST TEST $},
            'streaming [0]';
        like $Log[1],
            qr{^\[\d{2}/\S+/\d{4}:\d{2}:\d{2}:\d{2} \S+\] \[\d+\] \[127.0.0.1:\d+ <- example.com:80\] \[Response\] \|HTTP/1.0 200 OK\|Content-Type: text/plain\|\|OK $},
            'streaming [1]';
    }

    {
        my $app_streaming = sub {
            return sub {
                my ($responder) = @_;
                my $writer = $responder->([200, ['Content-Type' => 'text/plain']]);
                $writer->write("OK\n");
                $writer->write("OK\n");
                $writer->close;
                return;
            };
        };

        local @Log;
        my $res = $test->($app_streaming, with_body => 1, with_all_chunks => 1)->($req);
        is $res->code, 200, 'response code';
        is $res->content, "OK\nOK\n", 'response content';
        is @Log, 3, 'streaming [lines]';
        like $Log[0],
            qr{^\[\d{2}/\S+/\d{4}:\d{2}:\d{2}:\d{2} \S+\] \[\d+\] \[127.0.0.1:\d+ -> example.com:80\] \[Request \] \|POST / HTTP/1.1\|Host: example.com\|Content-Length: 10\|Content-Type: text/plain\|\|TEST TEST $},
            'streaming [0]';
        like $Log[1],
            qr{^\[\d{2}/\S+/\d{4}:\d{2}:\d{2}:\d{2} \S+\] \[\d+\] \[127.0.0.1:\d+ <- example.com:80\] \[Response\] \|HTTP/1.0 200 OK\|Content-Type: text/plain\|\|OK $},
            'streaming [1]';
        like $Log[2],
            qr{^\[\d{2}/\S+/\d{4}:\d{2}:\d{2}:\d{2} \S+\] \[\d+\] \[127.0.0.1:\d+ <- example.com:80\] \[Response\] \|HTTP/1.0 200 OK\|Content-Type: text/plain\|\|OK $},
            'streaming [2]';
    }

    {
        my $app_static_499 = sub {
            [499, ['Content-Type' => 'text/plain'], ["Unknown error\n"]]
        };

        {
            local @Log;
            my $res = $test->($app_static_499, with_body => 1)->($req);
            is $res->code, 499, 'response code';
            is $res->content, "Unknown error\n", 'response content';
            is @Log, 2, 'error 499 [lines]';
            like $Log[0],
                qr{^\[\d{2}/\S+/\d{4}:\d{2}:\d{2}:\d{2} \S+\] \[\d+\] \[127.0.0.1:\d+ -> example.com:80\] \[Request \] \|POST / HTTP/1.1\|Host: example.com\|Content-Length: 10|Content-Type: text/plain\|\|TEST TEST\|\|$},
                'error 499 [0]';
            like $Log[1],
                qr{^\[\d{2}/\S+/\d{4}:\d{2}:\d{2}:\d{2} \S+\] \[\d+\] \[127.0.0.1:\d+ <- example.com:80\] \[Response\] \|HTTP/1.0 499 \|Content-Type: text/plain\|\|Unknown error $},
                'error 499 [1]';
        }
    }

}

done_testing;



( run in 3.727 seconds using v1.01-cache-2.11-cpan-437f7b0c052 )