db: Remove weird error handling code
The 'driver_initiator_data_insert_by_key' DB API is exceptional in that it attempts to create a DB entry and returns a boolean value if there's a duplicate error rather than raise an exception. This means we need to do some special handling. Avoid the need for this special handling by raising an exception like everyone else and do the mapping to boolean values in the sole caller. Change-Id: I25472f592dbdb487fbbb376cb92ee0dda76b677a Signed-off-by: Stephen Finucane <stephenfin@redhat.com>
This commit is contained in:
parent
0eb2d1f0a7
commit
dc7c101480
@ -1784,9 +1784,6 @@ def driver_initiator_data_insert_by_key(context, initiator,
|
|||||||
"""Updates DriverInitiatorData entry.
|
"""Updates DriverInitiatorData entry.
|
||||||
|
|
||||||
Sets the value for the specified key within the namespace.
|
Sets the value for the specified key within the namespace.
|
||||||
|
|
||||||
If the entry already exists return False, if it inserted successfully
|
|
||||||
return True.
|
|
||||||
"""
|
"""
|
||||||
return IMPL.driver_initiator_data_insert_by_key(context,
|
return IMPL.driver_initiator_data_insert_by_key(context,
|
||||||
initiator,
|
initiator,
|
||||||
|
@ -8287,9 +8287,8 @@ def cleanup_expired_messages(context):
|
|||||||
###############################
|
###############################
|
||||||
|
|
||||||
|
|
||||||
# NOTE: We don't need a transaction context manager decorator since we're using
|
|
||||||
# the context manager directly inside
|
|
||||||
@require_context
|
@require_context
|
||||||
|
@main_context_manager.writer
|
||||||
def driver_initiator_data_insert_by_key(
|
def driver_initiator_data_insert_by_key(
|
||||||
context,
|
context,
|
||||||
initiator,
|
initiator,
|
||||||
@ -8303,14 +8302,14 @@ def driver_initiator_data_insert_by_key(
|
|||||||
data.key = key
|
data.key = key
|
||||||
data.value = value
|
data.value = value
|
||||||
try:
|
try:
|
||||||
# NOTE: We use a context manager since the decorator pattern requires
|
|
||||||
# we raise an exception or succeed, while we want to return a boolean.
|
|
||||||
# The context manager allows us to do manual cleanup here.
|
|
||||||
with main_context_manager.writer.savepoint.using(context):
|
|
||||||
data.save(context.session)
|
data.save(context.session)
|
||||||
return True
|
|
||||||
except db_exc.DBDuplicateEntry:
|
except db_exc.DBDuplicateEntry:
|
||||||
return False
|
raise exception.DriverInitiatorDataExists(
|
||||||
|
initiator=initiator,
|
||||||
|
namespace=namespace,
|
||||||
|
key=key,
|
||||||
|
)
|
||||||
|
return data
|
||||||
|
|
||||||
|
|
||||||
@require_context
|
@require_context
|
||||||
|
@ -1085,3 +1085,10 @@ class CinderAcceleratorError(CinderException):
|
|||||||
class SnapshotLimitReached(CinderException):
|
class SnapshotLimitReached(CinderException):
|
||||||
message = _("Exceeded the configured limit of "
|
message = _("Exceeded the configured limit of "
|
||||||
"%(set_limit)s snapshots per volume.")
|
"%(set_limit)s snapshots per volume.")
|
||||||
|
|
||||||
|
|
||||||
|
class DriverInitiatorDataExists(Duplicate):
|
||||||
|
message = _(
|
||||||
|
"Driver initiator data for initiator '%(initiator)s' and backend "
|
||||||
|
"'%(namespace)s' with key '%(key)s' already exists."
|
||||||
|
)
|
||||||
|
@ -3354,22 +3354,35 @@ class DBAPIDriverInitiatorDataTestCase(BaseTest):
|
|||||||
initiator = 'iqn.1993-08.org.debian:01:222'
|
initiator = 'iqn.1993-08.org.debian:01:222'
|
||||||
namespace = 'test_ns'
|
namespace = 'test_ns'
|
||||||
|
|
||||||
def _test_insert(self, key, value, expected_result=True):
|
def test_insert(self):
|
||||||
result = db.driver_initiator_data_insert_by_key(
|
key = 'key1'
|
||||||
self.ctxt, self.initiator, self.namespace, key, value)
|
value = 'foo'
|
||||||
self.assertEqual(expected_result, result)
|
|
||||||
|
|
||||||
data = db.driver_initiator_data_get(self.ctxt, self.initiator,
|
db.driver_initiator_data_insert_by_key(
|
||||||
self.namespace)
|
self.ctxt, self.initiator, self.namespace, key, value,
|
||||||
|
)
|
||||||
|
data = db.driver_initiator_data_get(
|
||||||
|
self.ctxt, self.initiator, self.namespace,
|
||||||
|
)
|
||||||
self.assertEqual(data[0].key, key)
|
self.assertEqual(data[0].key, key)
|
||||||
self.assertEqual(data[0].value, value)
|
self.assertEqual(data[0].value, value)
|
||||||
|
|
||||||
def test_insert(self):
|
|
||||||
self._test_insert('key1', 'foo')
|
|
||||||
|
|
||||||
def test_insert_already_exists(self):
|
def test_insert_already_exists(self):
|
||||||
self._test_insert('key2', 'bar')
|
key = 'key1'
|
||||||
self._test_insert('key2', 'bar', expected_result=False)
|
value = 'foo'
|
||||||
|
|
||||||
|
db.driver_initiator_data_insert_by_key(
|
||||||
|
self.ctxt, self.initiator, self.namespace, key, value,
|
||||||
|
)
|
||||||
|
self.assertRaises(
|
||||||
|
exception.DriverInitiatorDataExists,
|
||||||
|
db.driver_initiator_data_insert_by_key,
|
||||||
|
self.ctxt,
|
||||||
|
self.initiator,
|
||||||
|
self.namespace,
|
||||||
|
key,
|
||||||
|
value,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
@ddt.ddt
|
@ddt.ddt
|
||||||
|
@ -54,13 +54,16 @@ class VolumeDriverUtils(object):
|
|||||||
if saved successfully return True.
|
if saved successfully return True.
|
||||||
"""
|
"""
|
||||||
try:
|
try:
|
||||||
return self._db.driver_initiator_data_insert_by_key(
|
self._db.driver_initiator_data_insert_by_key(
|
||||||
self._get_context(ctxt),
|
self._get_context(ctxt),
|
||||||
initiator,
|
initiator,
|
||||||
self._data_namespace,
|
self._data_namespace,
|
||||||
key,
|
key,
|
||||||
value
|
value
|
||||||
)
|
)
|
||||||
|
return True
|
||||||
|
except exception.DriverInitiatorDataExists:
|
||||||
|
return False
|
||||||
except exception.CinderException:
|
except exception.CinderException:
|
||||||
LOG.exception("Failed to insert initiator data for"
|
LOG.exception("Failed to insert initiator data for"
|
||||||
" initiator %(initiator)s and backend"
|
" initiator %(initiator)s and backend"
|
||||||
|
Loading…
Reference in New Issue
Block a user