emitted on a pending object, it would fail
to load.
+ - [bug] ensure pickleability of all ORM exceptions
+ for multiprocessing compatibility. [ticket:2371]
+
- engine
- [bug] Added __reduce__ to StatementError,
- DBAPIError so that exceptions are pickleable,
- as when using multiprocessing. However, not
+ DBAPIError, column errors so that exceptions
+ are pickleable, as when using multiprocessing.
+ However, not
all DBAPIs support this yet, such as
psycopg2. [ticket:2371]
'required?' % _safe_cls_name(obj))
UnmappedError.__init__(self, msg)
+ def __reduce__(self):
+ return self.__class__, (None, self.args[0])
class UnmappedClassError(UnmappedError):
"""An mapping operation was requested for an unknown class."""
msg = _default_unmapped(cls)
UnmappedError.__init__(self, msg)
+ def __reduce__(self):
+ return self.__class__, (None, self.args[0])
class ObjectDeletedError(sa.exc.InvalidRequestError):
"""A refresh operation failed to retrieve the database
object.
"""
- def __init__(self, state):
- sa.exc.InvalidRequestError.__init__(
- self,
- "Instance '%s' has been deleted, or its "
+ def __init__(self, state, msg=None):
+ if not msg:
+ msg = "Instance '%s' has been deleted, or its "\
"row is otherwise not present." % orm_util.state_str(state)
- )
+
+ sa.exc.InvalidRequestError.__init__(self, msg)
+
+ def __reduce__(self):
+ return self.__class__, (None, self.args[0])
class UnmappedColumnError(sa.exc.InvalidRequestError):
"""Mapping operation was requested on an unknown column."""
screen2 = Screen(Child2(), screen1)
pickle.loads(pickle.dumps(screen2))
+ def test_exceptions(self):
+ class Foo(object):
+ pass
+ users = self.tables.users
+ mapper(User, users)
+
+ for sa_exc in (
+ orm_exc.UnmappedInstanceError(Foo()),
+ orm_exc.UnmappedClassError(Foo),
+ orm_exc.ObjectDeletedError(attributes.instance_state(User())),
+ ):
+ for loads, dumps in picklers():
+ repickled = loads(dumps(sa_exc))
+ eq_(repickled.args[0], sa_exc.args[0])
+
class PolymorphicDeferredTest(fixtures.MappedTest):
@classmethod
def define_tables(cls, metadata):