Added stream tests for presence events.
First batch of tests, currently focuses on the got_offline event.
This commit is contained in:
parent
03847497cc
commit
46ffa8e9fe
1 changed files with 86 additions and 0 deletions
86
tests/test_stream_presence.py
Normal file
86
tests/test_stream_presence.py
Normal file
|
@ -0,0 +1,86 @@
|
||||||
|
import time
|
||||||
|
from sleekxmpp.test import *
|
||||||
|
|
||||||
|
|
||||||
|
class TestStreamPresence(SleekTest):
|
||||||
|
"""
|
||||||
|
Test handling roster updates.
|
||||||
|
"""
|
||||||
|
|
||||||
|
def tearDown(self):
|
||||||
|
self.stream_close()
|
||||||
|
|
||||||
|
def testInitialUnavailablePresences(self):
|
||||||
|
"""
|
||||||
|
Test receiving unavailable presences from JIDs that
|
||||||
|
are not online.
|
||||||
|
"""
|
||||||
|
events = set()
|
||||||
|
|
||||||
|
def got_offline(presence):
|
||||||
|
# The got_offline event should not be triggered.
|
||||||
|
events.add('got_offline')
|
||||||
|
|
||||||
|
def unavailable(presence):
|
||||||
|
# The presence_unavailable event should be triggered.
|
||||||
|
events.add('unavailable')
|
||||||
|
|
||||||
|
self.stream_start()
|
||||||
|
self.xmpp.add_event_handler('got_offline', got_offline)
|
||||||
|
self.xmpp.add_event_handler('presence_unavailable', unavailable)
|
||||||
|
|
||||||
|
self.stream_recv("""
|
||||||
|
<presence type="unavailable" from="otheruser@localhost" />
|
||||||
|
""")
|
||||||
|
|
||||||
|
# Give event queue time to process.
|
||||||
|
time.sleep(0.1)
|
||||||
|
|
||||||
|
self.assertEqual(events, set(('unavailable',)),
|
||||||
|
"Got offline incorrectly triggered: %s." % events)
|
||||||
|
|
||||||
|
def testGotOffline(self):
|
||||||
|
"""Test that got_offline is triggered properly."""
|
||||||
|
events = []
|
||||||
|
def got_offline(presence):
|
||||||
|
events.append('got_offline')
|
||||||
|
|
||||||
|
self.stream_start()
|
||||||
|
self.xmpp.add_event_handler('got_offline', got_offline)
|
||||||
|
|
||||||
|
# Setup roster. Use a 'set' instead of 'result' so we
|
||||||
|
# don't have to handle get_roster() blocking.
|
||||||
|
#
|
||||||
|
# We use the stream to initialize the roster to make
|
||||||
|
# the test independent of the roster implementation.
|
||||||
|
self.stream_recv("""
|
||||||
|
<iq type="set">
|
||||||
|
<query xmlns="jabber:iq:roster">
|
||||||
|
<item jid="otheruser@localhost"
|
||||||
|
name="Other User"
|
||||||
|
subscription="both">
|
||||||
|
<group>Testers</group>
|
||||||
|
</item>
|
||||||
|
</query>
|
||||||
|
</iq>
|
||||||
|
""")
|
||||||
|
|
||||||
|
# Contact comes online.
|
||||||
|
self.stream_recv("""
|
||||||
|
<presence from="otheruser@localhost/foobar" />
|
||||||
|
""")
|
||||||
|
|
||||||
|
# Contact goes offline, should trigger got_offline.
|
||||||
|
self.stream_recv("""
|
||||||
|
<presence from="otheruser@localhost/foobar"
|
||||||
|
type="unavailable" />
|
||||||
|
""")
|
||||||
|
|
||||||
|
# Give event queue time to process.
|
||||||
|
time.sleep(0.1)
|
||||||
|
|
||||||
|
self.assertEqual(events, ['got_offline'],
|
||||||
|
"Got offline incorrectly triggered: %s" % events)
|
||||||
|
|
||||||
|
|
||||||
|
suite = unittest.TestLoader().loadTestsFromTestCase(TestStreamPresence)
|
Loading…
Reference in a new issue