Add more debug info and error handling to ssltest

This commit is contained in:
Peter Šurda 2017-01-14 13:55:57 +01:00
parent ff593273bf
commit 6247e1d3ea
Signed by untrusted user: PeterSurda
GPG Key ID: 0C5F50C0B5F37D87

View File

@ -2,6 +2,7 @@ import select
import socket import socket
import ssl import ssl
import sys import sys
import traceback
HOST = "127.0.0.1" HOST = "127.0.0.1"
PORT = 8912 PORT = 8912
@ -55,7 +56,8 @@ def sslHandshake(sock, server=False):
print "Waiting for SSL socket handhake write" print "Waiting for SSL socket handhake write"
select.select([], [self.sslSock], [], 10) select.select([], [self.sslSock], [], 10)
except Exception as e: except Exception as e:
print "SSL socket handhake failed, shutting down connection: %s" % (e) print "SSL socket handhake failed, shutting down connection"
traceback.print_exc()
return return
print "Success!" print "Success!"
return sslSock return sslSock
@ -71,11 +73,13 @@ if __name__ == "__main__":
sock, addr = serversock.accept() sock, addr = serversock.accept()
print "Got connection from %s:%i" % (addr[0], addr[1]) print "Got connection from %s:%i" % (addr[0], addr[1])
sslSock = sslHandshake(sock, True) sslSock = sslHandshake(sock, True)
if sslSock:
sslSock.shutdown(socket.SHUT_RDWR) sslSock.shutdown(socket.SHUT_RDWR)
sslSock.close() sslSock.close()
elif sys.argv[1] == "client": elif sys.argv[1] == "client":
sock = connect() sock = connect()
sslSock = sslHandshake(sock, False) sslSock = sslHandshake(sock, False)
if sslSock:
sslSock.shutdown(socket.SHUT_RDWR) sslSock.shutdown(socket.SHUT_RDWR)
sslSock.close() sslSock.close()
else: else: