From 288b742ed61bb62a210fdd3614d4e3883aa82407 Mon Sep 17 00:00:00 2001 From: Ton Voon Date: Sat, 8 Nov 2008 02:08:56 +0000 Subject: check_http now has options to specify the HTTP method (Jan - 2155152) git-svn-id: https://nagiosplug.svn.sourceforge.net/svnroot/nagiosplug/nagiosplug/trunk@2075 f882894a-f735-0410-b71e-b25c423dba1c --- plugins/tests/check_http.t | 69 +++++++++++++++++++++++++++++++++++++++++++--- 1 file changed, 65 insertions(+), 4 deletions(-) (limited to 'plugins/tests') diff --git a/plugins/tests/check_http.t b/plugins/tests/check_http.t index 6b932d9d..d54932e6 100755 --- a/plugins/tests/check_http.t +++ b/plugins/tests/check_http.t @@ -33,9 +33,7 @@ if ($pid) { print "Please contact me at: url, ">\n"; while (my $c = $d->accept ) { while (my $r = $c->get_request) { - if ($r->method eq "GET" and $r->url->path eq "/xyzzy") { - $c->send_file_response("/etc/passwd"); - } elsif ($r->method eq "GET" and $r->url->path =~ m^/statuscode/(\d+)^) { + if ($r->method eq "GET" and $r->url->path =~ m^/statuscode/(\d+)^) { $c->send_basic_header($1); $c->send_crlf; } elsif ($r->method eq "GET" and $r->url->path =~ m^/file/(.*)^) { @@ -47,6 +45,18 @@ if ($pid) { $c->send_crlf; sleep 1; $c->send_response("slow"); + } elsif ($r->url->path eq "/method") { + if ($r->method eq "DELETE") { + $c->send_error(RC_METHOD_NOT_ALLOWED); + } elsif ($r->method eq "foo") { + $c->send_error(RC_NOT_IMPLEMENTED); + } else { + $c->send_status_line(200, $r->method); + } + } elsif ($r->url->path eq "/postdata") { + $c->send_basic_header; + $c->send_crlf; + $c->send_response($r->method.":".$r->content); } else { $c->send_error(RC_FORBIDDEN); } @@ -63,7 +73,7 @@ if ($ARGV[0] && $ARGV[0] eq "-d") { } if (-x "./check_http") { - plan tests => 19; + plan tests => 39; } else { plan skip_all => "No check_http compiled"; } @@ -119,3 +129,54 @@ $result = NPTest->testCmd( $cmd ); is( $result->return_code, 2, $cmd); like( $result->output, '/^HTTP CRITICAL - Invalid HTTP response received from host on port (\d+): HTTP/1.1 203 Non-Authoritative Information/', "Output correct: ".$result->output ); +$cmd = "$command -j HEAD -u /method"; +$result = NPTest->testCmd( $cmd ); +is( $result->return_code, 0, $cmd); +like( $result->output, '/^HTTP OK HTTP/1.1 200 HEAD - 19 bytes in ([\d\.]+) seconds/', "Output correct: ".$result->output ); + +$cmd = "$command -j POST -u /method"; +$result = NPTest->testCmd( $cmd ); +is( $result->return_code, 0, $cmd); +like( $result->output, '/^HTTP OK HTTP/1.1 200 POST - 19 bytes in ([\d\.]+) seconds/', "Output correct: ".$result->output ); + +$cmd = "$command -j GET -u /method"; +$result = NPTest->testCmd( $cmd ); +is( $result->return_code, 0, $cmd); +like( $result->output, '/^HTTP OK HTTP/1.1 200 GET - 18 bytes in ([\d\.]+) seconds/', "Output correct: ".$result->output ); + +$cmd = "$command -u /method"; +$result = NPTest->testCmd( $cmd ); +is( $result->return_code, 0, $cmd); +like( $result->output, '/^HTTP OK HTTP/1.1 200 GET - 18 bytes in ([\d\.]+) seconds/', "Output correct: ".$result->output ); + +$cmd = "$command -P foo -u /method"; +$result = NPTest->testCmd( $cmd ); +is( $result->return_code, 0, $cmd); +like( $result->output, '/^HTTP OK HTTP/1.1 200 POST - 19 bytes in ([\d\.]+) seconds/', "Output correct: ".$result->output ); + +$cmd = "$command -j DELETE -u /method"; +$result = NPTest->testCmd( $cmd ); +is( $result->return_code, 1, $cmd); +like( $result->output, '/^HTTP WARNING: HTTP/1.1 405 Method Not Allowed/', "Output correct: ".$result->output ); + +$cmd = "$command -j foo -u /method"; +$result = NPTest->testCmd( $cmd ); +is( $result->return_code, 2, $cmd); +like( $result->output, '/^HTTP CRITICAL: HTTP/1.1 501 Not Implemented/', "Output correct: ".$result->output ); + +$cmd = "$command -P stufftoinclude -u /postdata -s POST:stufftoinclude"; +$result = NPTest->testCmd( $cmd ); +is( $result->return_code, 0, $cmd); +like( $result->output, '/^HTTP OK HTTP/1.1 200 OK - ([\d\.]+) second/', "Output correct: ".$result->output ); + +$cmd = "$command -j PUT -P stufftoinclude -u /postdata -s PUT:stufftoinclude"; +$result = NPTest->testCmd( $cmd ); +is( $result->return_code, 0, $cmd); +like( $result->output, '/^HTTP OK HTTP/1.1 200 OK - ([\d\.]+) second/', "Output correct: ".$result->output ); + +# To confirm that the free doesn't segfault +$cmd = "$command -P stufftoinclude -j PUT -u /postdata -s PUT:stufftoinclude"; +$result = NPTest->testCmd( $cmd ); +is( $result->return_code, 0, $cmd); +like( $result->output, '/^HTTP OK HTTP/1.1 200 OK - ([\d\.]+) second/', "Output correct: ".$result->output ); + -- cgit v1.2.3-74-g34f1