[Zodb-checkins] SVN: ZODB/trunk/src/ZEO/tests/servertesting.py Created small infrastructure that makes testing some aspects of zeo
Jim Fulton
jim at zope.com
Mon Sep 28 15:03:06 EDT 2009
Log message for revision 104592:
Created small infrastructure that makes testing some aspects of zeo
servers much easier. This was easier than I expected. I should have
done this a long time ago. :)
Changed:
A ZODB/trunk/src/ZEO/tests/servertesting.py
-=-
Added: ZODB/trunk/src/ZEO/tests/servertesting.py
===================================================================
--- ZODB/trunk/src/ZEO/tests/servertesting.py (rev 0)
+++ ZODB/trunk/src/ZEO/tests/servertesting.py 2009-09-28 19:03:05 UTC (rev 104592)
@@ -0,0 +1,58 @@
+##############################################################################
+#
+# Copyright Zope Foundation and Contributors.
+# All Rights Reserved.
+#
+# This software is subject to the provisions of the Zope Public License,
+# Version 2.1 (ZPL). A copy of the ZPL should accompany this distribution.
+# THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
+# WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+# WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
+# FOR A PARTICULAR PURPOSE.
+#
+##############################################################################
+
+# Testing the current ZEO implementation is rather hard due to the
+# architecture, which mixes concerns, especially between application
+# and networking. Still, it's not as bad as it could be.
+
+# The 2 most important classes in the architecture are ZEOStorage and
+# StorageServer. A ZEOStorage is created for each client connection.
+# The StorageServer maintains data shared or needed for coordination
+# among clients.
+
+# The other important part of the architecture is connections.
+# Connections are used by ZEOStorages to send messages or return data
+# to clients.
+
+# Here, we'll try to provide some testing infrastructure to isolate
+# servers from the network.
+
+import ZEO.StorageServer
+import ZEO.zrpc.connection
+import ZEO.zrpc.error
+
+class StorageServer(ZEO.StorageServer.StorageServer):
+
+ def DispatcherClass(*args, **kw):
+ pass
+
+class Conection:
+
+ peer_protocol_version = ZEO.zrpc.connection.Connection.current_protocol
+ connected = True
+
+ def __init__(self, name='connection', addr='test-addr'):
+ self.name = name
+ self.addr = addr
+
+ def close(self):
+ print self.name, 'closed'
+ self.connected = False
+
+ def poll(self):
+ if not self.connected:
+ raise ZEO.zrpc.error.DisconnectedError()
+
+ def callAsync(self, meth, *args):
+ print self.name, 'callAsync', meth, repr(args)
Property changes on: ZODB/trunk/src/ZEO/tests/servertesting.py
___________________________________________________________________
Added: svn:keywords
+ Id
Added: svn:eol-style
+ native
More information about the Zodb-checkins
mailing list