[ovn] Avoid unwanted ACL_NOT_FOUND error when deleting log objects
There is the possibility that db_remove raises an error if an ACL was deleted on parallel for other reasons while deleting a log object. On a normal situation, this command would remove the no-longer-needed 'log-related' property, but since the ACL is no longer there, it will raise an error. For this case, it is not problematic to have an ACL deleted mid-operation, so it should not raise any error. Related-Bug: #2019887 Signed-off-by: Elvira García <egarciar@redhat.com> Change-Id: I154393529134b5861e0ef0283257ef964fe057fd
This commit is contained in:
parent
a517cb0e65
commit
e0a2427a2f
@ -142,7 +142,8 @@ class OVNDriver(base.DriverBase):
|
|||||||
if hasattr(acl, 'label'):
|
if hasattr(acl, 'label'):
|
||||||
columns['label'] = 0
|
columns['label'] = 0
|
||||||
ovn_txn.add(self.ovn_nb.db_remove(
|
ovn_txn.add(self.ovn_nb.db_remove(
|
||||||
"ACL", acl_uuid, 'options', 'log-related'))
|
"ACL", acl_uuid, 'options', 'log-related',
|
||||||
|
if_exists=True))
|
||||||
ovn_txn.add(self.ovn_nb.db_set(
|
ovn_txn.add(self.ovn_nb.db_set(
|
||||||
"ACL", acl_uuid, *columns.items()))
|
"ACL", acl_uuid, *columns.items()))
|
||||||
acl_changes += 1
|
acl_changes += 1
|
||||||
|
@ -27,6 +27,7 @@ from neutron.tests.unit import fake_resources
|
|||||||
|
|
||||||
FAKE_CFG_RATE = 123
|
FAKE_CFG_RATE = 123
|
||||||
FAKE_CFG_BURST = 321
|
FAKE_CFG_BURST = 321
|
||||||
|
FAKE_LABEL = 1
|
||||||
|
|
||||||
|
|
||||||
class TestOVNDriverBase(base.BaseTestCase):
|
class TestOVNDriverBase(base.BaseTestCase):
|
||||||
@ -113,6 +114,7 @@ class TestOVNDriver(TestOVNDriverBase):
|
|||||||
acl_defaults_dict = {
|
acl_defaults_dict = {
|
||||||
"name": [name] if name else [],
|
"name": [name] if name else [],
|
||||||
"action": ovn_const.ACL_ACTION_ALLOW_RELATED,
|
"action": ovn_const.ACL_ACTION_ALLOW_RELATED,
|
||||||
|
"label": FAKE_LABEL
|
||||||
}
|
}
|
||||||
self.__dict__ = {**acl_defaults_dict, **acl_dict}
|
self.__dict__ = {**acl_defaults_dict, **acl_dict}
|
||||||
|
|
||||||
@ -247,6 +249,19 @@ class TestOVNDriver(TestOVNDriverBase):
|
|||||||
self.assertEqual(len(pg_dict["acls"]) - 1,
|
self.assertEqual(len(pg_dict["acls"]) - 1,
|
||||||
self._nb_ovn.db_set.call_count)
|
self._nb_ovn.db_set.call_count)
|
||||||
|
|
||||||
|
# This test is enforcing the use of if_exists so that we don't get
|
||||||
|
# unexpected errors while doing parallel operations like erasing log
|
||||||
|
# objects and security groups
|
||||||
|
@mock.patch.object(ovn_driver.LOG, 'info')
|
||||||
|
def test__remove_acls_log_only_if_exists(self, m_info):
|
||||||
|
pg_dict = self._fake_pg_dict(acls=['acl1', 'acl2', 'acl3'])
|
||||||
|
|
||||||
|
def _only_if_exists(_pg_table, acl_uuid, col, val, if_exists):
|
||||||
|
self.assertTrue(if_exists)
|
||||||
|
|
||||||
|
self._nb_ovn.db_remove.side_effect = _only_if_exists
|
||||||
|
self._log_driver._remove_acls_log([pg_dict], self._nb_ovn.transaction)
|
||||||
|
|
||||||
@mock.patch.object(ovn_driver.LOG, 'info')
|
@mock.patch.object(ovn_driver.LOG, 'info')
|
||||||
def test__remove_acls_log_with_log_name(self, m_info):
|
def test__remove_acls_log_with_log_name(self, m_info):
|
||||||
pg_dict = self._fake_pg_dict(acls=['acl1', 'acl2', 'acl3', 'acl4'])
|
pg_dict = self._fake_pg_dict(acls=['acl1', 'acl2', 'acl3', 'acl4'])
|
||||||
|
Loading…
Reference in New Issue
Block a user