1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74
|
#!/usr/bin/env perl
##################################################
use strict;
use Test::More;
use Data::Dumper;
use FindBin qw($Bin);
use lib 't';
if($ENV{TEST_AUTHOR}) {
eval "use HTTP::Server::Simple::CGI";
if($@) {
plan skip_all => 'HTTP::Server::Simple::CGI required';
}
else{
plan tests => 6;
}
}
else{
plan skip_all => 'Author test. Set $ENV{TEST_AUTHOR} to a true value to run.';
}
use_ok('Webinject');
my $webinject = Webinject->new();
isa_ok($webinject, "Webinject", 'Object is a Webinject');
require TestWebServer;
TestWebServer->start_webserver();
##################################################
# start our test cases
test_case_01();
##################################################
# SUBs
##################################################
##################################################
# Test 01
sub test_case_01 {
my $webinject = Webinject->new("httpauth" => 'localhost:58080:my_realm:user:pass');
my $case = {
'logresponse' => 'yes',
'logrequest' => 'yes',
'verifyresponsecode' => 200,
'url' => 'http://localhost:58080/auth',
};
my $expected = {
'id' => 1,
'passedcount' => 1,
'failedcount' => 0,
'url' => $case->{'url'},
'logresponse' => 'yes',
'logrequest' => 'yes',
'verifyresponsecode' => 200,
'iswarning' => 0,
'iscritical' => 0,
};
my $result = $webinject->_run_test_case($case);
is($result->{'latency'} < 1, 1, '01 - auth - latency');
delete $result->{'messages'};
delete $result->{'latency'};
delete $result->{'response'};
delete $result->{'request'};
is_deeply($result, $expected, '01 - auth - result') or BAIL_OUT("expected: \n".Dumper($expected)."\nresult: \n".Dumper($result));
is($webinject->{'result'}->{'iscritical'}, 0, '01 - auth - iscritical');
is($webinject->{'result'}->{'iswarning'}, 0, '01 - auth - iswarning');
}
|