- changed status to resolved
raise objectdeleted on deferred if row isn't present, test coverage
Issue #2191
resolved
diff -r eaa7aa4239af4f42cdb8b370120d1538c6704d6b lib/sqlalchemy/orm/exc.py
--- a/lib/sqlalchemy/orm/exc.py Sun Jun 12 20:35:37 2011 -0400
+++ b/lib/sqlalchemy/orm/exc.py Mon Jun 13 10:45:16 2011 -0400
@@ -7,7 +7,7 @@
"""SQLAlchemy ORM exceptions."""
import sqlalchemy as sa
-
+orm_util = sa.util.importlater('sqlalchemy.orm', 'util')
NO_STATE = (AttributeError, KeyError)
"""Exception types that may be raised by instrumentation implementations."""
@@ -78,7 +78,12 @@
class ObjectDeletedError(sa.exc.InvalidRequestError):
"""An refresh() operation failed to re-retrieve an object's row."""
-
+ def __init__(self, state):
+ sa.exc.InvalidRequestError.__init__(
+ self,
+ "Instance '%s' has been deleted, or its "
+ "row is otherwise not present." % orm_util.state_str(state)
+ )
class UnmappedColumnError(sa.exc.InvalidRequestError):
"""Mapping operation was requested on an unknown column."""
diff -r eaa7aa4239af4f42cdb8b370120d1538c6704d6b lib/sqlalchemy/orm/mapper.py
--- a/lib/sqlalchemy/orm/mapper.py Sun Jun 12 20:35:37 2011 -0400
+++ b/lib/sqlalchemy/orm/mapper.py Mon Jun 13 10:45:16 2011 -0400
@@ -1575,9 +1575,7 @@
# if instance is pending, a refresh operation
# may not complete (even if PK attributes are assigned)
if has_key and result is None:
- raise orm_exc.ObjectDeletedError(
- "Instance '%s' has been deleted." %
- state_str(state))
+ raise orm_exc.ObjectDeletedError(state)
def _optimized_get_statement(self, state, attribute_names):
"""assemble a WHERE clause which retrieves a given state by primary
diff -r eaa7aa4239af4f42cdb8b370120d1538c6704d6b lib/sqlalchemy/orm/strategies.py
--- a/lib/sqlalchemy/orm/strategies.py Sun Jun 12 20:35:37 2011 -0400
+++ b/lib/sqlalchemy/orm/strategies.py Mon Jun 13 10:45:16 2011 -0400
@@ -242,8 +242,10 @@
)
query = session.query(localparent)
- query._load_on_ident(state.key,
- only_load_props=group, refresh_state=state)
+ if query._load_on_ident(state.key,
+ only_load_props=group, refresh_state=state) is None:
+ raise orm_exc.ObjectDeletedError(state)
+
return attributes.ATTR_WAS_SET
log.class_logger(DeferredColumnLoader)
consider adding individual objectdeletederror tests to test_session, breaking up test_get_refreshes in test_expire.
Comments (3)
-
reporter -
reporter test was wrong: a8120e888e8cd5391f33e4a87e087d4eb2379592
-
reporter - removed milestone
Removing milestone: 0.7.2 (automated comment)
- Log in to comment
1a0c8ace3010d9d7bcfd651d4bb1340b83b3850b