diff options
| author | Mike Bayer <mike_mp@zzzcomputing.com> | 2012-09-22 16:03:57 -0400 |
|---|---|---|
| committer | Mike Bayer <mike_mp@zzzcomputing.com> | 2012-09-22 16:03:57 -0400 |
| commit | 03cb8ce548a99b97852c25f2fec26ed611afbb5c (patch) | |
| tree | c8843f6b02b22b835458a039d3dcc3b099bbcbad /lib/sqlalchemy/orm/session.py | |
| parent | 81c1ec33e37c23be58285d4ef607de9b670c547f (diff) | |
| download | sqlalchemy-03cb8ce548a99b97852c25f2fec26ed611afbb5c.tar.gz | |
- [bug] Extra logic has been added to the "flush"
that occurs within Session.commit(), such that the
extra state added by an after_flush() or
after_flush_postexec() hook is also flushed in a
subsequent flush, before the "commit" completes.
Subsequent calls to flush() will continue until
the after_flush hooks stop adding new state.
An "overflow" counter of 100 is also in place,
in the event of a broken after_flush() hook
adding new content each time. [ticket:2566]
Diffstat (limited to 'lib/sqlalchemy/orm/session.py')
| -rw-r--r-- | lib/sqlalchemy/orm/session.py | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/lib/sqlalchemy/orm/session.py b/lib/sqlalchemy/orm/session.py index 36ff5fc84..5e5cf2246 100644 --- a/lib/sqlalchemy/orm/session.py +++ b/lib/sqlalchemy/orm/session.py @@ -294,7 +294,15 @@ class SessionTransaction(object): subtransaction.commit() if not self.session._flushing: - self.session.flush() + for _flush_guard in xrange(100): + if self.session._is_clean(): + break + self.session.flush() + else: + raise exc.FlushError( + "Over 100 subsequent flushes have occurred within " + "session.commit() - is an after_flush() hook " + "creating new objects?") if self._parent is None and self.session.twophase: try: |
