# Test just the SSL support in the socket module, in a moderately bogus way. import sys from test import test_support import socket import time # Optionally test SSL support. This requires the 'network' resource as given # on the regrtest command line. skip_expected = not (test_support.is_resource_enabled('network') and hasattr(socket, "ssl")) def test_basic(): test_support.requires('network') import urllib if test_support.verbose: print "test_basic ..." socket.RAND_status() try: socket.RAND_egd(1) except TypeError: pass else: print "didn't raise TypeError" socket.RAND_add("this is a random string", 75.0) f = urllib.urlopen('https://sf.net') buf = f.read() f.close() def test_timeout(): test_support.requires('network') if test_support.verbose: print "test_timeout ..." # A service which issues a welcome banner (without need to write # anything). # XXX ("gmail.org", 995) has been unreliable so far, from time to time # XXX non-responsive for hours on end (& across all buildbot slaves, # XXX so that's not just a local thing). ADDR = "gmail.org", 995 s = socket.socket() s.settimeout(30.0) try: s.connect(ADDR) except socket.timeout: print >> sys.stderr, """\ WARNING: an attempt to connect to %r timed out, in test_timeout. That may be legitimate, but is not the outcome we hoped for. If this message is seen often, test_timeout should be changed to use a more reliable address.""" % (ADDR,) return ss = socket.ssl(s) # Read part of return welcome banner twice. ss.read(1) ss.read(1) s.close() def test_rude_shutdown(): if test_support.verbose: print "test_rude_shutdown ..." try: import thread except ImportError: return # some random port to connect to PORT = [9934] def listener(): s = socket.socket(socket.AF_INET, socket.SOCK_STREAM) PORT[0] = test_support.bind_port(s, '', PORT[0]) s.listen(5) s.accept() del s thread.exit() def connector(): s = socket.socket(socket.AF_INET, socket.SOCK_STREAM) s.connect(('localhost', PORT[0])) try: ssl_sock = socket.ssl(s) except socket.sslerror: pass else: raise test_support.TestFailed, \ 'connecting to closed SSL socket failed' thread.start_new_thread(listener, ()) time.sleep(1) connector() def test_main(): if not hasattr(socket, "ssl"): raise test_support.TestSkipped("socket module has no ssl support") test_rude_shutdown() test_basic() test_timeout() if __name__ == "__main__": test_main()