Added support for testind disconnect errors.

This commit is contained in:
Lance Stout 2011-05-27 11:01:30 -07:00
parent ec9aed5b75
commit 384e1a92b7
5 changed files with 55 additions and 2 deletions

View file

@ -58,6 +58,18 @@ class TestLiveSocket(object):
# ------------------------------------------------------------------ # ------------------------------------------------------------------
# Testing Interface # Testing Interface
def disconnect_errror(self):
"""
Used to simulate a socket disconnection error.
Not used by live sockets.
"""
try:
self.socket.shutdown()
self.socket.close()
except:
pass
def next_sent(self, timeout=None): def next_sent(self, timeout=None):
""" """
Get the next stanza that has been sent. Get the next stanza that has been sent.

View file

@ -39,6 +39,7 @@ class TestSocket(object):
self.recv_queue = queue.Queue() self.recv_queue = queue.Queue()
self.send_queue = queue.Queue() self.send_queue = queue.Queue()
self.is_live = False self.is_live = False
self.disconnected = False
def __getattr__(self, name): def __getattr__(self, name):
""" """
@ -89,6 +90,13 @@ class TestSocket(object):
""" """
self.recv_queue.put(data) self.recv_queue.put(data)
def disconnect_error(self):
"""
Simulate a disconnect error by raising a socket.error exception
for any current or further socket operations.
"""
self.disconnected = True
# ------------------------------------------------------------------ # ------------------------------------------------------------------
# Socket Interface # Socket Interface
@ -99,6 +107,8 @@ class TestSocket(object):
Arguments: Arguments:
Placeholders. Same as for socket.Socket.recv. Placeholders. Same as for socket.Socket.recv.
""" """
if self.disconnected:
raise socket.error
return self.read(block=True) return self.read(block=True)
def send(self, data): def send(self, data):
@ -108,6 +118,8 @@ class TestSocket(object):
Arguments: Arguments:
data -- String value to write. data -- String value to write.
""" """
if self.disconnected:
raise socket.error
self.send_queue.put(data) self.send_queue.put(data)
# ------------------------------------------------------------------ # ------------------------------------------------------------------
@ -132,6 +144,8 @@ class TestSocket(object):
timeout -- Time in seconds a block should last before timeout -- Time in seconds a block should last before
returning None. returning None.
""" """
if self.disconnected:
raise socket.error
if timeout is not None: if timeout is not None:
block = True block = True
try: try:

View file

@ -259,6 +259,13 @@ class SleekTest(unittest.TestCase):
# ------------------------------------------------------------------ # ------------------------------------------------------------------
# Methods for simulating stanza streams. # Methods for simulating stanza streams.
def stream_disconnect(self):
"""
Simulate a stream disconnection.
"""
if self.xmpp:
self.xmpp.socket.disconnect_error()
def stream_start(self, mode='client', skip=True, header=None, def stream_start(self, mode='client', skip=True, header=None,
socket='mock', jid='tester@localhost', socket='mock', jid='tester@localhost',
password='test', server='localhost', password='test', server='localhost',

View file

@ -978,7 +978,8 @@ class XMLStream(object):
log.debug("SEND: %s" % data) log.debug("SEND: %s" % data)
try: try:
self.socket.send(data.encode('utf-8')) self.socket.send(data.encode('utf-8'))
except: except Socket.error as serr:
self.event('socket_error', serr)
log.warning("Failed to send %s" % data) log.warning("Failed to send %s" % data)
self.disconnect(self.auto_reconnect) self.disconnect(self.auto_reconnect)
except KeyboardInterrupt: except KeyboardInterrupt:

View file

@ -1,5 +1,5 @@
import time
from sleekxmpp.test import * from sleekxmpp.test import *
import sleekxmpp.plugins.xep_0033 as xep_0033
class TestStreamTester(SleekTest): class TestStreamTester(SleekTest):
@ -57,4 +57,23 @@ class TestStreamTester(SleekTest):
self.stream_start(mode='client', skip=False) self.stream_start(mode='client', skip=False)
self.send_header(sto='localhost') self.send_header(sto='localhost')
def testStreamDisconnect(self):
"""Test that the test socket can simulate disconnections."""
self.stream_start()
events = set()
def stream_error(event):
events.add('socket_error')
self.xmpp.add_event_handler('socket_error', stream_error)
self.stream_disconnect()
self.xmpp.send_raw(' ')
time.sleep(.1)
self.failUnless('socket_error' in events,
"Stream error event not raised: %s" % events)
suite = unittest.TestLoader().loadTestsFromTestCase(TestStreamTester) suite = unittest.TestLoader().loadTestsFromTestCase(TestStreamTester)