]> Sergey Matveev's repositories - public-inbox.git/blobdiff - t/httpd-corner.psgi
lei: stricter external checks for valid $GIT_DIR/objects
[public-inbox.git] / t / httpd-corner.psgi
index ed1f92c0905e91e3f1c543745154407354ce5447..10cf8350041ad2c4c9b744e6c423ade6b2918675 100644 (file)
@@ -1,11 +1,12 @@
-# Copyright (C) 2016 all contributors <meta@public-inbox.org>
+# Copyright (C) all contributors <meta@public-inbox.org>
 # License: AGPL-3.0+ <https://www.gnu.org/licenses/agpl-3.0.txt>
 # 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};
@@ -48,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) = @_;
@@ -72,8 +73,52 @@ my $app = sub {
                        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 ]
 };