From 6ca0676893a11bdb65c890aad4c31d9621d51192 Mon Sep 17 00:00:00 2001 From: Vincent Pelletier <vincent@nexedi.com> Date: Tue, 5 Feb 2008 21:37:06 +0000 Subject: [PATCH] Same fixes as commits 19076 and 19077 on SQLQueue. git-svn-id: https://svn.erp5.org/repos/public/erp5/trunk@19087 20353a03-c40f-0410-a6d1-a30d3c3de9de --- product/CMFActivity/Activity/SQLDict.py | 21 +++++++-------------- 1 file changed, 7 insertions(+), 14 deletions(-) diff --git a/product/CMFActivity/Activity/SQLDict.py b/product/CMFActivity/Activity/SQLDict.py index 8887711fad..e58a81385e 100644 --- a/product/CMFActivity/Activity/SQLDict.py +++ b/product/CMFActivity/Activity/SQLDict.py @@ -411,20 +411,6 @@ class SQLDict(RAMDict, SQLBase): method(*args) except: LOG('SQLDict', WARNING, 'Exception raised when invoking messages (uid, path, method_id) %r' % ([(x[0], x[1].object_path, x[1].method_id) for x in message_uid_priority_list], ), error=sys.exc_info()) - to_free_uid_list = [x[0] for x in message_uid_priority_list] - try: - # Rollback all changes made on activity connection. - # We will commit to make messages available, and we cannot control - # what was done by the activity: it might have used the activity - # connection. As the transaction failed, we must rollback these - # potential changes before being allowed to commit in - # makeMessageListAvailable. - activity_tool.SQLDict_rollback() - makeMessageListAvailable(to_free_uid_list) - except: - LOG('SQLDict', PANIC, 'Failed to free messages: %r' % (to_free_uid_list, ), error=sys.exc_info()) - else: - LOG('SQLDict', TRACE, 'Freed messages %r' % (to_free_uid_list)) try: abortTransactionSynchronously() except: @@ -432,6 +418,13 @@ class SQLDict(RAMDict, SQLBase): LOG('SQLDict', PANIC, 'abort failed, thus some objects may be modified accidentally') return True # Stop processing messages for this tic call for this queue. + to_free_uid_list = [x[0] for x in message_uid_priority_list] + try: + makeMessageListAvailable(to_free_uid_list) + except: + LOG('SQLDict', PANIC, 'Failed to free messages: %r' % (to_free_uid_list, ), error=sys.exc_info()) + else: + LOG('SQLDict', TRACE, 'Freed messages %r' % (to_free_uid_list)) # Abort if something failed. if len([x for x in message_uid_priority_list if not x[1].is_executed]) != 0: endTransaction = abortTransactionSynchronously -- 2.30.9