Commit bd415c7a authored by Jim Fulton's avatar Jim Fulton

Added a number of helpers.

parent 5c263660
...@@ -12,10 +12,10 @@ ...@@ -12,10 +12,10 @@
# #
############################################################################## ##############################################################################
"""Conventience function for creating test databases """Conventience function for creating test databases
$Id$
""" """
from __future__ import with_statement
from ZODB.MappingStorage import DB from ZODB.MappingStorage import DB
import atexit import atexit
...@@ -24,8 +24,12 @@ import tempfile ...@@ -24,8 +24,12 @@ import tempfile
import time import time
import unittest import unittest
import persistent import persistent
import sys
import time
import transaction import transaction
import warnings
import zope.testing.setupstack import zope.testing.setupstack
import ZODB.utils
def setUp(test, name='test'): def setUp(test, name='test'):
transaction.abort() transaction.abort()
...@@ -99,3 +103,38 @@ class AAAA_Test_Runner_Hack(unittest.TestCase): ...@@ -99,3 +103,38 @@ class AAAA_Test_Runner_Hack(unittest.TestCase):
def testNothing(self): def testNothing(self):
pass pass
def assert_warning(category, func, warning_text=''):
if sys.version_info < (2, 6):
return func() # Can't use catch_warnings :(
with warnings.catch_warnings(record=True) as w:
warnings.simplefilter('default')
result = func()
for warning in w:
if ((warning.category is category)
and (warning_text in str(warning.message))):
return result
raise AssertionError(w)
def assert_deprecated(func, warning_text=''):
return assert_warning(DeprecationWarning, func, warning_text)
def wait(func=None, timeout=30):
if func is None:
return lambda f: wait(f, timeout)
for i in xrange(int(timeout*100)):
if func():
return
time.sleep(.01)
raise AssertionError
def store(storage, oid, value='x', serial=ZODB.utils.z64):
if not isinstance(oid, str):
oid = ZODB.utils.p64(oid)
if not isinstance(serial, str):
serial = ZODB.utils.p64(serial)
t = transaction.get()
storage.tpc_begin(t)
storage.store(oid, serial, value, '', t)
storage.tpc_vote(t)
storage.tpc_finish(t)
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