Retry on DBDeadlock

In some situations DBDeadlock may be raised. Retry in such case.

Change-Id: Id37b46b3bc85b93d4992a355a2be33dade71ea02
Partial-Bug: #1537738
This commit is contained in:
Oleksii Chuprykov 2016-02-10 18:34:30 +02:00
parent a48ca70ace
commit ea5424a9f3
2 changed files with 27 additions and 0 deletions

View File

@ -16,6 +16,7 @@ import datetime
import sys
from oslo_config import cfg
from oslo_db import api as oslo_db_api
from oslo_db.sqlalchemy import session as db_session
from oslo_db.sqlalchemy import utils
from oslo_serialization import jsonutils
@ -545,6 +546,8 @@ def stack_delete(context, stack_id):
session.flush()
@oslo_db_api.wrap_db_retry(max_retries=3, retry_on_deadlock=True,
retry_interval=0.5, inc_retry_interval=True)
def stack_lock_create(stack_id, engine_id):
session = get_session()
with session.begin():
@ -1148,6 +1151,8 @@ def sync_point_delete_all_by_stack_and_traversal(context, stack_id,
return rows_deleted
@oslo_db_api.wrap_db_retry(max_retries=3, retry_on_deadlock=True,
retry_interval=0.5, inc_retry_interval=True)
def sync_point_create(context, values):
values['entity_id'] = str(values['entity_id'])
sync_point_ref = models.SyncPoint()

View File

@ -13,11 +13,13 @@
import datetime
import json
import time
import uuid
import mock
import mox
from oslo_config import cfg
from oslo_db import exception as db_exception
from oslo_utils import timeutils
import six
@ -2157,6 +2159,14 @@ class DBAPIStackLockTest(common.HeatTestCase):
observed = db_api.stack_lock_release(self.stack.id, UUID2)
self.assertTrue(observed)
@mock.patch.object(time, 'sleep')
def test_stack_lock_retry_on_deadlock(self, sleep):
with mock.patch('sqlalchemy.orm.Session.add',
side_effect=db_exception.DBDeadlock) as mock_add:
self.assertRaises(db_exception.DBDeadlock,
db_api.stack_lock_create, self.stack.id, UUID1)
self.assertEqual(4, mock_add.call_count)
class DBAPIResourceDataTest(common.HeatTestCase):
def setUp(self):
@ -2791,6 +2801,18 @@ class DBAPISyncPointTest(common.HeatTestCase):
)
self.assertIsNone(ret_sync_point_stack)
@mock.patch.object(time, 'sleep')
def test_syncpoint_create_deadlock(self, sleep):
with mock.patch('sqlalchemy.orm.Session.add',
side_effect=db_exception.DBDeadlock) as add:
for res in self.resources:
self.assertRaises(db_exception.DBDeadlock,
create_sync_point,
self.ctx, entity_id=str(res.id),
stack_id=self.stack.id,
traversal_id=self.stack.current_traversal)
self.assertEqual(len(self.resources) * 4, add.call_count)
class DBAPICryptParamsPropsTest(common.HeatTestCase):
def setUp(self):