Merge "Delete share network subnet during network deletion"

This commit is contained in:
Zuul 2023-10-24 23:45:16 +00:00 committed by Gerrit Code Review
commit c6548e30a0
3 changed files with 27 additions and 0 deletions

View File

@ -4679,6 +4679,8 @@ def share_network_create(context, values):
@context_manager.writer @context_manager.writer
def share_network_delete(context, id): def share_network_delete(context, id):
network_ref = _share_network_get(context, id) network_ref = _share_network_get(context, id)
for subnet in network_ref['share_network_subnets']:
share_network_subnet_delete(context, subnet['id'])
network_ref.soft_delete(session=context.session) network_ref.soft_delete(session=context.session)

View File

@ -2738,6 +2738,24 @@ class ShareNetworkDatabaseAPITestCase(BaseDatabaseAPITestCase):
self.fake_context, self.fake_context,
self.share_nw_dict['id']) self.share_nw_dict['id'])
@ddt.data([{'id': 'fake_id_1', 'availability_zone_id': 'None'}],
[{'id': 'fake_id_2', 'availability_zone_id': 'None'},
{'id': 'fake_id_3', 'availability_zone_id': 'fake_az_id'}])
def test_delete_with_subnets(self, subnets):
db_api.share_network_create(self.fake_context, self.share_nw_dict)
for subnet in subnets:
subnet['share_network_id'] = self.share_nw_dict['id']
db_api.share_network_subnet_create(self.fake_context, subnet)
db_api.share_network_delete(self.fake_context,
self.share_nw_dict['id'])
self.assertRaises(exception.ShareNetworkSubnetNotFound,
db_api.share_network_subnet_get,
self.fake_context,
subnets[0]['id'])
def test_delete_not_found(self): def test_delete_not_found(self):
self.assertRaises(exception.ShareNetworkNotFound, self.assertRaises(exception.ShareNetworkNotFound,
db_api.share_network_delete, db_api.share_network_delete,

View File

@ -0,0 +1,7 @@
---
fixes:
- |
Now, default share network subnet is deleted when share network is deleted,
in case it is the only subnet present in share network. Please refer to the
`Launchpad bug #2037422 <https://bugs.launchpad.net/manila/+bug/2037422>`_
for more details.