X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=t%2Fhttpd-corner.psgi;h=18e556be0e39c29c5ca20f64ddbb4953da8052b4;hb=d62d98b9a7f502da65673f0b83a6d06312c060d9;hp=0e0e21a84cd585cf187793c8f85f85b78f574d10;hpb=aeaa38f620cf880a073b3a37463f0c577188df46;p=public-inbox.git diff --git a/t/httpd-corner.psgi b/t/httpd-corner.psgi index 0e0e21a8..18e556be 100644 --- a/t/httpd-corner.psgi +++ b/t/httpd-corner.psgi @@ -1,10 +1,9 @@ -# Copyright (C) 2016 all contributors +# Copyright (C) 2016-2019 all contributors # License: AGPL-3.0+ # corner case tests for the generic PSGI server # Usage: plackup [OPTIONS] /path/to/this/file use strict; use warnings; -use Plack::Request; use Plack::Builder; require Digest::SHA; my $app = sub { @@ -31,6 +30,7 @@ my $app = sub { return sub { open my $f, '<', $fifo or die "open $fifo: $!\n"; + local $/ = "\n"; my @r = <$f>; $_[0]->([200, $h, \@r ]); }; @@ -39,12 +39,55 @@ my $app = sub { my $fh = $_[0]->([200, $h]); open my $f, '<', $fifo or die "open $fifo: $!\n"; + local $/ = "\n"; while (defined(my $l = <$f>)) { $fh->write($l); } $fh->close; }; } + } elsif ($path eq '/host-port') { + $code = 200; + push @$body, "$env->{REMOTE_ADDR}:$env->{REMOTE_PORT}"; + } elsif ($path eq '/callback') { + return sub { + my ($res) = @_; + my $buf = "hello world\n"; + push @$h, 'Content-Length', length($buf); + my $fh = $res->([200, $h]); + $fh->write($buf); + $fh->close; + } + } elsif ($path eq '/empty') { + $code = 200; + } elsif ($path eq '/getline-die') { + $code = 200; + $body = Plack::Util::inline_object( + getline => sub { die 'GETLINE FAIL' }, + close => sub { die 'CLOSE FAIL' }, + ); + } elsif ($path eq '/close-die') { + $code = 200; + $body = Plack::Util::inline_object( + getline => sub { undef }, + close => sub { die 'CLOSE FAIL' }, + ); + } elsif ($path eq '/async-big') { + require PublicInbox::Qspawn; + open my $null, '>', '/dev/null' or die; + my $rdr = { 2 => fileno($null) }; + my $cmd = [qw(dd if=/dev/zero count=30 bs=1024k)]; + my $qsp = PublicInbox::Qspawn->new($cmd, undef, $rdr); + return $qsp->psgi_return($env, undef, sub { + my ($r, $bref) = @_; + # make $rd_hdr retry sysread + $parse_hdr in Qspawn: + return until length($$bref) > 8000; + close $null; + [ 200, [ qw(Content-Type application/octet-stream) ]]; + }); + } elsif ($path eq '/pid') { + $code = 200; + push @$body, "$$\n"; } [ $code, $h, $body ]