[Zodb-checkins] CVS: StandaloneZODB/ZEO/tests - testStart.py:1.3
Jeremy Hylton
jeremy@zope.com
Mon, 5 Aug 2002 18:31:25 -0400
Update of /cvs-repository/StandaloneZODB/ZEO/tests
In directory cvs.zope.org:/tmp/cvs-serv29109/tests
Modified Files:
testStart.py
Log Message:
Add a primitive test of zLOG re-initialization.
XXX This will probably hang for Guido.
=== StandaloneZODB/ZEO/tests/testStart.py 1.2 => 1.3 ===
except os.error:
pass
- def stop_server(self):
+ def getpids(self):
if not os.path.exists(self.env.zeo_pid):
# If there's no pid file, assume the server isn't running
- return
- ppid, pid = map(int, open(self.env.zeo_pid).read().split())
+ return None, None
+ return map(int, open(self.env.zeo_pid).read().split())
+
+ def stop_server(self):
+ ppid, pid = self.getpids()
self.kill(pids=[pid])
def kill(self, sig=signal.SIGTERM, pids=None):
@@ -131,6 +134,35 @@
port = 9090
outp = self.fork("-s", "-p", str(port))
self.connect(port=port)
+
+ def testLogRestart(self):
+ port = 9090
+ logfile1 = tempfile.mktemp(suffix="log")
+ logfile2 = tempfile.mktemp(suffix="log")
+ os.environ["EVENT_LOG_FILE"] = logfile1
+
+ try:
+ outp = self.fork("-s", "-p", str(port))
+ self.connect(port=port)
+ buf1 = open(logfile1).read()
+ self.assert_(buf1)
+ os.rename(logfile1, logfile2)
+ ppid, pid = self.getpids()
+ ## os.kill(ppid, signal.SIGHUP)
+ os.kill(pid, signal.SIGHUP)
+ self.connect(port=port)
+ buf2 = open(logfile1).read()
+ self.assert_(buf2)
+ finally:
+ self.shutdown()
+ try:
+ os.unlink(logfile1)
+ except os.error:
+ pass
+ try:
+ os.unlink(logfile2)
+ except os.error:
+ pass
def test_suite():
if os.name == "posix":