summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLance Stout <lancestout@gmail.com>2011-07-05 21:29:31 -0700
committerLance Stout <lancestout@gmail.com>2011-07-05 21:29:31 -0700
commit712da4c46e4ef5ee7995c37d8502c12391e23050 (patch)
tree1680cf7a164e695ddbd1bed1278c59bfb16867c2
parent5efb170e1d7d210304d5bc31f343743770d82e13 (diff)
downloadslixmpp-712da4c46e4ef5ee7995c37d8502c12391e23050.tar.gz
slixmpp-712da4c46e4ef5ee7995c37d8502c12391e23050.tar.bz2
slixmpp-712da4c46e4ef5ee7995c37d8502c12391e23050.tar.xz
slixmpp-712da4c46e4ef5ee7995c37d8502c12391e23050.zip
Add test to check that presence events are firing.
-rw-r--r--tests/test_stream_presence.py51
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)