99 lines
3.2 KiB
Perl
99 lines
3.2 KiB
Perl
# Test script for Perl extension Curl::easy.
|
|
# Check out the file README for more info.
|
|
|
|
# Before `make install' is performed this script should be runnable with
|
|
# `make t/thisfile.t'. After `make install' it should work as `perl thisfile.t'
|
|
|
|
######################### We start with some black magic to print on failure.
|
|
|
|
# Change 1..1 below to 1..last_test_to_print .
|
|
use strict;
|
|
|
|
BEGIN { $| = 1; print "1..20\n"; }
|
|
END {print "not ok 1\n" unless $::loaded;}
|
|
use Curl::easy;
|
|
|
|
$::loaded = 1;
|
|
print "ok 1\n";
|
|
|
|
######################### End of black magic.
|
|
|
|
# Insert your test code below (better if it prints "ok 13"
|
|
# (correspondingly "not ok 13") depending on the success of chunk 13
|
|
# of the test code):
|
|
|
|
my $count=1;
|
|
|
|
# list of tests
|
|
# site-url, verifypeer(0,1), verifyhost(0,2), result(0=ok, 1=fail)
|
|
my $url_list=[
|
|
[ 'https://216.168.252.86/', 0, 0, 0 ], # www.awayweb.com
|
|
[ 'https://216.168.252.86/', 0, 2, 1 ], # www.awayweb.com
|
|
[ 'https://www.verisign.com/', 0, 0, 0 ],
|
|
[ 'https://www.verisign.com/', 0, 2, 0 ],
|
|
[ 'https://www.verisign.com/', 1, 2, 0 ], # these fail on openssl0.9.5 - unknown sig
|
|
[ 'https://www.verisign.com/', 1, 2, 0 ], # these fail on openssl0.9.5 - unknown sig
|
|
[ 'https://lc2.law13.hotmail.passport.com/', 0, 0, 0 ],
|
|
[ 'https://lc2.law13.hotmail.passport.com/', 0, 2, 0 ],
|
|
[ 'https://lc2.law13.hotmail.passport.com/', 1, 2, 0 ], # fail on 0.9.5
|
|
[ 'https://lc2.law13.hotmail.passport.com/', 1, 2, 0 ], # fail on 0.9.5
|
|
[ 'https://www.modssl.org/', 0, 0, 0 ],
|
|
[ 'https://www.modssl.org/', 0, 2, 0 ],
|
|
[ 'https://www.modssl.org/', 1, 0, 1 ],
|
|
[ 'https://www.modssl.org/', 1, 2, 1 ],
|
|
];
|
|
|
|
# Init the curl session
|
|
my $curl = Curl::easy::init();
|
|
if ($curl == 0) {
|
|
print "not ";
|
|
}
|
|
print "ok ".++$count."\n";
|
|
|
|
|
|
Curl::easy::setopt($curl, CURLOPT_NOPROGRESS, 1);
|
|
Curl::easy::setopt($curl, CURLOPT_MUTE, 0);
|
|
#Curl::easy::setopt($curl, CURLOPT_FOLLOWLOCATION, 1);
|
|
Curl::easy::setopt($curl, CURLOPT_TIMEOUT, 30);
|
|
|
|
my @myheaders;
|
|
$myheaders[1] = "User-Agent: Verifying SSL functions in perl interface for libcURL";
|
|
Curl::easy::setopt($curl, CURLOPT_HTTPHEADER, \@myheaders);
|
|
|
|
open HEAD, ">head.out";
|
|
Curl::easy::setopt($curl, CURLOPT_WRITEHEADER, *HEAD);
|
|
print "ok ".++$count."\n";
|
|
|
|
open BODY, ">body.out";
|
|
Curl::easy::setopt($curl, CURLOPT_FILE,*BODY);
|
|
print "ok ".++$count."\n";
|
|
|
|
my $errbuf;
|
|
Curl::easy::setopt($curl, CURLOPT_ERRORBUFFER, "errbuf");
|
|
print "ok ".++$count."\n";
|
|
|
|
Curl::easy::setopt($curl, CURLOPT_FORBID_REUSE, 1);
|
|
|
|
|
|
print "ok ".++$count."\n";
|
|
Curl::easy::setopt($curl, CURLOPT_CAINFO,"ca-bundle.crt");
|
|
|
|
foreach my $test_list (@$url_list) {
|
|
my ($url,$verifypeer,$verifyhost,$result)=@{$test_list};
|
|
print STDERR "testing $url verify=$verifypeer at level $verifyhost expect ".($result?"fail":"pass")."\n";
|
|
|
|
Curl::easy::setopt($curl, CURLOPT_SSL_VERIFYPEER,$verifypeer); # do verify
|
|
Curl::easy::setopt($curl, CURLOPT_SSL_VERIFYHOST,$verifyhost); # check name
|
|
my $retcode;
|
|
|
|
Curl::easy::setopt($curl, CURLOPT_URL, $url);
|
|
|
|
$retcode=Curl::easy::perform($curl);
|
|
if ( ($retcode != 0) != $result) {
|
|
print STDERR "error $retcode $errbuf\n";
|
|
print "not ";
|
|
};
|
|
print "ok ".++$count."\n";
|
|
|
|
}
|