From 0fffbb82000a1a6c3c23d62fedcbd8e8141f8994 Mon Sep 17 00:00:00 2001 From: Lance Stout Date: Thu, 7 Oct 2010 10:58:13 -0400 Subject: Unit test reorganization. Moved SleekTest to sleekxmpp.test. Organized test suites by their focus. - Suites focused on testing stanza objects are named test_stanza_X.py - Suites focused on testing stream behavior are name test_stream_X.py --- tests/test_pubsubstanzas.py | 511 -------------------------------------------- 1 file changed, 511 deletions(-) delete mode 100644 tests/test_pubsubstanzas.py (limited to 'tests/test_pubsubstanzas.py') diff --git a/tests/test_pubsubstanzas.py b/tests/test_pubsubstanzas.py deleted file mode 100644 index 42a1b52e..00000000 --- a/tests/test_pubsubstanzas.py +++ /dev/null @@ -1,511 +0,0 @@ -from . sleektest import * -import sleekxmpp.plugins.xep_0004 as xep_0004 -import sleekxmpp.plugins.stanza_pubsub as pubsub - - -class TestPubsubStanzas(SleekTest): - - 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.check_iq(iq, """ - - - - - - - - """) - - 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.check_iq(iq, """ - - - - - - - - """) - - 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.check_iq(iq, """ - - - - - - - - - """) - - def testItems(self): - "Testing iq/pubsub/items stanzas" - iq = self.Iq() - iq['pubsub']['items']['node'] = 'crap' - 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.check_iq(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.check_iq(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.check_iq(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.check_iq(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.check_iq(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) - - self.check_iq(iq, """ - - - - - - - - - - - - - - - - - - """) - - def testDelete(self): - "Testing iq/pubsub_owner/delete stanzas" - iq = self.Iq() - iq['pubsub_owner']['delete']['node'] = 'thingers' - self.check_iq(iq, """ - - - - - """) - - 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' - - 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'}), - ]) - - self.check_iq(iq, """ - - - - - - - http://jabber.org/protocol/pubsub#node_config - - - leaf - - - - 1 - - - 1 - - - - - 1 - - - - - 10 - - - 1 - - - open - - - publishers - - - never - - - - - - """) - - 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.check_message(msg, """ - - - - - - - - - """) - - 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.check_message(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.check_message(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.check_message(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.check_message(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.check_message(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.check_message(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.check_message(msg, """ - - - - - """) - -suite = unittest.TestLoader().loadTestsFromTestCase(TestPubsubStanzas) -- cgit v1.2.3