diff --git a/sleekxmpp/plugins/stanza_pubsub.py b/sleekxmpp/plugins/stanza_pubsub.py
index e04f1a7..96d02f9 100644
--- a/sleekxmpp/plugins/stanza_pubsub.py
+++ b/sleekxmpp/plugins/stanza_pubsub.py
@@ -257,7 +257,7 @@ class Configure(ElementBase):
namespace = 'http://jabber.org/protocol/pubsub'
name = 'configure'
plugin_attrib = name
- interfaces = set(('node', 'type', 'config'))
+ interfaces = set(('node', 'type'))
plugin_attrib_map = {}
plugin_tag_map = {}
@@ -266,22 +266,8 @@ class Configure(ElementBase):
if not t: t == 'leaf'
return t
- def getConfig(self):
- config = self.xml.find('{jabber:x:data}x')
- form = xep_0004.Form()
- if config is not None:
- form.fromXML(config)
- return form
-
- def setConfig(self, value):
- self.xml.append(value.getXML())
- return self
-
- def delConfig(self):
- config = self.xml.find('{jabber:x:data}x')
- self.xml.remove(config)
-
registerStanzaPlugin(Pubsub, Configure)
+registerStanzaPlugin(Configure, xep_0004.Form)
class DefaultConfig(ElementBase):
namespace = 'http://jabber.org/protocol/pubsub#owner'
@@ -293,21 +279,6 @@ class DefaultConfig(ElementBase):
def __init__(self, *args, **kwargs):
ElementBase.__init__(self, *args, **kwargs)
-
- def getConfig(self):
- config = self.xml.find('{jabber:x:data}x')
- form = xep_0004.Form()
- if config is not None:
- form.fromXML(config)
- return form
-
- def setConfig(self, value):
- self.xml.append(value.getXML())
- return self
-
- def delConfig(self):
- config = self.xml.find('{jabber:x:data}x')
- self.xml.remove(config)
def getType(self):
t = self._getAttr('type')
@@ -315,6 +286,7 @@ class DefaultConfig(ElementBase):
return t
registerStanzaPlugin(PubsubOwner, DefaultConfig)
+registerStanzaPlugin(DefaultConfig, xep_0004.Form)
class Options(ElementBase):
namespace = 'http://jabber.org/protocol/pubsub'
@@ -538,22 +510,8 @@ class EventConfiguration(ElementBase):
plugin_attrib_map = {}
plugin_tag_map = {}
- def getConfig(self):
- config = self.xml.find('{jabber:x:data}x')
- form = xep_0004.Form()
- if config is not None:
- form.fromXML(config)
- return form
-
- def setConfig(self, value):
- self.xml.append(value.getXML())
- return self
-
- def delConfig(self):
- config = self.xml.find('{jabber:x:data}x')
- self.xml.remove(config)
-
registerStanzaPlugin(Event, EventConfiguration)
+registerStanzaPlugin(EventConfiguration, xep_0004.Form)
class EventPurge(ElementBase):
namespace = 'http://jabber.org/protocol/pubsub#event'
diff --git a/tests/test_pubsubstanzas.py b/tests/test_pubsubstanzas.py
index 089ee18..794fa03 100644
--- a/tests/test_pubsubstanzas.py
+++ b/tests/test_pubsubstanzas.py
@@ -1,315 +1,511 @@
-import unittest
-from xml.etree import cElementTree as ET
-from sleekxmpp.xmlstream.matcher.stanzapath import StanzaPath
-from . import xmlcompare
+from sleektest import *
+import sleekxmpp.plugins.xep_0004 as xep_0004
+import sleekxmpp.plugins.stanza_pubsub as pubsub
-class testpubsubstanzas(unittest.TestCase):
- def setUp(self):
- import sleekxmpp.plugins.stanza_pubsub as ps
- self.ps = ps
+class TestPubsubStanzas(SleekTest):
- def testAffiliations(self):
- "Testing iq/pubsub/affiliations/affiliation stanzas"
- iq = self.ps.Iq()
- aff1 = self.ps.Affiliation()
- aff1['node'] = 'testnode'
- aff1['affiliation'] = 'owner'
- aff2 = self.ps.Affiliation()
- aff2['node'] = 'testnode2'
- aff2['affiliation'] = 'publisher'
- iq['pubsub']['affiliations'].append(aff1)
- iq['pubsub']['affiliations'].append(aff2)
- xmlstring = """"""
- iq2 = self.ps.Iq(None, self.ps.ET.fromstring(xmlstring))
- iq3 = self.ps.Iq()
- values = iq2.getValues()
- iq3.setValues(values)
- self.failUnless(xmlstring == str(iq) == str(iq2) == str(iq3), "3 methods for creating stanza don't match")
- self.failUnless(iq.match('iq@id=0/pubsub/affiliations/affiliation@node=testnode2@affiliation=publisher'), 'Match path failed')
+ def testAffiliations(self):
+ "Testing iq/pubsub/affiliations/affiliation stanzas"
+ iq = self.Iq()
+ aff1 = pubsub.Affiliation()
+ aff1['node'] = 'testnode'
+ aff1['affiliation'] = 'owner'
+ aff2 = pubsub.Affiliation()
+ aff2['node'] = 'testnode2'
+ aff2['affiliation'] = 'publisher'
+ iq['pubsub']['affiliations'].append(aff1)
+ iq['pubsub']['affiliations'].append(aff2)
+ self.checkIq(iq, """
+
+
+
+
+
+
+
+ """)
- def testSubscriptions(self):
- "Testing iq/pubsub/subscriptions/subscription stanzas"
- iq = self.ps.Iq()
- sub1 = self.ps.Subscription()
- sub1['node'] = 'testnode'
- sub1['jid'] = 'steve@myserver.tld/someresource'
- sub2 = self.ps.Subscription()
- sub2['node'] = 'testnode2'
- sub2['jid'] = 'boogers@bork.top/bill'
- sub2['subscription'] = 'subscribed'
- iq['pubsub']['subscriptions'].append(sub1)
- iq['pubsub']['subscriptions'].append(sub2)
- xmlstring = """"""
- iq2 = self.ps.Iq(None, self.ps.ET.fromstring(xmlstring))
- iq3 = self.ps.Iq()
- values = iq2.getValues()
- iq3.setValues(values)
- self.failUnless(xmlstring == str(iq) == str(iq2) == str(iq3))
-
- def testOptionalSettings(self):
- "Testing iq/pubsub/subscription/subscribe-options stanzas"
- iq = self.ps.Iq()
- iq['pubsub']['subscription']['suboptions']['required'] = True
- iq['pubsub']['subscription']['node'] = 'testnode alsdkjfas'
- iq['pubsub']['subscription']['jid'] = "fritzy@netflint.net/sleekxmpp"
- iq['pubsub']['subscription']['subscription'] = 'unconfigured'
- xmlstring = """"""
- iq2 = self.ps.Iq(None, self.ps.ET.fromstring(xmlstring))
- iq3 = self.ps.Iq()
- values = iq2.getValues()
- iq3.setValues(values)
- self.failUnless(xmlstring == str(iq) == str(iq2) == str(iq3))
-
- def testItems(self):
- "Testing iq/pubsub/items stanzas"
- iq = self.ps.Iq()
- iq['pubsub']['items']
- payload = ET.fromstring("""""")
- payload2 = ET.fromstring("""""")
- item = self.ps.Item()
- item['id'] = 'asdf'
- item['payload'] = payload
- item2 = self.ps.Item()
- item2['id'] = 'asdf2'
- item2['payload'] = payload2
- iq['pubsub']['items'].append(item)
- iq['pubsub']['items'].append(item2)
- xmlstring = """ """
- iq2 = self.ps.Iq(None, self.ps.ET.fromstring(xmlstring))
- iq3 = self.ps.Iq()
- values = iq2.getValues()
- iq3.setValues(values)
- self.failUnless(xmlstring == str(iq) == str(iq2) == str(iq3))
-
- def testCreate(self):
- "Testing iq/pubsub/create&configure stanzas"
- from sleekxmpp.plugins import xep_0004
- iq = self.ps.Iq()
- iq['pubsub']['create']['node'] = 'mynode'
- form = xep_0004.Form()
- form.addField('pubsub#title', ftype='text-single', value='This thing is awesome')
- iq['pubsub']['configure']['config'] = form
- xmlstring = """This thing is awesome"""
- iq2 = self.ps.Iq(None, self.ps.ET.fromstring(xmlstring))
- iq3 = self.ps.Iq()
- values = iq2.getValues()
- iq3.setValues(values)
- self.failUnless(xmlstring == str(iq) == str(iq2) == str(iq3))
-
- def testState(self):
- "Testing iq/psstate stanzas"
- from sleekxmpp.plugins import xep_0004
- iq = self.ps.Iq()
- iq['psstate']['node']= 'mynode'
- iq['psstate']['item']= 'myitem'
- pl = ET.Element('{http://andyet.net/protocol/pubsubqueue}claimed')
- iq['psstate']['payload'] = pl
- xmlstring = """"""
- iq2 = self.ps.Iq(None, self.ps.ET.fromstring(xmlstring))
- iq3 = self.ps.Iq()
- values = iq2.getValues()
- iq3.setValues(values)
- self.failUnless(xmlstring == str(iq) == str(iq2) == str(iq3))
-
- def testDefault(self):
- "Testing iq/pubsub_owner/default stanzas"
- from sleekxmpp.plugins import xep_0004
- iq = self.ps.Iq()
- iq['pubsub_owner']['default']
- iq['pubsub_owner']['default']['node'] = 'mynode'
- iq['pubsub_owner']['default']['type'] = 'leaf'
- form = xep_0004.Form()
- form.addField('pubsub#title', ftype='text-single', value='This thing is awesome')
- iq['pubsub_owner']['default']['config'] = form
- xmlstring = """This thing is awesome"""
- iq2 = self.ps.Iq(None, self.ps.ET.fromstring(xmlstring))
- iq3 = self.ps.Iq()
- values = iq2.getValues()
- iq3.setValues(values)
- self.failUnless(xmlstring == str(iq) == str(iq2) == str(iq3))
-
- def testSubscribe(self):
- "Testing iq/pubsub/subscribe stanzas"
- from sleekxmpp.plugins import xep_0004
- iq = self.ps.Iq()
- iq['pubsub']['subscribe']['options']
- iq['pubsub']['subscribe']['node'] = 'cheese'
- iq['pubsub']['subscribe']['jid'] = 'fritzy@netflint.net/sleekxmpp'
- iq['pubsub']['subscribe']['options']['node'] = 'cheese'
- iq['pubsub']['subscribe']['options']['jid'] = 'fritzy@netflint.net/sleekxmpp'
- form = xep_0004.Form()
- form.addField('pubsub#title', ftype='text-single', value='This thing is awesome')
- iq['pubsub']['subscribe']['options']['options'] = form
- xmlstring = """This thing is awesome"""
- iq2 = self.ps.Iq(None, self.ps.ET.fromstring(xmlstring))
- iq3 = self.ps.Iq()
- values = iq2.getValues()
- iq3.setValues(values)
- self.failUnless(xmlstring == str(iq) == str(iq2) == str(iq3))
-
- def testPublish(self):
- "Testing iq/pubsub/publish stanzas"
- iq = self.ps.Iq()
- iq['pubsub']['publish']['node'] = 'thingers'
- payload = ET.fromstring("""""")
- payload2 = ET.fromstring("""""")
- item = self.ps.Item()
- item['id'] = 'asdf'
- item['payload'] = payload
- item2 = self.ps.Item()
- item2['id'] = 'asdf2'
- item2['payload'] = payload2
- iq['pubsub']['publish'].append(item)
- iq['pubsub']['publish'].append(item2)
- xmlstring = """ """
- iq2 = self.ps.Iq(None, self.ps.ET.fromstring(xmlstring))
- iq3 = self.ps.Iq()
- values = iq2.getValues()
- iq3.setValues(values)
- self.failUnless(xmlstring == str(iq) == str(iq2) == str(iq3))
+ def testSubscriptions(self):
+ "Testing iq/pubsub/subscriptions/subscription stanzas"
+ iq = self.Iq()
+ sub1 = pubsub.Subscription()
+ sub1['node'] = 'testnode'
+ sub1['jid'] = 'steve@myserver.tld/someresource'
+ sub2 = pubsub.Subscription()
+ sub2['node'] = 'testnode2'
+ sub2['jid'] = 'boogers@bork.top/bill'
+ sub2['subscription'] = 'subscribed'
+ iq['pubsub']['subscriptions'].append(sub1)
+ iq['pubsub']['subscriptions'].append(sub2)
+ self.checkIq(iq, """
+
+
+
+
+
+
+
+ """)
- def testDelete(self):
- "Testing iq/pubsub_owner/delete stanzas"
- iq = self.ps.Iq()
- iq['pubsub_owner']['delete']['node'] = 'thingers'
- xmlstring = """"""
- iq2 = self.ps.Iq(None, self.ps.ET.fromstring(xmlstring))
- iq3 = self.ps.Iq()
- iq3.setValues(iq2.getValues())
- self.failUnless(xmlstring == str(iq) == str(iq2) == str(iq3))
+ def testOptionalSettings(self):
+ "Testing iq/pubsub/subscription/subscribe-options stanzas"
+ iq = self.Iq()
+ iq['pubsub']['subscription']['suboptions']['required'] = True
+ iq['pubsub']['subscription']['node'] = 'testnode alsdkjfas'
+ iq['pubsub']['subscription']['jid'] = "fritzy@netflint.net/sleekxmpp"
+ iq['pubsub']['subscription']['subscription'] = 'unconfigured'
+ self.checkIq(iq, """
+
+
+
+
+
+
+
+
+ """)
+
+ def testItems(self):
+ "Testing iq/pubsub/items stanzas"
+ iq = self.Iq()
+ iq['pubsub']['items']
+ payload = ET.fromstring("""
+
+
+
+ """)
+ payload2 = ET.fromstring("""
+
+
+
+ """)
+ item = pubsub.Item()
+ item['id'] = 'asdf'
+ item['payload'] = payload
+ item2 = pubsub.Item()
+ item2['id'] = 'asdf2'
+ item2['payload'] = payload2
+ iq['pubsub']['items'].append(item)
+ iq['pubsub']['items'].append(item2)
+ self.checkIq(iq, """
+
+
+
+ -
+
+
+
+
+
+ -
+
+
+
+
+
+
+
+ """)
+
+ def testCreate(self):
+ "Testing iq/pubsub/create&configure stanzas"
+ iq = self.Iq()
+ iq['pubsub']['create']['node'] = 'mynode'
+ iq['pubsub']['configure']['form'].addField('pubsub#title',
+ ftype='text-single',
+ value='This thing is awesome')
+ self.checkIq(iq, """
+
+
+
+
+
+
+ This thing is awesome
+
+
+
+
+ """)
+
+ def testState(self):
+ "Testing iq/psstate stanzas"
+ iq = self.Iq()
+ iq['psstate']['node']= 'mynode'
+ iq['psstate']['item']= 'myitem'
+ pl = ET.Element('{http://andyet.net/protocol/pubsubqueue}claimed')
+ iq['psstate']['payload'] = pl
+ self.checkIq(iq, """
+
+
+
+
+ """)
+
+ def testDefault(self):
+ "Testing iq/pubsub_owner/default stanzas"
+ iq = self.Iq()
+ iq['pubsub_owner']['default']
+ iq['pubsub_owner']['default']['node'] = 'mynode'
+ iq['pubsub_owner']['default']['type'] = 'leaf'
+ iq['pubsub_owner']['default']['form'].addField('pubsub#title',
+ ftype='text-single',
+ value='This thing is awesome')
+ self.checkIq(iq, """
+
+
+
+
+
+ This thing is awesome
+
+
+
+
+ """, use_values=False)
+
+ def testSubscribe(self):
+ "Testing iq/pubsub/subscribe stanzas"
+ iq = self.Iq()
+ iq['pubsub']['subscribe']['options']
+ iq['pubsub']['subscribe']['node'] = 'cheese'
+ iq['pubsub']['subscribe']['jid'] = 'fritzy@netflint.net/sleekxmpp'
+ iq['pubsub']['subscribe']['options']['node'] = 'cheese'
+ iq['pubsub']['subscribe']['options']['jid'] = 'fritzy@netflint.net/sleekxmpp'
+ form = xep_0004.Form()
+ form.addField('pubsub#title', ftype='text-single', value='This thing is awesome')
+ iq['pubsub']['subscribe']['options']['options'] = form
+ self.checkIq(iq, """
+
+
+
+
+
+
+ This thing is awesome
+
+
+
+
+
+ """, use_values=False)
+
+ def testPublish(self):
+ "Testing iq/pubsub/publish stanzas"
+ iq = self.Iq()
+ iq['pubsub']['publish']['node'] = 'thingers'
+ payload = ET.fromstring("""
+
+
+
+ """)
+ payload2 = ET.fromstring("""
+
+
+
+ """)
+ item = pubsub.Item()
+ item['id'] = 'asdf'
+ item['payload'] = payload
+ item2 = pubsub.Item()
+ item2['id'] = 'asdf2'
+ item2['payload'] = payload2
+ iq['pubsub']['publish'].append(item)
+ iq['pubsub']['publish'].append(item2)
- def testCreateConfigGet(self):
- """Testing getting config from full create"""
- xml = """http://jabber.org/protocol/pubsub#node_configleaf111101openpublishersnever"""
- iq = self.ps.Iq(None, self.ps.ET.fromstring(xml))
- config = iq['pubsub']['configure']['config']
- self.failUnless(config.getValues() != {})
+ self.checkIq(iq, """
+
+
+
+ -
+
+
+
+
+
+ -
+
+
+
+
+
+
+
+ """)
- def testItemEvent(self):
- """Testing message/pubsub_event/items/item"""
- msg = self.ps.Message()
- item = self.ps.EventItem()
- pl = ET.Element('{http://netflint.net/protocol/test}test', {'failed':'3', 'passed':'24'})
- item['payload'] = pl
- item['id'] = 'abc123'
- msg['pubsub_event']['items'].append(item)
- msg['pubsub_event']['items']['node'] = 'cheese'
- msg['type'] = 'normal'
- xmlstring = """ """
- msg2 = self.ps.Message(None, self.ps.ET.fromstring(xmlstring))
- msg3 = self.ps.Message()
- msg3.setValues(msg2.getValues())
- self.failUnless(xmlstring == str(msg) == str(msg2) == str(msg3))
+ def testDelete(self):
+ "Testing iq/pubsub_owner/delete stanzas"
+ iq = self.Iq()
+ iq['pubsub_owner']['delete']['node'] = 'thingers'
+ self.checkIq(iq, """
+
+
+
+
+ """)
- def testItemsEvent(self):
- """Testing multiple message/pubsub_event/items/item"""
- msg = self.ps.Message()
- item = self.ps.EventItem()
- item2 = self.ps.EventItem()
- pl = ET.Element('{http://netflint.net/protocol/test}test', {'failed':'3', 'passed':'24'})
- pl2 = ET.Element('{http://netflint.net/protocol/test-other}test', {'total':'27', 'failed':'3'})
- item2['payload'] = pl2
- item['payload'] = pl
- item['id'] = 'abc123'
- item2['id'] = '123abc'
- msg['pubsub_event']['items'].append(item)
- msg['pubsub_event']['items'].append(item2)
- msg['pubsub_event']['items']['node'] = 'cheese'
- msg['type'] = 'normal'
- xmlstring = """ """
- msg2 = self.ps.Message(None, self.ps.ET.fromstring(xmlstring))
- msg3 = self.ps.Message()
- msg3.setValues(msg2.getValues())
- self.failUnless(xmlstring == str(msg) == str(msg2) == str(msg3))
+ def testCreateConfigGet(self):
+ """Testing getting config from full create"""
+ iq = self.Iq()
+ iq['to'] = 'pubsub.asdf'
+ iq['from'] = 'fritzy@asdf/87292ede-524d-4117-9076-d934ed3db8e7'
+ iq['type'] = 'set'
+ iq['id'] = 'E'
- def testItemsEvent(self):
- """Testing message/pubsub_event/items/item & retract mix"""
- msg = self.ps.Message()
- item = self.ps.EventItem()
- item2 = self.ps.EventItem()
- pl = ET.Element('{http://netflint.net/protocol/test}test', {'failed':'3', 'passed':'24'})
- pl2 = ET.Element('{http://netflint.net/protocol/test-other}test', {'total':'27', 'failed':'3'})
- item2['payload'] = pl2
- retract = self.ps.EventRetract()
- retract['id'] = 'aabbcc'
- item['payload'] = pl
- item['id'] = 'abc123'
- item2['id'] = '123abc'
- msg['pubsub_event']['items'].append(item)
- msg['pubsub_event']['items'].append(retract)
- msg['pubsub_event']['items'].append(item2)
- msg['pubsub_event']['items']['node'] = 'cheese'
- msg['type'] = 'normal'
- xmlstring = """ """
- msg2 = self.ps.Message(None, self.ps.ET.fromstring(xmlstring))
- msg3 = self.ps.Message()
- msg3.setValues(msg2.getValues())
- self.failUnless(xmlstring == str(msg) == str(msg2) == str(msg3))
-
- def testCollectionAssociate(self):
- """Testing message/pubsub_event/collection/associate"""
- msg = self.ps.Message()
- msg['pubsub_event']['collection']['associate']['node'] = 'cheese'
- msg['pubsub_event']['collection']['node'] = 'cheeseburger'
- msg['type'] = 'headline'
- xmlstring = """"""
- msg2 = self.ps.Message(None, self.ps.ET.fromstring(xmlstring))
- msg3 = self.ps.Message()
- msg3.setValues(msg2.getValues())
- self.failUnless(xmlstring == str(msg) == str(msg2) == str(msg3))
+ pub = iq['pubsub']
+ pub['create']['node'] = 'testnode2'
+ pub['configure']['form']['type'] = 'submit'
+ pub['configure']['form'].setFields([
+ ('FORM_TYPE', {'type': 'hidden',
+ 'value': 'http://jabber.org/protocol/pubsub#node_config'}),
+ ('pubsub#node_type', {'type': 'list-single',
+ 'label': 'Select the node type',
+ 'value': 'leaf'}),
+ ('pubsub#title', {'type': 'text-single',
+ 'label': 'A friendly name for the node'}),
+ ('pubsub#deliver_notifications', {'type': 'boolean',
+ 'label': 'Deliver event notifications',
+ 'value': True}),
+ ('pubsub#deliver_payloads', {'type': 'boolean',
+ 'label': 'Deliver payloads with event notifications',
+ 'value': True}),
+ ('pubsub#notify_config', {'type': 'boolean',
+ 'label': 'Notify subscribers when the node configuration changes'}),
+ ('pubsub#notify_delete', {'type': 'boolean',
+ 'label': 'Notify subscribers when the node is deleted'}),
+ ('pubsub#notify_retract', {'type': 'boolean',
+ 'label': 'Notify subscribers when items are removed from the node',
+ 'value': True}),
+ ('pubsub#notify_sub', {'type': 'boolean',
+ 'label': 'Notify owners about new subscribers and unsubscribes'}),
+ ('pubsub#persist_items', {'type': 'boolean',
+ 'label': 'Persist items in storage'}),
+ ('pubsub#max_items', {'type': 'text-single',
+ 'label': 'Max # of items to persist',
+ 'value': '10'}),
+ ('pubsub#subscribe', {'type': 'boolean',
+ 'label': 'Whether to allow subscriptions',
+ 'value': True}),
+ ('pubsub#access_model', {'type': 'list-single',
+ 'label': 'Specify the subscriber model',
+ 'value': 'open'}),
+ ('pubsub#publish_model', {'type': 'list-single',
+ 'label': 'Specify the publisher model',
+ 'value': 'publishers'}),
+ ('pubsub#send_last_published_item', {'type': 'list-single',
+ 'label': 'Send last published item',
+ 'value': 'never'}),
+ ('pubsub#presence_based_delivery', {'type': 'boolean',
+ 'label': 'Deliver notification only to available users'}),
+ ])
- def testCollectionDisassociate(self):
- """Testing message/pubsub_event/collection/disassociate"""
- msg = self.ps.Message()
- msg['pubsub_event']['collection']['disassociate']['node'] = 'cheese'
- msg['pubsub_event']['collection']['node'] = 'cheeseburger'
- msg['type'] = 'headline'
- xmlstring = """"""
- msg2 = self.ps.Message(None, self.ps.ET.fromstring(xmlstring))
- msg3 = self.ps.Message()
- msg3.setValues(msg2.getValues())
- self.failUnless(xmlstring == str(msg) == str(msg2) == str(msg3))
+ self.checkIq(iq, """
+
+
+
+
+
+
+ http://jabber.org/protocol/pubsub#node_config
+
+
+ leaf
+
+
+
+ 1
+
+
+ 1
+
+
+
+
+ 1
+
+
+
+
+ 10
+
+
+ 1
+
+
+ open
+
+
+ publishers
+
+
+ never
+
+
+
+
+
+ """)
- def testEventConfiguration(self):
- """Testing message/pubsub_event/configuration/config"""
- msg = self.ps.Message()
- from sleekxmpp.plugins import xep_0004
- form = xep_0004.Form()
- form.addField('pubsub#title', ftype='text-single', value='This thing is awesome')
- msg['pubsub_event']['configuration']['node'] = 'cheese'
- msg['pubsub_event']['configuration']['config'] = form
- msg['type'] = 'headline'
- xmlstring = """This thing is awesome"""
- msg2 = self.ps.Message(None, self.ps.ET.fromstring(xmlstring))
- msg3 = self.ps.Message()
- msg3.setValues(msg2.getValues())
- self.failUnless(xmlstring == str(msg) == str(msg2) == str(msg3))
-
- def testEventPurge(self):
- """Testing message/pubsub_event/purge"""
- msg = self.ps.Message()
- msg['pubsub_event']['purge']['node'] = 'pickles'
- msg['type'] = 'headline'
- xmlstring = """"""
- msg2 = self.ps.Message(None, self.ps.ET.fromstring(xmlstring))
- msg3 = self.ps.Message()
- msg3.setValues(msg2.getValues())
- self.failUnless(xmlstring == str(msg) == str(msg2) == str(msg3))
-
- def testEventSubscription(self):
- """Testing message/pubsub_event/subscription"""
- msg = self.ps.Message()
- msg['pubsub_event']['subscription']['node'] = 'pickles'
- msg['pubsub_event']['subscription']['jid'] = 'fritzy@netflint.net/test'
- msg['pubsub_event']['subscription']['subid'] = 'aabb1122'
- msg['pubsub_event']['subscription']['subscription'] = 'subscribed'
- msg['pubsub_event']['subscription']['expiry'] = 'presence'
- msg['type'] = 'headline'
- xmlstring = """"""
- msg2 = self.ps.Message(None, self.ps.ET.fromstring(xmlstring))
- msg3 = self.ps.Message()
- msg3.setValues(msg2.getValues())
- self.failUnless(xmlcompare.comparemany([xmlstring, str(msg), str(msg2), str(msg3)]))
+ def testItemEvent(self):
+ """Testing message/pubsub_event/items/item"""
+ msg = self.Message()
+ item = pubsub.EventItem()
+ pl = ET.Element('{http://netflint.net/protocol/test}test', {'failed':'3', 'passed':'24'})
+ item['payload'] = pl
+ item['id'] = 'abc123'
+ msg['pubsub_event']['items'].append(item)
+ msg['pubsub_event']['items']['node'] = 'cheese'
+ msg['type'] = 'normal'
+ self.checkMessage(msg, """
+
+
+
+ -
+
+
+
+
+ """)
-suite = unittest.TestLoader().loadTestsFromTestCase(testpubsubstanzas)
+ def testItemsEvent(self):
+ """Testing multiple message/pubsub_event/items/item"""
+ msg = self.Message()
+ item = pubsub.EventItem()
+ item2 = pubsub.EventItem()
+ pl = ET.Element('{http://netflint.net/protocol/test}test', {'failed':'3', 'passed':'24'})
+ pl2 = ET.Element('{http://netflint.net/protocol/test-other}test', {'total':'27', 'failed':'3'})
+ item2['payload'] = pl2
+ item['payload'] = pl
+ item['id'] = 'abc123'
+ item2['id'] = '123abc'
+ msg['pubsub_event']['items'].append(item)
+ msg['pubsub_event']['items'].append(item2)
+ msg['pubsub_event']['items']['node'] = 'cheese'
+ msg['type'] = 'normal'
+ self.checkMessage(msg, """
+
+
+
+ -
+
+
+ -
+
+
+
+
+ """)
+
+ def testItemsEvent(self):
+ """Testing message/pubsub_event/items/item & retract mix"""
+ msg = self.Message()
+ item = pubsub.EventItem()
+ item2 = pubsub.EventItem()
+ pl = ET.Element('{http://netflint.net/protocol/test}test', {'failed':'3', 'passed':'24'})
+ pl2 = ET.Element('{http://netflint.net/protocol/test-other}test', {'total':'27', 'failed':'3'})
+ item2['payload'] = pl2
+ retract = pubsub.EventRetract()
+ retract['id'] = 'aabbcc'
+ item['payload'] = pl
+ item['id'] = 'abc123'
+ item2['id'] = '123abc'
+ msg['pubsub_event']['items'].append(item)
+ msg['pubsub_event']['items'].append(retract)
+ msg['pubsub_event']['items'].append(item2)
+ msg['pubsub_event']['items']['node'] = 'cheese'
+ msg['type'] = 'normal'
+ self.checkMessage(msg, """
+
+
+
+ -
+
+
+ -
+
+
+
+
+ """)
+
+ def testCollectionAssociate(self):
+ """Testing message/pubsub_event/collection/associate"""
+ msg = self.Message()
+ msg['pubsub_event']['collection']['associate']['node'] = 'cheese'
+ msg['pubsub_event']['collection']['node'] = 'cheeseburger'
+ msg['type'] = 'headline'
+ self.checkMessage(msg, """
+
+
+
+
+
+
+ """)
+
+ def testCollectionDisassociate(self):
+ """Testing message/pubsub_event/collection/disassociate"""
+ msg = self.Message()
+ msg['pubsub_event']['collection']['disassociate']['node'] = 'cheese'
+ msg['pubsub_event']['collection']['node'] = 'cheeseburger'
+ msg['type'] = 'headline'
+ self.checkMessage(msg, """
+
+
+
+
+
+
+ """)
+
+ def testEventConfiguration(self):
+ """Testing message/pubsub_event/configuration/config"""
+ msg = self.Message()
+ msg['pubsub_event']['configuration']['node'] = 'cheese'
+ msg['pubsub_event']['configuration']['form'].addField('pubsub#title',
+ ftype='text-single',
+ value='This thing is awesome')
+ msg['type'] = 'headline'
+ self.checkMessage(msg, """
+
+
+
+
+
+ This thing is awesome
+
+
+
+
+ """)
+
+ def testEventPurge(self):
+ """Testing message/pubsub_event/purge"""
+ msg = self.Message()
+ msg['pubsub_event']['purge']['node'] = 'pickles'
+ msg['type'] = 'headline'
+ self.checkMessage(msg, """
+
+
+
+
+ """)
+
+ def testEventSubscription(self):
+ """Testing message/pubsub_event/subscription"""
+ msg = self.Message()
+ msg['pubsub_event']['subscription']['node'] = 'pickles'
+ msg['pubsub_event']['subscription']['jid'] = 'fritzy@netflint.net/test'
+ msg['pubsub_event']['subscription']['subid'] = 'aabb1122'
+ msg['pubsub_event']['subscription']['subscription'] = 'subscribed'
+ msg['pubsub_event']['subscription']['expiry'] = 'presence'
+ msg['type'] = 'headline'
+ self.checkMessage(msg, """
+
+
+
+
+ """)
+
+suite = unittest.TestLoader().loadTestsFromTestCase(TestPubsubStanzas)