diff options
author | Lance Stout <lancestout@gmail.com> | 2011-02-24 14:15:02 -0500 |
---|---|---|
committer | Lance Stout <lancestout@gmail.com> | 2011-02-24 14:15:02 -0500 |
commit | 1a81b2f464a3f35c99ff1659b7debb6006004d4f (patch) | |
tree | 41b3fa7930aade08087bdf9476f4382c3d37ec35 /tests/test_stream_xep_0085.py | |
parent | 77251452c106618ab1cfdad546eb224bc9693dea (diff) | |
download | slixmpp-1a81b2f464a3f35c99ff1659b7debb6006004d4f.tar.gz slixmpp-1a81b2f464a3f35c99ff1659b7debb6006004d4f.tar.bz2 slixmpp-1a81b2f464a3f35c99ff1659b7debb6006004d4f.tar.xz slixmpp-1a81b2f464a3f35c99ff1659b7debb6006004d4f.zip |
Add tests for XEP-0085, fix some bugs.
Diffstat (limited to 'tests/test_stream_xep_0085.py')
-rw-r--r-- | tests/test_stream_xep_0085.py | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/tests/test_stream_xep_0085.py b/tests/test_stream_xep_0085.py new file mode 100644 index 00000000..2a814805 --- /dev/null +++ b/tests/test_stream_xep_0085.py @@ -0,0 +1,59 @@ +import threading +import time + +from sleekxmpp.test import * + + +class TestStreamChatStates(SleekTest): + + def tearDown(self): + self.stream_close() + + def testChatStates(self): + self.stream_start(mode='client', plugins=['xep_0030', 'xep_0085']) + + results = [] + + def handle_state(msg): + results.append(msg['chat_state']) + + self.xmpp.add_event_handler('chatstate_active', handle_state) + self.xmpp.add_event_handler('chatstate_inactive', handle_state) + self.xmpp.add_event_handler('chatstate_paused', handle_state) + self.xmpp.add_event_handler('chatstate_gone', handle_state) + self.xmpp.add_event_handler('chatstate_composing', handle_state) + + self.recv(""" + <message> + <active xmlns="http://jabber.org/protocol/chatstates" /> + </message> + """) + self.recv(""" + <message> + <inactive xmlns="http://jabber.org/protocol/chatstates" /> + </message> + """) + self.recv(""" + <message> + <paused xmlns="http://jabber.org/protocol/chatstates" /> + </message> + """) + self.recv(""" + <message> + <composing xmlns="http://jabber.org/protocol/chatstates" /> + </message> + """) + self.recv(""" + <message> + <gone xmlns="http://jabber.org/protocol/chatstates" /> + </message> + """) + + # Give event queue time to process + time.sleep(0.3) + expected = ['active', 'inactive', 'paused', 'composing', 'gone'] + self.failUnless(results == expected, + "Chat state event not handled: %s" % results) + + +suite = unittest.TestLoader().loadTestsFromTestCase(TestStreamChatStates) |