|
|
71c899 |
Pouze v M2Crypto-0.21.1: randpool.dat
|
|
|
71c899 |
diff -ur M2Crypto/tests/test_bio_ssl.py M2Crypto-0.21.1/tests/test_bio_ssl.py
|
|
|
71c899 |
--- M2Crypto/tests/test_bio_ssl.py 2011-01-15 20:10:05.000000000 +0100
|
|
|
71c899 |
+++ M2Crypto-0.21.1/tests/test_bio_ssl.py 2014-01-06 23:31:47.709383892 +0100
|
|
|
71c899 |
@@ -11,7 +11,7 @@
|
|
|
71c899 |
from M2Crypto import Rand
|
|
|
71c899 |
from M2Crypto import threading as m2threading
|
|
|
71c899 |
|
|
|
71c899 |
-from test_ssl import srv_host, srv_port
|
|
|
71c899 |
+from test_ssl import srv_host, allocate_srv_port
|
|
|
71c899 |
|
|
|
71c899 |
class HandshakeClient(threading.Thread):
|
|
|
71c899 |
|
|
|
71c899 |
@@ -113,6 +113,7 @@
|
|
|
71c899 |
conn.set_bio(readbio, writebio)
|
|
|
71c899 |
conn.set_accept_state()
|
|
|
71c899 |
handshake_complete = False
|
|
|
71c899 |
+ srv_port = allocate_srv_port()
|
|
|
71c899 |
sock = socket.socket()
|
|
|
71c899 |
sock.bind((srv_host, srv_port))
|
|
|
71c899 |
sock.listen(5)
|
|
|
71c899 |
diff -ur M2Crypto/tests/test_ssl.py M2Crypto-0.21.1/tests/test_ssl.py
|
|
|
71c899 |
--- M2Crypto/tests/test_ssl.py 2014-01-06 22:49:57.961307007 +0100
|
|
|
71c899 |
+++ M2Crypto-0.21.1/tests/test_ssl.py 2014-01-06 23:30:13.856457390 +0100
|
|
|
71c899 |
@@ -26,7 +26,16 @@
|
|
|
71c899 |
from fips import fips_mode
|
|
|
71c899 |
|
|
|
71c899 |
srv_host = 'localhost'
|
|
|
71c899 |
-srv_port = 64000
|
|
|
71c899 |
+
|
|
|
71c899 |
+def allocate_srv_port():
|
|
|
71c899 |
+ s = socket.socket()
|
|
|
71c899 |
+ try:
|
|
|
71c899 |
+ s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
|
|
|
71c899 |
+ s.bind((srv_host, 0))
|
|
|
71c899 |
+ (host, port) = s.getsockname()
|
|
|
71c899 |
+ finally:
|
|
|
71c899 |
+ s.close()
|
|
|
71c899 |
+ return port
|
|
|
71c899 |
|
|
|
71c899 |
def verify_cb_new_function(ok, store):
|
|
|
71c899 |
try:
|
|
|
71c899 |
@@ -113,17 +122,13 @@
|
|
|
71c899 |
|
|
|
71c899 |
def setUp(self):
|
|
|
71c899 |
self.srv_host = srv_host
|
|
|
71c899 |
- self.srv_port = srv_port
|
|
|
71c899 |
- self.srv_addr = (srv_host, srv_port)
|
|
|
71c899 |
- self.srv_url = 'https://%s:%s/' % (srv_host, srv_port)
|
|
|
71c899 |
+ self.srv_port = allocate_srv_port()
|
|
|
71c899 |
+ self.srv_addr = (srv_host, self.srv_port)
|
|
|
71c899 |
+ self.srv_url = 'https://%s:%s/' % (srv_host, self.srv_port)
|
|
|
71c899 |
self.args = ['s_server', '-quiet', '-www',
|
|
|
71c899 |
#'-cert', 'server.pem', Implicitly using this
|
|
|
71c899 |
'-accept', str(self.srv_port)]
|
|
|
71c899 |
|
|
|
71c899 |
- def tearDown(self):
|
|
|
71c899 |
- global srv_port
|
|
|
71c899 |
- srv_port = srv_port - 1
|
|
|
71c899 |
-
|
|
|
71c899 |
|
|
|
71c899 |
class PassSSLClientTestCase(BaseSSLClientTestCase):
|
|
|
71c899 |
|
|
|
71c899 |
@@ -136,7 +141,7 @@
|
|
|
71c899 |
pid = self.start_server(self.args)
|
|
|
71c899 |
try:
|
|
|
71c899 |
from M2Crypto import httpslib
|
|
|
71c899 |
- c = httpslib.HTTPSConnection(srv_host, srv_port)
|
|
|
71c899 |
+ c = httpslib.HTTPSConnection(srv_host, self.srv_port)
|
|
|
71c899 |
c.request('GET', '/')
|
|
|
71c899 |
data = c.getresponse().read()
|
|
|
71c899 |
c.close()
|
|
|
71c899 |
@@ -153,7 +158,7 @@
|
|
|
71c899 |
ctx.load_cert('tests/x509.pem')
|
|
|
71c899 |
ctx.set_verify(SSL.verify_peer | SSL.verify_fail_if_no_peer_cert, 1)
|
|
|
71c899 |
ctx.set_session_cache_mode(m2.SSL_SESS_CACHE_CLIENT)
|
|
|
71c899 |
- c = httpslib.HTTPSConnection(srv_host, srv_port, ssl_context=ctx)
|
|
|
71c899 |
+ c = httpslib.HTTPSConnection(srv_host, self.srv_port, ssl_context=ctx)
|
|
|
71c899 |
c.request('GET', '/')
|
|
|
71c899 |
ses = c.get_session()
|
|
|
71c899 |
t = ses.as_text()
|
|
|
71c899 |
@@ -166,7 +171,7 @@
|
|
|
71c899 |
ctx2.load_cert('tests/x509.pem')
|
|
|
71c899 |
ctx2.set_verify(SSL.verify_peer | SSL.verify_fail_if_no_peer_cert, 1)
|
|
|
71c899 |
ctx2.set_session_cache_mode(m2.SSL_SESS_CACHE_CLIENT)
|
|
|
71c899 |
- c2 = httpslib.HTTPSConnection(srv_host, srv_port, ssl_context=ctx2)
|
|
|
71c899 |
+ c2 = httpslib.HTTPSConnection(srv_host, self.srv_port, ssl_context=ctx2)
|
|
|
71c899 |
c2.set_session(ses)
|
|
|
71c899 |
c2.request('GET', '/')
|
|
|
71c899 |
ses2 = c2.get_session()
|
|
|
71c899 |
@@ -186,7 +191,7 @@
|
|
|
71c899 |
ctx = SSL.Context()
|
|
|
71c899 |
ctx.set_verify(SSL.verify_peer | SSL.verify_fail_if_no_peer_cert, 9)
|
|
|
71c899 |
ctx.load_verify_locations('tests/ca.pem')
|
|
|
71c899 |
- c = httpslib.HTTPSConnection(srv_host, srv_port, ssl_context=ctx)
|
|
|
71c899 |
+ c = httpslib.HTTPSConnection(srv_host, self.srv_port, ssl_context=ctx)
|
|
|
71c899 |
c.request('GET', '/')
|
|
|
71c899 |
data = c.getresponse().read()
|
|
|
71c899 |
c.close()
|
|
|
71c899 |
@@ -201,7 +206,7 @@
|
|
|
71c899 |
ctx = SSL.Context()
|
|
|
71c899 |
ctx.set_verify(SSL.verify_peer | SSL.verify_fail_if_no_peer_cert, 9)
|
|
|
71c899 |
ctx.load_verify_locations('tests/server.pem')
|
|
|
71c899 |
- c = httpslib.HTTPSConnection(srv_host, srv_port, ssl_context=ctx)
|
|
|
71c899 |
+ c = httpslib.HTTPSConnection(srv_host, self.srv_port, ssl_context=ctx)
|
|
|
71c899 |
self.assertRaises(SSL.SSLError, c.request, 'GET', '/')
|
|
|
71c899 |
c.close()
|
|
|
71c899 |
finally:
|
|
|
71c899 |
@@ -211,7 +216,7 @@
|
|
|
71c899 |
pid = self.start_server(self.args)
|
|
|
71c899 |
try:
|
|
|
71c899 |
from M2Crypto import httpslib
|
|
|
71c899 |
- c = httpslib.HTTPS(srv_host, srv_port)
|
|
|
71c899 |
+ c = httpslib.HTTPS(srv_host, self.srv_port)
|
|
|
71c899 |
c.putrequest('GET', '/')
|
|
|
71c899 |
c.putheader('Accept', 'text/html')
|
|
|
71c899 |
c.putheader('Accept', 'text/plain')
|
|
|
71c899 |
@@ -232,7 +237,7 @@
|
|
|
71c899 |
ctx = SSL.Context()
|
|
|
71c899 |
ctx.set_verify(SSL.verify_peer | SSL.verify_fail_if_no_peer_cert, 9)
|
|
|
71c899 |
ctx.load_verify_locations('tests/ca.pem')
|
|
|
71c899 |
- c = httpslib.HTTPS(srv_host, srv_port, ssl_context=ctx)
|
|
|
71c899 |
+ c = httpslib.HTTPS(srv_host, self.srv_port, ssl_context=ctx)
|
|
|
71c899 |
c.putrequest('GET', '/')
|
|
|
71c899 |
c.putheader('Accept', 'text/html')
|
|
|
71c899 |
c.putheader('Accept', 'text/plain')
|
|
|
71c899 |
@@ -253,7 +258,7 @@
|
|
|
71c899 |
ctx = SSL.Context()
|
|
|
71c899 |
ctx.set_verify(SSL.verify_peer | SSL.verify_fail_if_no_peer_cert, 9)
|
|
|
71c899 |
ctx.load_verify_locations('tests/server.pem')
|
|
|
71c899 |
- c = httpslib.HTTPS(srv_host, srv_port, ssl_context=ctx)
|
|
|
71c899 |
+ c = httpslib.HTTPS(srv_host, self.srv_port, ssl_context=ctx)
|
|
|
71c899 |
c.putrequest('GET', '/')
|
|
|
71c899 |
c.putheader('Accept', 'text/html')
|
|
|
71c899 |
c.putheader('Accept', 'text/plain')
|
|
|
71c899 |
@@ -871,7 +876,7 @@
|
|
|
71c899 |
from M2Crypto import m2urllib
|
|
|
71c899 |
url = m2urllib.FancyURLopener()
|
|
|
71c899 |
url.addheader('Connection', 'close')
|
|
|
71c899 |
- u = url.open('https://%s:%s/' % (srv_host, srv_port))
|
|
|
71c899 |
+ u = url.open('https://%s:%s/' % (srv_host, self.srv_port))
|
|
|
71c899 |
data = u.read()
|
|
|
71c899 |
u.close()
|
|
|
71c899 |
finally:
|
|
|
71c899 |
@@ -896,7 +901,7 @@
|
|
|
71c899 |
from M2Crypto import m2urllib2
|
|
|
71c899 |
opener = m2urllib2.build_opener()
|
|
|
71c899 |
opener.addheaders = [('Connection', 'close')]
|
|
|
71c899 |
- u = opener.open('https://%s:%s/' % (srv_host, srv_port))
|
|
|
71c899 |
+ u = opener.open('https://%s:%s/' % (srv_host, self.srv_port))
|
|
|
71c899 |
data = u.read()
|
|
|
71c899 |
u.close()
|
|
|
71c899 |
finally:
|
|
|
71c899 |
@@ -913,7 +918,7 @@
|
|
|
71c899 |
from M2Crypto import m2urllib2
|
|
|
71c899 |
opener = m2urllib2.build_opener(ctx)
|
|
|
71c899 |
opener.addheaders = [('Connection', 'close')]
|
|
|
71c899 |
- u = opener.open('https://%s:%s/' % (srv_host, srv_port))
|
|
|
71c899 |
+ u = opener.open('https://%s:%s/' % (srv_host, self.srv_port))
|
|
|
71c899 |
data = u.read()
|
|
|
71c899 |
u.close()
|
|
|
71c899 |
finally:
|
|
|
71c899 |
@@ -930,7 +935,7 @@
|
|
|
71c899 |
from M2Crypto import m2urllib2
|
|
|
71c899 |
opener = m2urllib2.build_opener(ctx)
|
|
|
71c899 |
opener.addheaders = [('Connection', 'close')]
|
|
|
71c899 |
- self.assertRaises(SSL.SSLError, opener.open, 'https://%s:%s/' % (srv_host, srv_port))
|
|
|
71c899 |
+ self.assertRaises(SSL.SSLError, opener.open, 'https://%s:%s/' % (srv_host, self.srv_port))
|
|
|
71c899 |
finally:
|
|
|
71c899 |
self.stop_server(pid)
|
|
|
71c899 |
|
|
|
71c899 |
@@ -942,7 +947,7 @@
|
|
|
71c899 |
from M2Crypto import m2urllib2
|
|
|
71c899 |
opener = m2urllib2.build_opener(ctx, m2urllib2.HTTPBasicAuthHandler())
|
|
|
71c899 |
m2urllib2.install_opener(opener)
|
|
|
71c899 |
- req = m2urllib2.Request('https://%s:%s/' % (srv_host, srv_port))
|
|
|
71c899 |
+ req = m2urllib2.Request('https://%s:%s/' % (srv_host, self.srv_port))
|
|
|
71c899 |
u = m2urllib2.urlopen(req)
|
|
|
71c899 |
data = u.read()
|
|
|
71c899 |
u.close()
|
|
|
71c899 |
@@ -963,7 +968,7 @@
|
|
|
71c899 |
import gc
|
|
|
71c899 |
from M2Crypto import m2urllib2
|
|
|
71c899 |
o = m2urllib2.build_opener()
|
|
|
71c899 |
- r = o.open('https://%s:%s/' % (srv_host, srv_port))
|
|
|
71c899 |
+ r = o.open('https://%s:%s/' % (srv_host, self.srv_port))
|
|
|
71c899 |
s = [r.fp._sock.fp]
|
|
|
71c899 |
r.close()
|
|
|
71c899 |
self.assertEqual(len(gc.get_referrers(s[0])), 1)
|
|
|
71c899 |
@@ -990,7 +995,7 @@
|
|
|
71c899 |
pid = self.start_server(self.args)
|
|
|
71c899 |
try:
|
|
|
71c899 |
from M2Crypto import httpslib
|
|
|
71c899 |
- c = httpslib.HTTPS(srv_host, srv_port)
|
|
|
71c899 |
+ c = httpslib.HTTPS(srv_host, self.srv_port)
|
|
|
71c899 |
c.putrequest('GET', '/')
|
|
|
71c899 |
c.putheader('Accept', 'text/html')
|
|
|
71c899 |
c.putheader('Accept', 'text/plain')
|
|
|
71c899 |
@@ -1029,7 +1034,7 @@
|
|
|
71c899 |
pid = self.start_server(self.args)
|
|
|
71c899 |
try:
|
|
|
71c899 |
from M2Crypto import httpslib
|
|
|
71c899 |
- c = httpslib.HTTPS(srv_host, srv_port)
|
|
|
71c899 |
+ c = httpslib.HTTPS(srv_host, self.srv_port)
|
|
|
71c899 |
c.putrequest('GET', '/' + FIFO_NAME)
|
|
|
71c899 |
c.putheader('Accept', 'text/html')
|
|
|
71c899 |
c.putheader('Accept', 'text/plain')
|
|
|
71c899 |
@@ -1086,7 +1091,7 @@
|
|
|
71c899 |
|
|
|
71c899 |
contextFactory = ContextFactory()
|
|
|
71c899 |
factory = EchoClientFactory()
|
|
|
71c899 |
- wrapper.connectSSL(srv_host, srv_port, factory, contextFactory)
|
|
|
71c899 |
+ wrapper.connectSSL(srv_host, self.srv_port, factory, contextFactory)
|
|
|
71c899 |
reactor.run() # This will block until reactor.stop() is called
|
|
|
71c899 |
finally:
|
|
|
71c899 |
self.stop_server(pid)
|