ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/AnyEvent/t/80_ssltest.t
(Generate patch)

Comparing AnyEvent/t/80_ssltest.t (file contents):
Revision 1.1 by root, Thu Oct 2 08:43:58 2008 UTC vs.
Revision 1.10 by root, Thu Apr 5 06:14:10 2012 UTC

1#!/usr/bin/perl 1#!/usr/bin/perl
2 2
3use Test::More qw(no_plan); 3BEGIN { eval "use Net::SSLeay 1.33 (); 1" or ((print "1..0 # SKIP no usable Net::SSLeay\n"), exit 0) }
4 4
5use Test::More tests => 415;
6
7no warnings;
5use strict qw(vars subs); 8use strict qw(vars subs);
6 9
7use AnyEvent::Socket; 10use AnyEvent::Socket;
8use AnyEvent::Handle; 11use AnyEvent::Handle;
12use AnyEvent::TLS;
9 13
10{ 14my $ctx = new AnyEvent::TLS cert_file => $0;
11 my $ctx = AnyEvent::Handle::TLS_CTX;
12 Net::SSLeay::CTX_use_certificate_chain_file ($ctx, $0)
13 or die "unable to set certificate chain file";
14 Net::SSLeay::CTX_use_PrivateKey_file ($ctx, $0, Net::SSLeay::FILETYPE_PEM ())
15 or die "unable to set private key file";
16}
17 15
18for my $mode (1..5) { 16for my $mode (1..5) {
17 ok (1, "mode $mode");
18
19 my $server_done = AnyEvent->condvar; 19 my $server_done = AnyEvent->condvar;
20 my $client_done = AnyEvent->condvar; 20 my $client_done = AnyEvent->condvar;
21 21
22 my $server_port = AnyEvent->condvar; 22 my $server_port = AnyEvent->condvar;
23 23
28 28
29 ok (1, "server_connect $mode"); 29 ok (1, "server_connect $mode");
30 30
31 my $hd; $hd = new AnyEvent::Handle 31 my $hd; $hd = new AnyEvent::Handle
32 tls => "accept", 32 tls => "accept",
33 tls_ctx => $ctx,
33 fh => $fh, 34 fh => $fh,
34 timeout => 8, 35 timeout => 8,
35 on_error => sub { 36 on_error => sub {
36 ok (0, "server_error <$!>"); 37 ok (0, "server_error <$_[2]>");
37 $server_done->send; undef $hd; 38 $server_done->send; undef $hd;
38 }, 39 },
39 on_eof => sub { 40 on_eof => sub {
40 ok (1, "server_eof"); 41 ok (1, "server_eof");
41 $server_done->send; undef $hd; 42 $server_done->send; undef $hd;
82 83
83 }, sub { 84 }, sub {
84 $server_port->send ($_[2]); 85 $server_port->send ($_[2]);
85 }; 86 };
86 87
87 tcp_connect "localhost", $server_port->recv, sub {
88 my ($fh) = @_;
89
90 ok (1, "client_connect $mode");
91
92 my $hd; $hd = new AnyEvent::Handle 88 my $hd; $hd = new AnyEvent::Handle
89 connect => ["127.0.0.1", $server_port->recv],
93 tls => "connect", 90 tls => "connect",
94 fh => $fh, 91 tls_ctx => $ctx,
95 timeout => 8, 92 timeout => 8,
93 on_connect => sub {
94 ok (1, "client_connect $mode");
95 },
96 on_error => sub { 96 on_error => sub {
97 ok (0, "client_error <$!>"); 97 ok (0, "client_error <$_[2]>");
98 $client_done->send; undef $hd; 98 $client_done->send; undef $hd;
99 }, 99 },
100 on_eof => sub { 100 on_eof => sub {
101 ok (1, "client_eof"); 101 ok (1, "client_eof");
102 $client_done->send; undef $hd; 102 $client_done->send; undef $hd;
103 }; 103 };
104 104
105 if ($mode == 1) { 105 if ($mode == 1) {
106 $hd->push_write ("1\n");
107 $hd->on_drain (sub {
108 ok (1, "client_drain");
109 $client_done->send; undef $hd;
110 });
111 } elsif ($mode == 2) {
112 $hd->push_read (line => sub {
113 ok ($_[1] eq "2", "line 2 <$_[1]>");
114 });
115 } elsif ($mode == 3) {
116 $hd->push_write ("3\n");
117 $hd->push_read (line => sub {
118 ok ($_[1] eq "4", "line 4 <$_[1]>");
119 });
120 } elsif ($mode == 4) {
121 $hd->push_read (line => sub {
122 ok ($_[1] eq "5", "line 5 <$_[1]>");
106 $hd->push_write ("1\n"); 123 $hd->push_write ("6\n");
107 $hd->on_drain (sub { 124 $hd->on_drain (sub {
108 ok (1, "client_drain"); 125 ok (1, "client_drain");
109 $client_done->send; undef $hd; 126 $client_done->send; undef $hd;
110 }); 127 });
128 });
111 } elsif ($mode == 2) { 129 } elsif ($mode == 5) {
112 $hd->push_read (line => sub { 130 # some randomly-sized blocks
113 ok ($_[1] eq "2", "line 2 <$_[1]>"); 131 srand 0;
114 }); 132 my $cnt = 64;
115 } elsif ($mode == 3) { 133 my $block; $block = sub {
134 my $len = (16 << int rand 14) - 16 + int rand 32;
135 ok (1, "write $len");
116 $hd->push_write ("3\n"); 136 $hd->push_write ("$len\n");
117 $hd->push_read (line => sub { 137 $hd->push_write (packstring => "N", "\x00" x $len);
118 ok ($_[1] eq "4", "line 4 <$_[1]>");
119 }); 138 };
120 } elsif ($mode == 4) { 139
140 for my $i (1..$cnt) {
141 $hd->push_read (line => sub {
142 my ($i, $cnt, $block) = ($i, $cnt, $block); # 5.8.9. bug workaround
143 my $len = $_[1];
144 ok (1, "client block $len/1");
121 $hd->push_read (line => sub { 145 $hd->unshift_read (packstring => "N", sub {
122 ok ($_[1] eq "5", "line 5 <$_[1]>"); 146 ok ($len == length $_[1], "client block $len/2");
123 $hd->push_write ("6\n"); 147
124 $hd->on_drain (sub { 148 if ($i != $cnt) {
149 $block->();
150 } else {
125 ok (1, "client_drain"); 151 ok (1, "client_drain 5");
126 $client_done->send; undef $hd; 152 $client_done->send; undef $hd;
153 }
127 }); 154 });
128 }); 155 });
129 } elsif ($mode == 5) {
130 # some randomly-sized blocks
131 srand 0;
132 my $cnt = 64;
133 my $block; $block = sub {
134 my $len = (16 << int rand 14) - 16 + int rand 32;
135 ok (1, "write $len");
136 $hd->push_write ("$len\n");
137 $hd->push_write (packstring => "N", "\x00" x $len);
138 };
139
140 for my $i (1..$cnt) {
141 $hd->push_read (line => sub {
142 my $len = $_[1];
143 ok (1, "client block $len/1");
144 $hd->unshift_read (packstring => "N", sub {
145 ok ($len == length $_[1], "client block $len/2");
146
147 if ($i != $cnt) {
148 $block->();
149 } else {
150 ok (1, "client_drain");
151 $client_done->send; undef $hd;
152 }
153 });
154 });
155 }
156
157 $block->();
158 } 156 }
157
158 $block->();
159 }; 159 }
160 160
161 $server_done->recv; 161 $server_done->recv;
162 $client_done->recv; 162 $client_done->recv;
163} 163}
164 164
165__END__ 165__END__
166-----BEGIN RSA PRIVATE KEY-----
167MIIEpAIBAAKCAQEA02VwAqlQzCrPenkxUjawHcXzJreJ9LDhX7Bkg3E/RB6Ilm4D
168LBeilCmzkY7avp57+WCiVw2qkg+kH4Ef2sd+r10UCGPh/1diLehRAzp3Ho1bixyg
169w+zkDm79OnN3uHxuKigkAxx3GGz9HhQA83U+RUns+39/OnFh0RY6/f5rV2ziA9jD
1706HK3Mnsuxocd46YbVdiqlQK430CgiGj8dV44JG6+R6x3r5qXDbbRtGubC29kQOUq
171kYslbpTo7ml8ShyqAP6qa8BpeSIaNG1CQQ/7JkAdxSWyFHqMQ0HR3BUiaEfUElZt
172DFgXcCkKB5F8jx+wYoLzlPHHZaUvfP2nueYjcwIDAQABAoIBAQCtRDMuu0ByV5R/
173Od5nGFP500mcrkrwuBnBqH56DdRhLPWe9sS62xRyhEuePoykOJo8qCvnVlg8J33K
174JLfLRkBb09qbleKiuyjJn+Tm1IDWFd62gtxyOjQicG41/nZeS/6vpv79XdNvvcUp
175ZhPxeGN1v0XyTWomqNAX5DSuAl5Q5HxkaRYNeuLZaPYkqmEVTgYqNSes/wRLKUb6
176MaVrZ9AA/oHJMmmV4evf06s7l7ICjxAWeas7CI6UGkEz8ZFoVRJsLk5xtTsnZLgf
177f24/pqHz1vApPs7CsJhK2HsLZcxMPD+hmTNI/Njl51WoH8zGhkv+p88vDzybpNSF
178Hpkl+ZlBAoGBAOyfjVLD0OznJKSFksoCZKS4dlPHgXUb47Qb/XchIySQ/DNO6ff9
179AA6r6doDFp51A8N1GRtGQN4LKujFPOdZ5ah7zbc2PfuOJGHku0Oby+ydgHJ19eW4
180s3CIM20TuzLndFPrEGFgOrt+i5qKisti2OOZhjsDwfd48vsBm9U20lUpAoGBAOS1
181Chm+vA7JevPzl+acbDSiyELaNRAXZ73CX4NIxJURjsgDeOurnBtLQEQyagZbNHcx
182W4pc59Ql5KDLzu/Sne8oC3pxhaWeIPhc2d3cd/8UyGtQLtN2QnilwkjHgi3x1JGb
183RPRsgAV6nwn10qUrze1XLkHsTCRI4QYD/k0uXcs7AoGBAMStJaFag2i2Ax4ArG7e
184KFtFu4yNckwtv0kwTrBbScOWAxp+iDiJASgwunJsSLuylUs8JH8oGLi23ZaWgrXl
185Yd918BpNqp1Rm2oG3aQndguZKm95Hscvi26Itv39/YYlHeq2omndu1OmrlDowM6m
186vZIIRKr+x5Vz4brCro09QPxpAoGARJAdghBTEl/Gc2HgdOsJ6VGvlZMS+0r498NQ
187nOvwuvuzgTTBSG1+9BPAJXGzpUosVVs/pSArA8eEXcwbsnvCixLHNiLYPQlFuw8i
1885UcV1iul1b4I+63lSYPv1Z+x4BIydqBEsL3iN0JGcVb3mjqilndfT7YGMY6DnykN
189UJgI2EcCgYAMfZHnD06XFM8ny+NsFILItpGqjCmAhkEPGwl1Zhy5Hx16CFDPDwGt
190CmIbxNSLsDyiiK+i5tuSUFhV2Bw/iT539979INTIdNL1ughfhATR8MVNiOKCvZBa
191uoEeE19szmG7Mj2eV2IDH0e8iaikjRFcfN89s39tNn1AjBNmEccUJA==
192-----END RSA PRIVATE KEY-----
193-----
166-----BEGIN CERTIFICATE----- 194-----BEGIN CERTIFICATE-----
167MIIDJjCCAtCgAwIBAgIJAJ3NPnD6z5+2MA0GCSqGSIb3DQEBBQUAMIGWMQswCQYD 195MIIDHTCCAgWgAwIBAgIJAPASTbY2HCx0MA0GCSqGSIb3DQEBBQUAMBMxETAPBgNV
168VQQGEwJYTjETMBEGA1UECBMKU29tZS1TdGF0ZTESMBAGA1UEBxMJU29tZS1DaXR5 196BAMTCEFueUV2ZW50MB4XDTEyMDQwNTA1NTk1MFoXDTM3MDQwNTA1NTk1MFowEzER
169MRUwEwYDVQQKEwxTb21lLUNvbXBhbnkxEjAQBgNVBAsTCVNvbWUtVW5pdDEQMA4G 197MA8GA1UEAxMIQW55RXZlbnQwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB
170A1UEAxMHU29tZS1DTjEhMB8GCSqGSIb3DQEJARYSc29tZUBlbWFpbC5pbnZhbGlk 198AQDTZXACqVDMKs96eTFSNrAdxfMmt4n0sOFfsGSDcT9EHoiWbgMsF6KUKbORjtq+
171MB4XDTA4MTAwMTA3NDk1OFoXDTM5MDMwODA3NDk1OFowgZYxCzAJBgNVBAYTAlhO 199nnv5YKJXDaqSD6QfgR/ax36vXRQIY+H/V2It6FEDOncejVuLHKDD7OQObv06c3e4
172MRMwEQYDVQQIEwpTb21lLVN0YXRlMRIwEAYDVQQHEwlTb21lLUNpdHkxFTATBgNV 200fG4qKCQDHHcYbP0eFADzdT5FSez7f386cWHRFjr9/mtXbOID2MPocrcyey7Ghx3j
173BAoTDFNvbWUtQ29tcGFueTESMBAGA1UECxMJU29tZS1Vbml0MRAwDgYDVQQDEwdT 201phtV2KqVArjfQKCIaPx1Xjgkbr5HrHevmpcNttG0a5sLb2RA5SqRiyVulOjuaXxK
174b21lLUNOMSEwHwYJKoZIhvcNAQkBFhJzb21lQGVtYWlsLmludmFsaWQwXDANBgkq 202HKoA/qprwGl5Iho0bUJBD/smQB3FJbIUeoxDQdHcFSJoR9QSVm0MWBdwKQoHkXyP
175hkiG9w0BAQEFAANLADBIAkEAvdBuyGvUQ2YDMfEhEi9Rogbz48KNzvF1csGb5qwE 203H7BigvOU8cdlpS98/ae55iNzAgMBAAGjdDByMB0GA1UdDgQWBBTHphJ9Il0PtIWD
1768y7QA9BVBclFMvcO55FQHnWECBI+DNKeP6vJlXN1wMRH5QIDAQABo4H+MIH7MB0G 204DI9aueToXo9DYzBDBgNVHSMEPDA6gBTHphJ9Il0PtIWDDI9aueToXo9DY6EXpBUw
177A1UdDgQWBBScspJuXxPCTlFAyiMeXa6j/zW8ATCBywYDVR0jBIHDMIHAgBScspJu 205EzERMA8GA1UEAxMIQW55RXZlbnSCCQDwEk22NhwsdDAMBgNVHRMEBTADAQH/MA0G
178XxPCTlFAyiMeXa6j/zW8AaGBnKSBmTCBljELMAkGA1UEBhMCWE4xEzARBgNVBAgT 206CSqGSIb3DQEBBQUAA4IBAQA/vY+qg2xjNeOuDySW/VOsStEwcaiAm/t24z3TYoZG
179ClNvbWUtU3RhdGUxEjAQBgNVBAcTCVNvbWUtQ2l0eTEVMBMGA1UEChMMU29tZS1D 2072ZzyKuvFXolhXsalCahNPcyUxZqDAekODPRaq+geFaZrOn41cq/LABTKv5Theukv
180b21wYW55MRIwEAYDVQQLEwlTb21lLVVuaXQxEDAOBgNVBAMTB1NvbWUtQ04xITAf 208H7IruIFARBo1pTPFCKMnDqESBdHvV1xTOcKGxGH5I9iMgiUrd/NnlAaloT/cCNFI
181BgkqhkiG9w0BCQEWEnNvbWVAZW1haWwuaW52YWxpZIIJAJ3NPnD6z5+2MAwGA1Ud 209OwhEPsF9kBsZwJBGWrjjVttU2lzMzizS7vaSIWLBuEDObWbSXiU+IdG+nODOe2Dv
182EwQFMAMBAf8wDQYJKoZIhvcNAQEFBQADQQA48HjY23liyBMmh3cNo9TC+/bu/G3E 210W7PL43yd4fz4HQvN4IaZrtwkd7XiKodRR1gWjLjW/3y5kuXL+DA/jkTjrRgiH8K7
183oT5npm3+Lh6VA/4kKMyMu2mP31BToTZfl7vUcBJCQBhPFYOiPd/HnwzW 211lVjm7gvkULRV2POQqtc2DUVXLubQmmGSjmQmxSwFX65t
184-----END CERTIFICATE----- 212-----END CERTIFICATE-----
185-----BEGIN RSA PRIVATE KEY-----
186MIIBOwIBAAJBAL3Qbshr1ENmAzHxIRIvUaIG8+PCjc7xdXLBm+asBPMu0APQVQXJ
187RTL3DueRUB51hAgSPgzSnj+ryZVzdcDER+UCAwEAAQJAGRftDWHz9dUOpxORo63N
188xPXWWE3oIWuac0lVKvGi1eMoI4UCW/Y7qM4rXsUXqasUo3mxV24+QqJHDQid1qi6
189AQIhAN5BtiqfjFjb97uUbdE6aiqE+nSG0eXlkeHKNpBNtiUxAiEA2qHNZ5fcQTqT
1904qlnYhbI+g6bTwuR7QnzzGTlHUGxsPUCIQDLfvTw37Zb4cNYb1WBPW/ZUHoU2SAz
19101cXmdMNmumL8QIhAJMGTENl9FBJPDopAcUM3YqLWBYICdIF51WEZC8QhpYhAiBe
192KcoNT51hv3pKK8oZtPJGsKFjmGVVnZeNNzyQmt/YWw==
193-----END RSA PRIVATE KEY-----
194
195
196

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines