Mercurial > libervia-pubsub
view idavoll/test/test_storage.py @ 127:d3689da18ed2
Don't use encode('utf-8') on serialized XML.
Return unicode strings for get_items()
Rename get_items_by_ids() to get_items_by_id() as in the interface.
Make purge() work.
Don't return item ids when removing items.
author | Ralph Meijer <ralphm@ik.nu> |
---|---|
date | Sun, 24 Apr 2005 17:21:43 +0000 |
parents | 8f99b4f7aea2 |
children | fe8cb99363ff |
line wrap: on
line source
from twisted.trial import unittest from twisted.trial.assertions import * from twisted.words.protocols.jabber import jid from twisted.internet import defer from idavoll import storage OWNER = jid.JID('owner@example.com') SUBSCRIBER = jid.JID('subscriber@example.com/Home') SUBSCRIBER_NEW = jid.JID('new@example.com/Home') SUBSCRIBER_TO_BE_DELETED = jid.JID('to_be_deleted@example.com/Home') SUBSCRIBER_PENDING = jid.JID('pending@example.com/Home') class StorageTests: def _assignTestNode(self, node): self.node = node def setUpClass(self): d = self.s.get_node('pre-existing') d.addCallback(self._assignTestNode) return d def testGetNode(self): return self.s.get_node('pre-existing') def testGetNonExistingNode(self): d = self.s.get_node('non-existing') assertFailure(d, storage.NodeNotFound) return d def testGetNodeIDs(self): def cb(node_ids): assertIn('pre-existing', node_ids) assertNotIn('non-existing', node_ids) return self.s.get_node_ids().addCallback(cb) def testCreateExistingNode(self): d = self.s.create_node('pre-existing', OWNER) assertFailure(d, storage.NodeExists) return d def testCreateNode(self): def cb(void): d = self.s.get_node('new 1') return d d = self.s.create_node('new 1', OWNER) d.addCallback(cb) return d def testDeleteNonExistingNode(self): d = self.s.delete_node('non-existing') assertFailure(d, storage.NodeNotFound) return d def testDeleteNode(self): def cb(void): d = self.s.get_node('to-be-deleted') assertFailure(d, storage.NodeNotFound) return d d = self.s.delete_node('to-be-deleted') d.addCallback(cb) return d def testGetAffiliations(self): def cb(affiliations): assertIn(('pre-existing', 'owner'), affiliations) d = self.s.get_affiliations(OWNER) d.addCallback(cb) return d def testGetSubscriptions(self): def cb(subscriptions): assertIn(('pre-existing', SUBSCRIBER, 'subscribed'), subscriptions) d = self.s.get_subscriptions(SUBSCRIBER) d.addCallback(cb) return d # Node tests def testGetType(self): assertEqual(self.node.get_type(), 'leaf') def testGetConfiguration(self): config = self.node.get_configuration() assertIn('pubsub#persist_items', config.iterkeys()) assertIn('pubsub#deliver_payloads', config.iterkeys()) assertEqual(config['pubsub#persist_items'], True) assertEqual(config['pubsub#deliver_payloads'], True) def testSetConfiguration(self): def get_config(node): d = node.set_configuration({'pubsub#persist_items': False}) d.addCallback(lambda _: node) return d def check_object_config(node): config = node.get_configuration() assertEqual(config['pubsub#persist_items'], False) def get_node(void): return self.s.get_node('to-be-reconfigured') def check_storage_config(node): config = node.get_configuration() assertEqual(config['pubsub#persist_items'], False) d = self.s.get_node('to-be-reconfigured') d.addCallback(get_config) d.addCallback(check_object_config) d.addCallback(get_node) d.addCallback(check_storage_config) return d def testGetMetaData(self): meta_data = self.node.get_meta_data() for key, value in self.node.get_configuration().iteritems(): assertIn(key, meta_data.iterkeys()) assertEqual(value, meta_data[key]) assertIn('pubsub#node_type', meta_data.iterkeys()) assertEqual(meta_data['pubsub#node_type'], 'leaf') def testGetAffiliation(self): def cb(affiliation): assertEqual(affiliation, 'owner') d = self.node.get_affiliation(OWNER) d.addCallback(cb) return d def testGetNonExistingAffiliation(self): def cb(affiliation): assertEqual(affiliation, None) d = self.node.get_affiliation(SUBSCRIBER) d.addCallback(cb) return d def testAddSubscription(self): def cb1(void): return self.node.get_subscription(SUBSCRIBER_NEW) def cb2(state): assertEqual(state, 'pending') d = self.node.add_subscription(SUBSCRIBER_NEW, 'pending') d.addCallback(cb1) d.addCallback(cb2) return d def testAddExistingSubscription(self): d = self.node.add_subscription(SUBSCRIBER, 'pending') assertFailure(d, storage.SubscriptionExists) return d def testGetSubscription(self): def cb(subscriptions): assertEquals(subscriptions[0][1], 'subscribed') assertEquals(subscriptions[1][1], 'pending') assertEquals(subscriptions[2][1], None) d = defer.DeferredList([self.node.get_subscription(SUBSCRIBER), self.node.get_subscription(SUBSCRIBER_PENDING), self.node.get_subscription(OWNER)]) d.addCallback(cb) return d def testRemoveSubscription(self): return self.node.remove_subscription(SUBSCRIBER_TO_BE_DELETED) def testRemoveNonExistingSubscription(self): d = self.node.remove_subscription(OWNER) assertFailure(d, storage.SubscriptionNotFound) return d def testGetSubscribers(self): def cb(subscribers): assertIn(SUBSCRIBER, subscribers) assertNotIn(SUBSCRIBER_PENDING, subscribers) assertNotIn(OWNER, subscribers) d = self.node.get_subscribers() d.addCallback(cb) return d def testIsSubscriber(self): def cb(subscribed): assertEquals(subscribed[0][1], True) assertEquals(subscribed[1][1], False) assertEquals(subscribed[2][1], False) d = defer.DeferredList([self.node.is_subscribed(SUBSCRIBER), self.node.is_subscribed(SUBSCRIBER_PENDING), self.node.is_subscribed(OWNER)]) d.addCallback(cb) return d class MemoryStorageStorageTestCase(unittest.TestCase, StorageTests): def setUpClass(self): from idavoll.memory_storage import Storage, LeafNode, Subscription, \ default_config self.s = Storage() self.s._nodes['pre-existing'] = \ LeafNode('pre-existing', OWNER, default_config) self.s._nodes['to-be-deleted'] = \ LeafNode('to-be-deleted', OWNER, None) self.s._nodes['to-be-reconfigured'] = \ LeafNode('to-be-reconfigured', OWNER, default_config) subscriptions = self.s._nodes['pre-existing']._subscriptions subscriptions[SUBSCRIBER.full()] = Subscription('subscribed') subscriptions[SUBSCRIBER_TO_BE_DELETED.full()] = \ Subscription('subscribed') subscriptions[SUBSCRIBER_PENDING.full()] = \ Subscription('pending') return StorageTests.setUpClass(self) class PgsqlStorageStorageTestCase(unittest.TestCase, StorageTests): def _callSuperSetUpClass(self, void): return StorageTests.setUpClass(self) def setUpClass(self): from idavoll.pgsql_storage import Storage self.s = Storage('ralphm', 'pubsub_test') self.s._dbpool.start() d = self.s._dbpool.runInteraction(self.init) d.addCallback(self._callSuperSetUpClass) return d def tearDownClass(self): # return self.s._dbpool.runInteraction(self.cleandb) pass def init(self, cursor): self.cleandb(cursor) cursor.execute("""INSERT INTO nodes (node) VALUES ('pre-existing')""") cursor.execute("""INSERT INTO nodes (node) VALUES ('to-be-deleted')""") cursor.execute("""INSERT INTO nodes (node) VALUES ('to-be-reconfigured')""") cursor.execute("""INSERT INTO entities (jid) VALUES (%s)""", OWNER.userhost().encode('utf-8')) cursor.execute("""INSERT INTO affiliations (node_id, entity_id, affiliation) SELECT nodes.id, entities.id, 'owner' FROM nodes, entities WHERE node='pre-existing' AND jid=%s""", OWNER.userhost().encode('utf-8')) cursor.execute("""INSERT INTO entities (jid) VALUES (%s)""", SUBSCRIBER.userhost().encode('utf-8')) cursor.execute("""INSERT INTO subscriptions (node_id, entity_id, resource, subscription) SELECT nodes.id, entities.id, %s, 'subscribed' FROM nodes, entities WHERE node='pre-existing' AND jid=%s""", (SUBSCRIBER.resource.encode('utf-8'), SUBSCRIBER.userhost().encode('utf-8'))) cursor.execute("""INSERT INTO entities (jid) VALUES (%s)""", SUBSCRIBER_TO_BE_DELETED.userhost().encode('utf-8')) cursor.execute("""INSERT INTO subscriptions (node_id, entity_id, resource, subscription) SELECT nodes.id, entities.id, %s, 'subscribed' FROM nodes, entities WHERE node='pre-existing' AND jid=%s""", (SUBSCRIBER_TO_BE_DELETED.resource.encode('utf-8'), SUBSCRIBER_TO_BE_DELETED.userhost().encode('utf-8'))) cursor.execute("""INSERT INTO entities (jid) VALUES (%s)""", SUBSCRIBER_PENDING.userhost().encode('utf-8')) cursor.execute("""INSERT INTO subscriptions (node_id, entity_id, resource, subscription) SELECT nodes.id, entities.id, %s, 'pending' FROM nodes, entities WHERE node='pre-existing' AND jid=%s""", (SUBSCRIBER_PENDING.resource.encode('utf-8'), SUBSCRIBER_PENDING.userhost().encode('utf-8'))) def cleandb(self, cursor): cursor.execute("""DELETE FROM nodes WHERE node in ('non-existing', 'pre-existing', 'to-be-deleted', 'new 1', 'new 2', 'new 3', 'to-be-reconfigured')""") cursor.execute("""DELETE FROM entities WHERE jid=%s""", OWNER.userhost().encode('utf-8')) cursor.execute("""DELETE FROM entities WHERE jid=%s""", SUBSCRIBER.userhost().encode('utf-8')) cursor.execute("""DELETE FROM entities WHERE jid=%s""", SUBSCRIBER_TO_BE_DELETED.userhost().encode('utf-8')) cursor.execute("""DELETE FROM entities WHERE jid=%s""", SUBSCRIBER_PENDING.userhost().encode('utf-8'))