[Zope-Checkins] CVS: ZODB3/ZEO/tests - testConnection.py:1.4

Barry Warsaw barry@wooz.org
Tue, 10 Dec 2002 17:44:26 -0500


Update of /cvs-repository/ZODB3/ZEO/tests
In directory cvs.zope.org:/tmp/cvs-serv28352

Modified Files:
	testConnection.py 
Log Message:
Refactor a bit to allow Berkeley storages to be included in these
tests, including read_only tests.


=== ZODB3/ZEO/tests/testConnection.py 1.3 => 1.4 ===
--- ZODB3/ZEO/tests/testConnection.py:1.3	Tue Dec 10 16:48:23 2002
+++ ZODB3/ZEO/tests/testConnection.py	Tue Dec 10 17:44:26 2002
@@ -36,13 +36,8 @@
 
     """Add Unix-specific scaffolding to the generic test suite."""
 
-    def startServer(self, create=1, index=0, read_only=0, ro_svr=0):
-        zLOG.LOG("testZEO", zLOG.INFO,
-                 "startServer(create=%d, index=%d, read_only=%d)" %
-                 (create, index, read_only))
-        path = "%s.%d" % (self.file, index)
-        addr = self.addr[index]
-        conf = """\
+    def getConfig(self, path, create, read_only):
+        return """\
         <Storage>
             type FileStorage
             file_name %s
@@ -52,6 +47,13 @@
                          create and 'yes' or 'no',
                          read_only and 'yes' or 'no')
 
+    def startServer(self, create=1, index=0, read_only=0, ro_svr=0):
+        zLOG.LOG("testZEO", zLOG.INFO,
+                 "startServer(create=%d, index=%d, read_only=%d)" %
+                 (create, index, read_only))
+        path = "%s.%d" % (self.file, index)
+        addr = self.addr[index]
+        conf = self.getConfig(path, create, read_only)
         pid, server = forker.start_zeo_server(conf, addr, ro_svr)
         self._pids.append(pid)
         self._servers.append(server)
@@ -66,6 +68,18 @@
             except os.error, err:
                 print err
 
+
+class BDBConnectionTests(UnixConnectionTests):
+    def getConfig(self, path, create, read_only):
+        # Full always creates and doesn't have a read_only flag
+        return """\
+        <Storage>
+            type Full
+            name %s
+            read_only %s
+        </Storage>""" % (path, read_only)
+
+
 class WindowsConnectionTests(ConnectionTests):
 
     """Add Windows-specific scaffolding to the generic test suite."""
@@ -92,6 +106,7 @@
             # XXX waitpid() isn't available until Python 2.3
             time.sleep(0.5)
 
+
 if os.name == "posix":
     test_classes = [UnixConnectionTests]
 elif os.name == "nt":
@@ -99,8 +114,15 @@
 else:
     raise RuntimeError, "unsupported os: %s" % os.name
 
-def test_suite():
+try:
+    from bsddb3Storage.Full import Full
+except ImportError:
+    pass
+else:
+    test_classes.append(BDBConnectionTests)
 
+
+def test_suite():
     # shutup warnings about mktemp
     import warnings
     warnings.filterwarnings("ignore", "mktemp")