diff options
Diffstat (limited to 'perl/Curl_easy/t/08ssl.t')
-rw-r--r-- | perl/Curl_easy/t/08ssl.t | 98 |
1 files changed, 98 insertions, 0 deletions
diff --git a/perl/Curl_easy/t/08ssl.t b/perl/Curl_easy/t/08ssl.t new file mode 100644 index 000000000..0da9a556c --- /dev/null +++ b/perl/Curl_easy/t/08ssl.t @@ -0,0 +1,98 @@ +# 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"; + +} |