diff options
author | Lance Stout <lancestout@gmail.com> | 2011-07-05 21:29:31 -0700 |
---|---|---|
committer | Lance Stout <lancestout@gmail.com> | 2011-07-05 21:29:31 -0700 |
commit | 712da4c46e4ef5ee7995c37d8502c12391e23050 (patch) | |
tree | 1680cf7a164e695ddbd1bed1278c59bfb16867c2 /tests | |
parent | 5efb170e1d7d210304d5bc31f343743770d82e13 (diff) | |
download | slixmpp-712da4c46e4ef5ee7995c37d8502c12391e23050.tar.gz slixmpp-712da4c46e4ef5ee7995c37d8502c12391e23050.tar.bz2 slixmpp-712da4c46e4ef5ee7995c37d8502c12391e23050.tar.xz slixmpp-712da4c46e4ef5ee7995c37d8502c12391e23050.zip |
Add test to check that presence events are firing.
Diffstat (limited to 'tests')
-rw-r--r-- | tests/test_stream_presence.py | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/tests/test_stream_presence.py b/tests/test_stream_presence.py index 1d5caa98..0b086266 100644 --- a/tests/test_stream_presence.py +++ b/tests/test_stream_presence.py @@ -184,5 +184,56 @@ class TestStreamPresence(SleekTest): self.assertEqual(events, expected, "Incorrect events triggered: %s" % events) + def test_presence_events(self): + """Test that presence events are raised.""" + + events = [] + + self.stream_start() + + ptypes = ['available', 'away', 'dnd', 'xa', 'chat', + 'unavailable', 'subscribe', 'subscribed', + 'unsubscribe', 'unsubscribed'] + + for ptype in ptypes: + handler = lambda p: events.append(p['type']) + self.xmpp.add_event_handler('presence_%s' % ptype, handler) + + self.recv(""" + <presence /> + """) + self.recv(""" + <presence><show>away</show></presence> + """) + self.recv(""" + <presence><show>dnd</show></presence> + """) + self.recv(""" + <presence><show>xa</show></presence> + """) + self.recv(""" + <presence><show>chat</show></presence> + """) + self.recv(""" + <presence type="unavailable" /> + """) + self.recv(""" + <presence type="subscribe" /> + """) + self.recv(""" + <presence type="subscribed" /> + """) + self.recv(""" + <presence type="unsubscribe" /> + """) + self.recv(""" + <presence type="unsubscribed" /> + """) + + time.sleep(.5) + + self.assertEqual(events, ptypes, + "Not all events raised: %s" % events) + suite = unittest.TestLoader().loadTestsFromTestCase(TestStreamPresence) |