[Zodb-checkins] CVS: Packages/ZODB/tests -
PackableStorage.py:1.20.6.3.26.1 StorageTestBase.py:1.27.6.1.36.1
testPersistentMapping.py:1.5.34.1.36.1
Tres Seaver
tseaver at palladion.com
Sat May 28 20:42:23 EDT 2005
Update of /cvs-repository/Packages/ZODB/tests
In directory cvs.zope.org:/tmp/cvs-serv32028/lib/python/ZODB/tests
Modified Files:
Tag: tseaver-hasattr_geddon-branch
PackableStorage.py StorageTestBase.py testPersistentMapping.py
Log Message:
- Removed all uses of the 'hasattr' builtin from the core, where
the object being tested derives (or might) from Persistent.
XXX: currently, this branch imports a 'safe_hasattr' from ZODB.utils,
which adds a dependency on ZODB for some packages; we probably
need a better location, and perhas a C implementation?
=== Packages/ZODB/tests/PackableStorage.py 1.20.6.3 => 1.20.6.3.26.1 ===
--- Packages/ZODB/tests/PackableStorage.py:1.20.6.3 Fri Jan 16 14:17:51 2004
+++ Packages/ZODB/tests/PackableStorage.py Sat May 28 20:41:37 2005
@@ -35,6 +35,7 @@
from ZODB.tests.StorageTestBase import snooze
from ZODB.POSException import ConflictError, StorageError
from ZODB.PersistentMapping import PersistentMapping
+from ZODB.utils import safe_hasattr
ZERO = '\0'*8
@@ -77,7 +78,7 @@
# Fun, huh?
def dumps(obj):
def getpersid(obj):
- if hasattr(obj, 'getoid'):
+ if safe_hasattr(obj, 'getoid'):
return obj.getoid()
return None
s = StringIO()
=== Packages/ZODB/tests/StorageTestBase.py 1.27.6.1 => 1.27.6.1.36.1 ===
--- Packages/ZODB/tests/StorageTestBase.py:1.27.6.1 Mon Sep 15 17:26:57 2003
+++ Packages/ZODB/tests/StorageTestBase.py Sat May 28 20:41:37 2005
@@ -32,6 +32,7 @@
from ZODB.Transaction import Transaction
from ZODB.utils import u64
+from ZODB.utils import safe_hasattr
from ZODB.tests.MinPO import MinPO
@@ -52,7 +53,8 @@
p = Pickler(f, 1)
p.persistent_id = lambda obj: getattr(obj, '_p_oid', None)
klass = obj.__class__
- assert not hasattr(obj, '__getinitargs__'), "not ready for constructors"
+ assert not safe_hasattr(obj,
+ '__getinitargs__'), "not ready for constructors"
args = None
mod = getattr(klass, '__module__', None)
=== Packages/ZODB/tests/testPersistentMapping.py 1.5.34.1 => 1.5.34.1.36.1 ===
--- Packages/ZODB/tests/testPersistentMapping.py:1.5.34.1 Mon Sep 15 17:26:57 2003
+++ Packages/ZODB/tests/testPersistentMapping.py Sat May 28 20:41:37 2005
@@ -25,6 +25,7 @@
import ZODB
from ZODB.MappingStorage import MappingStorage
from ZODB.Transaction import Transaction
+from ZODB.utils import safe_hasattr
import cPickle
import cStringIO
import sys
@@ -49,8 +50,8 @@
# If the root can be loaded successfully, we should be okay.
r = db.open().root()
# But make sure it looks like a new mapping
- self.assert_(hasattr(r, 'data'))
- self.assert_(not hasattr(r, '_container'))
+ self.assert_(safe_hasattr(r, 'data'))
+ self.assert_(not safe_hasattr(r, '_container'))
def checkNewPicklesAreSafe(self):
s = MappingStorage()
@@ -71,8 +72,8 @@
state = u.load()
inst.__setstate__(state)
- self.assert_(hasattr(inst, '_container'))
- self.assert_(not hasattr(inst, 'data'))
+ self.assert_(safe_hasattr(inst, '_container'))
+ self.assert_(not safe_hasattr(inst, 'data'))
def find_global(modulename, classname):
"""Helper for this test suite to get special PersistentMapping"""
More information about the Zodb-checkins
mailing list