Commit 48083622 authored by Barry Warsaw's avatar Barry Warsaw

Changes to make the tests more robust under Windows.

checkCreateNoFile(), checkCreateWithFilename(),
checkCreateWithFileobj(): Make sure these tests close the file object
before they attempt to unlink the underlying file.y

checkCloseNoUnlink(), checkDel(): New tests in the CreateCommitLogTest
class.

CloseCommitLogTest: removed this class; its tests are folded into
CreateCommitLogTest.
parent 2dc88797
...@@ -15,53 +15,52 @@ import CommitLog ...@@ -15,53 +15,52 @@ import CommitLog
class CreateCommitLogTest(unittest.TestCase): class CreateCommitLogTest(unittest.TestCase):
def checkCreateNoFile(self): def checkCreateNoFile(self):
"""Commit log creation with auto-generation of log file"""
log = CommitLog.CommitLog() log = CommitLog.CommitLog()
filename = log.get_filename() filename = log.get_filename()
try:
assert os.path.exists(filename) assert os.path.exists(filename)
os.unlink(filename) finally:
log.close(unlink=1)
assert not os.path.exists(filename)
def checkCreateWithFilename(self): def checkCreateWithFilename(self):
"""Commit log creation with named file"""
filename = 'commit.log' filename = 'commit.log'
log = CommitLog.CommitLog(filename) log = CommitLog.CommitLog(filename)
try:
assert os.path.exists(filename) assert os.path.exists(filename)
os.unlink(filename) finally:
log.close(unlink=1)
assert not os.path.exists(filename)
def checkCreateWithFileobj(self): def checkCreateWithFileobj(self):
"""Commit log use of existing file object"""
filename = 'commit.log' filename = 'commit.log'
fp = open(filename, 'w+b') fp = open(filename, 'w+b')
try:
self.assertRaises(CommitLog.TruncationError, self.assertRaises(CommitLog.TruncationError,
CommitLog.CommitLog, fp) CommitLog.CommitLog, fp)
finally:
fp.close()
os.unlink(filename) os.unlink(filename)
def checkCloseNoUnlink(self):
log = CommitLog.CommitLog()
class CloseCommitLogTest(unittest.TestCase): filename = log.get_filename()
def setUp(self): log.close()
self._log = CommitLog.CommitLog() try:
self._filename = self._log.get_filename() assert os.path.exists(filename)
finally:
def tearDown(self): os.unlink(filename)
if self._filename: assert not os.path.exists(filename)
os.unlink(self._filename)
def checkDel(self): def checkDel(self):
"""CommitLog.__del__()""" log = CommitLog.CommitLog()
del self._log filename = log.get_filename()
assert os.path.exists(self._filename) del log
try:
def checkCloseDefaults(self): assert os.path.exists(filename)
"""CommitLog.close(), same as CommitLog.__del__()""" finally:
self._log.close() os.unlink(filename)
assert os.path.exists(self._filename) assert not os.path.exists(filename)
def checkCloseWithUnlink(self):
"""CommitLog.close(unlink=1)"""
self._log.close(unlink=1)
assert not os.path.exists(self._filename)
self._filename = None
...@@ -76,29 +75,24 @@ class BaseSetupTearDown(unittest.TestCase): ...@@ -76,29 +75,24 @@ class BaseSetupTearDown(unittest.TestCase):
class CommitLogStateTransitionTest(BaseSetupTearDown): class CommitLogStateTransitionTest(BaseSetupTearDown):
def checkProperStart(self): def checkProperStart(self):
"""Newly created log file initializes state to START"""
# BAW: best we can do is make sure we can start a new commit log # BAW: best we can do is make sure we can start a new commit log
self._log.start() self._log.start()
def checkAppendSetsOpen(self): def checkAppendSetsOpen(self):
"""First append sets log file state to OPEN"""
# BAW: Best we can do is assert that the state isn't START # BAW: Best we can do is assert that the state isn't START
self._log._append('x', 'ignore') self._log._append('x', 'ignore')
self.assertRaises(CommitLog.StateTransitionError, self._log.start) self.assertRaises(CommitLog.StateTransitionError, self._log.start)
def checkPromiseSetsPromise(self): def checkPromiseSetsPromise(self):
"""Promising from START or OPEN sets state to PROMISE"""
# BAW: Best we can do is assert that state isn't START # BAW: Best we can do is assert that state isn't START
self._log.promise() self._log.promise()
self.assertRaises(CommitLog.StateTransitionError, self._log.start) self.assertRaises(CommitLog.StateTransitionError, self._log.start)
def checkBadDoublePromise(self): def checkBadDoublePromise(self):
"""Promising an already promised transaction fails"""
self._log.promise() self._log.promise()
self.assertRaises(CommitLog.StateTransitionError, self._log.promise) self.assertRaises(CommitLog.StateTransitionError, self._log.promise)
def checkFinishSetsStart(self): def checkFinishSetsStart(self):
"""Finishing sets state to START"""
self._log.finish() self._log.finish()
# BAW: best we can do is make sure we can start a new commit log # BAW: best we can do is make sure we can start a new commit log
self._log.start() self._log.start()
...@@ -125,7 +119,6 @@ class Gen: ...@@ -125,7 +119,6 @@ class Gen:
class LowLevelStoreAndLoadTest(BaseSetupTearDown): class LowLevelStoreAndLoadTest(BaseSetupTearDown):
def checkOneStoreAndLoad(self): def checkOneStoreAndLoad(self):
"""Low-level storing one record and reading it back"""
self._log.start() self._log.start()
self._log._append('x', 'ignore') self._log._append('x', 'ignore')
self._log.promise() self._log.promise()
...@@ -134,7 +127,6 @@ class LowLevelStoreAndLoadTest(BaseSetupTearDown): ...@@ -134,7 +127,6 @@ class LowLevelStoreAndLoadTest(BaseSetupTearDown):
assert None == self._log._next() assert None == self._log._next()
def checkTenStoresAndLoads(self): def checkTenStoresAndLoads(self):
"""Low-level storing ten records and reading them back"""
self._log.start() self._log.start()
for k, v in Gen(): for k, v in Gen():
self._log._append(k, v) self._log._append(k, v)
...@@ -156,7 +148,6 @@ class PacklessLogTest(BaseSetupTearDown): ...@@ -156,7 +148,6 @@ class PacklessLogTest(BaseSetupTearDown):
self._log.start() self._log.start()
def checkOneStoreAndLoad(self): def checkOneStoreAndLoad(self):
"""PacklessLog: API for one object"""
self._log.write_object(oid=10, pickle='ignore') self._log.write_object(oid=10, pickle='ignore')
self._log.promise() self._log.promise()
oid, pickle = self._log.next() oid, pickle = self._log.next()
...@@ -164,7 +155,6 @@ class PacklessLogTest(BaseSetupTearDown): ...@@ -164,7 +155,6 @@ class PacklessLogTest(BaseSetupTearDown):
assert None == self._log.next() assert None == self._log.next()
def checkTenStoresAndLoads(self): def checkTenStoresAndLoads(self):
"""PacklessLog: API storing ten objects and reading them back"""
for k, v in Gen(): for k, v in Gen():
self._log.write_object(v, k*10) self._log.write_object(v, k*10)
self._log.promise() self._log.promise()
...@@ -186,7 +176,6 @@ class FullLogTest(BaseSetupTearDown): ...@@ -186,7 +176,6 @@ class FullLogTest(BaseSetupTearDown):
self._log.start() self._log.start()
def checkOneStoreAndLoad(self): def checkOneStoreAndLoad(self):
"""FullLog: API for one object"""
oid = 10 oid = 10
vid = 8 vid = 8
nvrevid = 0 nvrevid = 0
...@@ -203,7 +192,6 @@ class FullLogTest(BaseSetupTearDown): ...@@ -203,7 +192,6 @@ class FullLogTest(BaseSetupTearDown):
assert None == self._log.next() assert None == self._log.next()
def checkOtherWriteMethods(self): def checkOtherWriteMethods(self):
"""FullLog: check other write_*() methods"""
oid = 10 oid = 10
vid = 1 vid = 1
nvrevid = 0 nvrevid = 0
...@@ -244,14 +232,12 @@ class FullLogTest(BaseSetupTearDown): ...@@ -244,14 +232,12 @@ class FullLogTest(BaseSetupTearDown):
def suite(): def suite():
suite = unittest.TestSuite() suite = unittest.TestSuite()
# Creation # Creation and closing
suite.addTest(CreateCommitLogTest('checkCreateNoFile')) suite.addTest(CreateCommitLogTest('checkCreateNoFile'))
suite.addTest(CreateCommitLogTest('checkCreateWithFilename')) suite.addTest(CreateCommitLogTest('checkCreateWithFilename'))
suite.addTest(CreateCommitLogTest('checkCreateWithFileobj')) suite.addTest(CreateCommitLogTest('checkCreateWithFileobj'))
# Closing suite.addTest(CreateCommitLogTest('checkCloseNoUnlink'))
suite.addTest(CloseCommitLogTest('checkDel')) suite.addTest(CreateCommitLogTest('checkDel'))
suite.addTest(CloseCommitLogTest('checkCloseDefaults'))
suite.addTest(CloseCommitLogTest('checkCloseWithUnlink'))
# State transitions # State transitions
suite.addTest(CommitLogStateTransitionTest('checkProperStart')) suite.addTest(CommitLogStateTransitionTest('checkProperStart'))
suite.addTest(CommitLogStateTransitionTest('checkAppendSetsOpen')) suite.addTest(CommitLogStateTransitionTest('checkAppendSetsOpen'))
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment