diff idavoll/test/test_storage.py @ 114:e7cfe05bc1d2

Initial revision.
author Ralph Meijer <ralphm@ik.nu>
date Fri, 08 Apr 2005 16:33:40 +0000
parents
children bc872c33e88c
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/idavoll/test/test_storage.py	Fri Apr 08 16:33:40 2005 +0000
@@ -0,0 +1,120 @@
+from twisted.trial import unittest
+from twisted.trial.assertions import *
+from twisted.words.protocols.jabber import jid
+
+from idavoll import storage
+
+OWNER = jid.JID('owner@example.com')
+SUBSCRIBER = jid.JID('subscriber@example.com/Home')
+
+class StorageTests:
+
+    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
+
+class MemoryStorageStorageTestCase(unittest.TestCase, StorageTests):
+
+    def setUpClass(self):
+        from idavoll.memory_storage import Storage, LeafNode, Subscription
+        self.s = Storage()
+        self.s._nodes['pre-existing'] = LeafNode('pre-existing', OWNER, None)
+        self.s._nodes['to-be-deleted'] = LeafNode('to-be-deleted', OWNER, None)
+        self.s._nodes['pre-existing']._subscriptions[SUBSCRIBER.full()] = \
+                Subscription('subscribed')
+
+class PgsqlStorageStorageTestCase(unittest.TestCase, StorageTests):
+    def setUpClass(self):
+        from idavoll.pgsql_storage import Storage
+        self.s = Storage('ralphm', 'pubsub_test')
+        self.s._dbpool.start()
+        return self.s._dbpool.runInteraction(self.init)
+
+    def tearDownClass(self):
+        return self.s._dbpool.runInteraction(self.cleandb)
+
+    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 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')))
+    
+    def cleandb(self, cursor):
+        cursor.execute("""DELETE FROM nodes WHERE node in
+                          ('pre-existing', 'new 1', 'new 2', 'new 3')""")
+        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'))