summaryrefslogtreecommitdiff
path: root/perl/Curl_easy/t/08ssl.t
blob: 0da9a556ca8ecb6a0401f33ac93cd95af38c3488 (plain)
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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
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";

}