Blame SOURCES/m2crypto-0.21.1-tests-random-ports.patch

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)