summaryrefslogtreecommitdiff
path: root/perl/Curl_easy/t/08ssl.t
diff options
context:
space:
mode:
Diffstat (limited to 'perl/Curl_easy/t/08ssl.t')
-rw-r--r--perl/Curl_easy/t/08ssl.t98
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";
+
+}