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:
parent
a48ca70ace
commit
ea5424a9f3
@ -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()
|
||||
|
@ -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):
|
||||
|
Loading…
Reference in New Issue
Block a user