diff options
Diffstat (limited to 'tests/fastcgi.t')
-rwxr-xr-x | tests/fastcgi.t | 233 |
1 files changed, 0 insertions, 233 deletions
diff --git a/tests/fastcgi.t b/tests/fastcgi.t deleted file mode 100755 index 37b82f71..00000000 --- a/tests/fastcgi.t +++ /dev/null @@ -1,233 +0,0 @@ -#!/usr/bin/env perl -BEGIN { - # add current source dir to the include-path - # we need this for make distcheck - (my $srcdir = $0) =~ s,/[^/]+$,/,; - unshift @INC, $srcdir; -} - -use strict; -use Test::More tests => 32; -use LightyTest; - -my $tf = LightyTest->new(); - -my $t; -my $php_child = -1; - -my $phpbin = (defined $ENV{'PHP'} ? $ENV{'PHP'} : '/usr/bin/php-cgi'); - -SKIP: { - skip "PHP already running on port 1026", 1 if $tf->listening_on(1026); - skip "no php binary found", 1 unless -x $phpbin; - ok(-1 != ($php_child = $tf->spawnfcgi($phpbin, 1026)), "Spawning php"); -} - -SKIP: { - skip "no PHP running on port 1026", 30 unless $tf->listening_on(1026); - - ok($tf->start_proc == 0, "Starting lighttpd") or goto cleanup; - - $t->{REQUEST} = ( <<EOF -POST /get-post-md5.php?var=content HTTP/1.0 -Host: zzz.example.org -Content-Type: application/x-www-form-urlencoded -Content-Length: 11 - -content=abc -EOF - ); - $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200, 'HTTP-Content' => '900150983cd24fb0d6963f7d28e17f72' } ]; - ok($tf->handle_http($t) == 0, 'Post data'); - - $t->{REQUEST} = ( <<EOF -GET /phpinfo.php HTTP/1.0 -Host: www.example.org -EOF - ); - $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200 } ]; - ok($tf->handle_http($t) == 0, 'valid request'); - - $t->{REQUEST} = ( <<EOF -GET /phpinfofoobar.php HTTP/1.0 -Host: www.example.org -EOF - ); - $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 404 } ]; - ok($tf->handle_http($t) == 0, 'file not found'); - - $t->{REQUEST} = ( <<EOF -GET /go/ HTTP/1.0 -Host: www.example.org -EOF - ); - $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200 } ]; - ok($tf->handle_http($t) == 0, 'index-file handling'); - - $t->{REQUEST} = ( <<EOF -GET /redirect.php HTTP/1.0 -Host: www.example.org -EOF - ); - $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 302, 'Location' => 'http://www.example.org:2048/' } ]; - ok($tf->handle_http($t) == 0, 'Status + Location via FastCGI'); - - $t->{REQUEST} = ( <<EOF -GET /get-server-env.php?env=PHP_SELF HTTP/1.0 -Host: www.example.org -EOF - ); - $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200 } ]; - ok($tf->handle_http($t) == 0, '$_SERVER["PHP_SELF"]'); - - $t->{REQUEST} = ( <<EOF -GET /get-server-env.php/foo?env=SCRIPT_NAME HTTP/1.0 -Host: www.example.org -EOF - ); - $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200, 'HTTP-Content' => '/get-server-env.php' } ]; - ok($tf->handle_http($t) == 0, '$_SERVER["SCRIPT_NAME"]'); - - $t->{REQUEST} = ( <<EOF -GET /get-server-env.php/foo?env=PATH_INFO HTTP/1.0 -Host: www.example.org -EOF - ); - $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200, 'HTTP-Content' => '/foo' } ]; - ok($tf->handle_http($t) == 0, '$_SERVER["PATH_INFO"]'); - - $t->{REQUEST} = ( <<EOF -GET /get-server-env.php?env=SERVER_NAME HTTP/1.0 -Host: www.example.org -EOF - ); - $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200, 'HTTP-Content' => 'www.example.org' } ]; - ok($tf->handle_http($t) == 0, 'SERVER_NAME'); - - $t->{REQUEST} = ( <<EOF -GET /get-server-env.php?env=SERVER_NAME HTTP/1.0 -Host: foo.example.org -EOF - ); - $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200, 'HTTP-Content' => 'www.example.org' } ]; - ok($tf->handle_http($t) == 0, 'SERVER_NAME'); - - $t->{REQUEST} = ( <<EOF -GET /get-server-env.php?env=SERVER_NAME HTTP/1.0 -Host: vvv.example.org -EOF - ); - $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200, 'HTTP-Content' => 'www.example.org' } ]; - ok($tf->handle_http($t) == 0, 'SERVER_NAME'); - - $t->{REQUEST} = ( <<EOF -GET /get-server-env.php?env=SERVER_NAME HTTP/1.0 -Host: zzz.example.org -EOF - ); - $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200, 'HTTP-Content' => 'zzz.example.org' } ]; - ok($tf->handle_http($t) == 0, 'SERVER_NAME'); - - $t->{REQUEST} = ( <<EOF -GET /cgi.php/abc HTTP/1.0 -EOF - ); - $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200 } ]; - ok($tf->handle_http($t) == 0, 'PATHINFO'); - - $t->{REQUEST} = ( <<EOF -GET /cgi.php%20%20%20 HTTP/1.0 -EOF - ); - $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 404 } ]; - ok($tf->handle_http($t) == 0, 'No source retrieval'); - - $t->{REQUEST} = ( <<EOF -GET /www/abc/def HTTP/1.0 -EOF - ); - $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 404 } ]; - ok($tf->handle_http($t) == 0, 'PATHINFO on a directory'); - - $t->{REQUEST} = ( <<EOF -GET /indexfile/ HTTP/1.0 -EOF - ); - $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200, 'HTTP-Content' => '/indexfile/index.php' } ]; - ok($tf->handle_http($t) == 0, 'PHP_SELF + Indexfile, Bug #3'); - - $t->{REQUEST} = ( <<EOF -GET /prefix.fcgi?var=SCRIPT_NAME HTTP/1.0 -EOF - ); - $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200, 'HTTP-Content' => '/prefix.fcgi' } ]; - ok($tf->handle_http($t) == 0, 'PATH_INFO, check-local off'); - - $t->{REQUEST} = ( <<EOF -GET /prefix.fcgi/foo/bar?var=SCRIPT_NAME HTTP/1.0 -EOF - ); - $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200, 'HTTP-Content' => '/prefix.fcgi' } ]; - ok($tf->handle_http($t) == 0, 'PATH_INFO, check-local off'); - - $t->{REQUEST} = ( <<EOF -GET /prefix.fcgi/foo/bar?var=PATH_INFO HTTP/1.0 -EOF - ); - $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200, 'HTTP-Content' => '/foo/bar' } ]; - ok($tf->handle_http($t) == 0, 'PATH_INFO, check-local off'); - - - ok($tf->stop_proc == 0, "Stopping lighttpd"); - - - $tf->{CONFIGFILE} = 'fastcgi-10.conf'; - ok($tf->start_proc == 0, "Starting lighttpd with $tf->{CONFIGFILE}") or goto cleanup; - $t->{REQUEST} = ( <<EOF -GET /get-server-env.php?env=SERVER_NAME HTTP/1.0 -Host: zzz.example.org -EOF - ); - $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200, 'HTTP-Content' => 'zzz.example.org' } ]; - ok($tf->handle_http($t) == 0, 'FastCGI + Host'); - - ok($tf->stop_proc == 0, "Stopping lighttpd"); - - $tf->{CONFIGFILE} = 'bug-06.conf'; - ok($tf->start_proc == 0, "Starting lighttpd with $tf->{CONFIGFILE}") or goto cleanup; - $t->{REQUEST} = ( <<EOF -GET /indexfile/ HTTP/1.0 -Host: www.example.org -EOF - ); - $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 200, 'HTTP-Content' => '/indexfile/index.php' } ]; - ok($tf->handle_http($t) == 0, 'Bug #6'); - - ok($tf->stop_proc == 0, "Stopping lighttpd"); - - $tf->{CONFIGFILE} = 'bug-12.conf'; - ok($tf->start_proc == 0, "Starting lighttpd with bug-12.conf") or goto cleanup; - $t->{REQUEST} = ( <<EOF -POST /indexfile/abc HTTP/1.0 -Host: www.example.org -Content-Length: 0 -EOF - ); - $t->{RESPONSE} = [ { 'HTTP-Protocol' => 'HTTP/1.0', 'HTTP-Status' => 404, 'HTTP-Content' => '/indexfile/return-404.php' } ]; - ok($tf->handle_http($t) == 0, 'Bug #12'); - - ok($tf->stop_proc == 0, "Stopping lighttpd"); -} - -SKIP: { - skip "PHP not started, cannot stop it", 1 unless $php_child != -1; - ok(0 == $tf->endspawnfcgi($php_child), "Stopping php"); -} - -exit 0; - -cleanup: ; - -$tf->endspawnfcgi($php_child) if $php_child != -1; - -die(); |