diff options
author | Lance Stout <lancestout@gmail.com> | 2010-11-17 15:45:16 -0500 |
---|---|---|
committer | Lance Stout <lancestout@gmail.com> | 2010-11-17 15:45:16 -0500 |
commit | ea48bb5ac58aa186c18c42c83e21a6a636bd22a9 (patch) | |
tree | d04eb4d423b9ec9c35e5636a649a0dccdd2ca862 /sleekxmpp/test/sleektest.py | |
parent | 6ee8a2980c2a7c9a8c65453b1d2c551717069ce5 (diff) | |
download | slixmpp-ea48bb5ac58aa186c18c42c83e21a6a636bd22a9.tar.gz slixmpp-ea48bb5ac58aa186c18c42c83e21a6a636bd22a9.tar.bz2 slixmpp-ea48bb5ac58aa186c18c42c83e21a6a636bd22a9.tar.xz slixmpp-ea48bb5ac58aa186c18c42c83e21a6a636bd22a9.zip |
Fixed some live stream test errors.
Added test demonstrating using multiple stream clients
in a single test.
Diffstat (limited to 'sleekxmpp/test/sleektest.py')
-rw-r--r-- | sleekxmpp/test/sleektest.py | 33 |
1 files changed, 25 insertions, 8 deletions
diff --git a/sleekxmpp/test/sleektest.py b/sleekxmpp/test/sleektest.py index d7a6147b..27a7556f 100644 --- a/sleekxmpp/test/sleektest.py +++ b/sleekxmpp/test/sleektest.py @@ -7,6 +7,10 @@ """ import unittest +try: + import Queue as queue +except: + import queue import sleekxmpp from sleekxmpp import ClientXMPP, ComponentXMPP @@ -279,6 +283,10 @@ class SleekTest(unittest.TestCase): else: raise ValueError("Unknown XMPP connection mode.") + # We will use this to wait for the session_start event + # for live connections. + skip_queue = queue.Queue() + if socket == 'mock': self.xmpp.set_socket(TestSocket()) @@ -293,6 +301,10 @@ class SleekTest(unittest.TestCase): self.xmpp.socket.recv_data(header) elif socket == 'live': self.xmpp.socket_class = TestLiveSocket + def wait_for_session(x): + self.xmpp.socket.clear() + skip_queue.put('started') + self.xmpp.add_event_handler('session_start', wait_for_session) self.xmpp.connect() else: raise ValueError("Unknown socket type.") @@ -300,10 +312,13 @@ class SleekTest(unittest.TestCase): self.xmpp.register_plugins() self.xmpp.process(threaded=True) if skip: - # Clear startup stanzas - self.xmpp.socket.next_sent(timeout=1) - if mode == 'component': + if socket != 'live': + # Clear startup stanzas self.xmpp.socket.next_sent(timeout=1) + if mode == 'component': + self.xmpp.socket.next_sent(timeout=1) + else: + skip_queue.get(block=True, timeout=10) def make_header(self, sto='', sfrom='', @@ -573,11 +588,13 @@ class SleekTest(unittest.TestCase): Defaults to the value of self.match_method. """ sent = self.xmpp.socket.next_sent(timeout) - if isinstance(data, str): - xml = self.parse_xml(data) - self.fix_namespaces(xml, 'jabber:client') - data = self.xmpp._build_stanza(xml, 'jabber:client') - self.check(data, sent, + if sent is None: + return False + print sent + xml = self.parse_xml(sent) + self.fix_namespaces(xml, 'jabber:client') + sent = self.xmpp._build_stanza(xml, 'jabber:client') + self.check(sent, data, method=method, defaults=defaults, use_values=use_values) |