X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=t%2Fhttpd-corner.psgi;h=10cf8350041ad2c4c9b744e6c423ade6b2918675;hb=6b4e4f0d2d52a4b39c68d8f63915ddb7e1e8270e;hp=da8a2ee8b646ef7b9937c9d72ab9616e924f4fd3;hpb=5186d1f71d83ad84104c93da6bd27908a1610403;p=public-inbox.git
diff --git a/t/httpd-corner.psgi b/t/httpd-corner.psgi
index da8a2ee8..10cf8350 100644
--- a/t/httpd-corner.psgi
+++ b/t/httpd-corner.psgi
@@ -1,11 +1,12 @@
-# Copyright (C) 2016 all contributors
+# Copyright (C) all contributors
# License: AGPL-3.0+
# corner case tests for the generic PSGI server
# Usage: plackup [OPTIONS] /path/to/this/file
-use strict;
+use v5.12;
use warnings;
use Plack::Builder;
require Digest::SHA;
+my $pi_config = $ENV{PI_CONFIG} // 'unset'; # capture ASAP
my $app = sub {
my ($env) = @_;
my $path = $env->{PATH_INFO};
@@ -30,6 +31,7 @@ my $app = sub {
return sub {
open my $f, '<', $fifo or
die "open $fifo: $!\n";
+ local $/ = "\n";
my @r = <$f>;
$_[0]->([200, $h, \@r ]);
};
@@ -38,6 +40,7 @@ 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);
}
@@ -46,7 +49,7 @@ my $app = sub {
}
} elsif ($path eq '/host-port') {
$code = 200;
- push @$body, "$env->{REMOTE_ADDR}:$env->{REMOTE_PORT}";
+ push @$body, "$env->{REMOTE_ADDR} $env->{REMOTE_PORT}";
} elsif ($path eq '/callback') {
return sub {
my ($res) = @_;
@@ -56,8 +59,66 @@ my $app = sub {
$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 '/psgi-return-gzip') {
+ require PublicInbox::Qspawn;
+ require PublicInbox::GzipFilter;
+ my $cmd = [qw(echo hello world)];
+ my $qsp = PublicInbox::Qspawn->new($cmd);
+ $env->{'qspawn.filter'} = PublicInbox::GzipFilter->new;
+ return $qsp->psgi_return($env, undef, sub {
+ [ 200, [ qw(Content-Type application/octet-stream)]]
+ });
+ } elsif ($path eq '/psgi-return-compressible') {
+ require PublicInbox::Qspawn;
+ my $cmd = [qw(echo goodbye world)];
+ my $qsp = PublicInbox::Qspawn->new($cmd);
+ return $qsp->psgi_return($env, undef, sub {
+ [200, [qw(Content-Type text/plain)]]
+ });
+ } elsif ($path eq '/psgi-return-enoent') {
+ require PublicInbox::Qspawn;
+ my $cmd = [ 'this-better-not-exist-in-PATH'.rand ];
+ my $qsp = PublicInbox::Qspawn->new($cmd);
+ return $qsp->psgi_return($env, undef, sub {
+ [ 200, [ qw(Content-Type application/octet-stream)]]
+ });
+ } elsif ($path eq '/pid') {
+ $code = 200;
+ push @$body, "$$\n";
+ } elsif ($path eq '/url_scheme') {
+ $code = 200;
+ push @$body, $env->{'psgi.url_scheme'}
+ } elsif ($path eq '/PI_CONFIG') {
+ $code = 200;
+ push @$body, $pi_config; # show value at ->refresh_groups
}
-
[ $code, $h, $body ]
};