mirror of
https://github.com/correl/SleekXMPP.git
synced 2024-11-23 19:19:53 +00:00
added test for unsolicided unavailable presence and fixed bug to make it pass
This commit is contained in:
parent
223507f36f
commit
ae41c08fec
2 changed files with 20 additions and 3 deletions
|
@ -271,12 +271,13 @@ class basexmpp(object):
|
|||
name = self.roster[jid].get('name', '')
|
||||
if show == 'unavailable':
|
||||
logging.debug("%s %s got offline" % (jid, resource))
|
||||
if len(self.roster[jid]['presence']):
|
||||
del self.roster[jid]['presence'][resource]
|
||||
else:
|
||||
del self.roster[jid]['presence'][resource]
|
||||
if len(self.roster[jid]['presence']) == 0 and not self.roster[jid]['in_roster']:
|
||||
del self.roster[jid]
|
||||
if not wasoffline:
|
||||
self.event("got_offline", presence)
|
||||
else:
|
||||
return False
|
||||
self.event("changed_status", presence)
|
||||
name = ''
|
||||
if name:
|
||||
|
|
|
@ -11,5 +11,21 @@ class testpresencestanzas(unittest.TestCase):
|
|||
p = self.p.Presence()
|
||||
p['type'] = 'dnd'
|
||||
self.failUnless(str(p) == "<presence><show>dnd</show></presence>")
|
||||
|
||||
def testPresenceUnsolicitedOffline(self):
|
||||
"Unsolicted offline presence does not spawn changed_status or update roster"
|
||||
p = self.p.Presence()
|
||||
p['type'] = 'unavailable'
|
||||
p['from'] = 'bill@chadmore.com/gmail15af'
|
||||
import sleekxmpp
|
||||
c = sleekxmpp.ClientXMPP('crap@wherever', 'password')
|
||||
happened = []
|
||||
def handlechangedpresence(event):
|
||||
happened.append(True)
|
||||
c.add_event_handler("changed_status", handlechangedpresence)
|
||||
c._handlePresence(p)
|
||||
self.failUnless(happened == [], "changed_status event triggered for superfulous unavailable presence")
|
||||
self.failUnless(c.roster == {}, "Roster updated for superfulous unavailable presence")
|
||||
|
||||
|
||||
suite = unittest.TestLoader().loadTestsFromTestCase(testpresencestanzas)
|
||||
|
|
Loading…
Reference in a new issue