Merge "Fix pool creation with single LB create call" into stable/xena

This commit is contained in:
Zuul 2023-06-28 00:07:34 +00:00 committed by Gerrit Code Review
commit f395d378eb
9 changed files with 58 additions and 43 deletions

View File

@ -85,12 +85,17 @@ class LoadBalancerFlows(object):
post_amp_prefix = constants.POST_LB_AMP_ASSOCIATION_SUBFLOW post_amp_prefix = constants.POST_LB_AMP_ASSOCIATION_SUBFLOW
lb_create_flow.add( lb_create_flow.add(
self.get_post_lb_amp_association_flow( self.get_post_lb_amp_association_flow(post_amp_prefix, topology))
post_amp_prefix, topology, mark_active=(not listeners)))
if listeners: if listeners:
lb_create_flow.add(*self._create_listeners_flow()) lb_create_flow.add(*self._create_listeners_flow())
lb_create_flow.add(
database_tasks.MarkLBActiveInDB(
mark_subobjects=True,
requires=constants.LOADBALANCER
)
)
return lb_create_flow return lb_create_flow
def _create_single_topology(self): def _create_single_topology(self):
@ -220,16 +225,9 @@ class LoadBalancerFlows(object):
flows.append( flows.append(
self.listener_flows.get_create_all_listeners_flow() self.listener_flows.get_create_all_listeners_flow()
) )
flows.append(
database_tasks.MarkLBActiveInDB(
mark_subobjects=True,
requires=constants.LOADBALANCER
)
)
return flows return flows
def get_post_lb_amp_association_flow(self, prefix, topology, def get_post_lb_amp_association_flow(self, prefix, topology):
mark_active=True):
"""Reload the loadbalancer and create networking subflows for """Reload the loadbalancer and create networking subflows for
created/allocated amphorae. created/allocated amphorae.
@ -253,10 +251,6 @@ class LoadBalancerFlows(object):
post_create_LB_flow.add(database_tasks.UpdateLoadbalancerInDB( post_create_LB_flow.add(database_tasks.UpdateLoadbalancerInDB(
requires=[constants.LOADBALANCER, constants.UPDATE_DICT])) requires=[constants.LOADBALANCER, constants.UPDATE_DICT]))
if mark_active:
post_create_LB_flow.add(database_tasks.MarkLBActiveInDB(
name=sf_name + '-' + constants.MARK_LB_ACTIVE_INDB,
requires=constants.LOADBALANCER))
return post_create_LB_flow return post_create_LB_flow
def _get_delete_listeners_flow(self, lb): def _get_delete_listeners_flow(self, lb):

View File

@ -926,6 +926,8 @@ class MarkLBActiveInDB(BaseDatabaseTask):
loadbalancer.id) loadbalancer.id)
for listener in loadbalancer.listeners: for listener in loadbalancer.listeners:
self._mark_listener_status(listener, constants.ACTIVE) self._mark_listener_status(listener, constants.ACTIVE)
for pool in loadbalancer.pools:
self._mark_pool_status(pool, constants.ACTIVE)
LOG.info("Mark ACTIVE in DB for load balancer id: %s", LOG.info("Mark ACTIVE in DB for load balancer id: %s",
loadbalancer.id) loadbalancer.id)
@ -1000,14 +1002,20 @@ class MarkLBActiveInDB(BaseDatabaseTask):
""" """
if self.mark_subobjects: if self.mark_subobjects:
LOG.debug("Marking all listeners of loadbalancer %s ERROR", LOG.debug("Marking all listeners and pools of loadbalancer %s"
loadbalancer.id) " ERROR", loadbalancer.id)
for listener in loadbalancer.listeners: for listener in loadbalancer.listeners:
try: try:
self._mark_listener_status(listener, constants.ERROR) self._mark_listener_status(listener, constants.ERROR)
except Exception: except Exception:
LOG.warning("Error updating listener %s provisioning " LOG.warning("Error updating listener %s provisioning "
"status", listener.id) "status", listener.id)
for pool in loadbalancer.pools:
try:
self._mark_pool_status(pool, constants.ERROR)
except Exception:
LOG.warning("Error updating pool %s provisioning "
"status", pool.id)
class UpdateLBServerGroupInDB(BaseDatabaseTask): class UpdateLBServerGroupInDB(BaseDatabaseTask):

View File

@ -87,12 +87,18 @@ class LoadBalancerFlows(object):
post_amp_prefix = constants.POST_LB_AMP_ASSOCIATION_SUBFLOW post_amp_prefix = constants.POST_LB_AMP_ASSOCIATION_SUBFLOW
lb_create_flow.add( lb_create_flow.add(
self.get_post_lb_amp_association_flow( self.get_post_lb_amp_association_flow(post_amp_prefix, topology))
post_amp_prefix, topology, mark_active=(not listeners)))
if listeners: if listeners:
lb_create_flow.add(*self._create_listeners_flow()) lb_create_flow.add(*self._create_listeners_flow())
lb_create_flow.add(
database_tasks.MarkLBActiveInDB(
mark_subobjects=True,
requires=constants.LOADBALANCER
)
)
return lb_create_flow return lb_create_flow
def _create_single_topology(self): def _create_single_topology(self):
@ -214,16 +220,9 @@ class LoadBalancerFlows(object):
flows.append( flows.append(
self.listener_flows.get_create_all_listeners_flow() self.listener_flows.get_create_all_listeners_flow()
) )
flows.append(
database_tasks.MarkLBActiveInDB(
mark_subobjects=True,
requires=constants.LOADBALANCER
)
)
return flows return flows
def get_post_lb_amp_association_flow(self, prefix, topology, def get_post_lb_amp_association_flow(self, prefix, topology):
mark_active=True):
"""Reload the loadbalancer and create networking subflows for """Reload the loadbalancer and create networking subflows for
created/allocated amphorae. created/allocated amphorae.
@ -246,10 +245,6 @@ class LoadBalancerFlows(object):
post_create_LB_flow.add(database_tasks.UpdateLoadbalancerInDB( post_create_LB_flow.add(database_tasks.UpdateLoadbalancerInDB(
requires=[constants.LOADBALANCER, constants.UPDATE_DICT])) requires=[constants.LOADBALANCER, constants.UPDATE_DICT]))
if mark_active:
post_create_LB_flow.add(database_tasks.MarkLBActiveInDB(
name=sf_name + '-' + constants.MARK_LB_ACTIVE_INDB,
requires=constants.LOADBALANCER))
return post_create_LB_flow return post_create_LB_flow
def _get_delete_listeners_flow(self, listeners): def _get_delete_listeners_flow(self, listeners):

View File

@ -1000,6 +1000,8 @@ class MarkLBActiveInDB(BaseDatabaseTask):
id=loadbalancer[constants.LOADBALANCER_ID]) id=loadbalancer[constants.LOADBALANCER_ID])
for listener in db_lb.listeners: for listener in db_lb.listeners:
self._mark_listener_status(listener, constants.ACTIVE) self._mark_listener_status(listener, constants.ACTIVE)
for pool in db_lb.pools:
self._mark_pool_status(pool, constants.ACTIVE)
LOG.info("Mark ACTIVE in DB for load balancer id: %s", LOG.info("Mark ACTIVE in DB for load balancer id: %s",
loadbalancer[constants.LOADBALANCER_ID]) loadbalancer[constants.LOADBALANCER_ID])
@ -1074,8 +1076,8 @@ class MarkLBActiveInDB(BaseDatabaseTask):
""" """
if self.mark_subobjects: if self.mark_subobjects:
LOG.debug("Marking all listeners of loadbalancer %s ERROR", LOG.debug("Marking all listeners and pools of loadbalancer %s"
loadbalancer[constants.LOADBALANCER_ID]) " ERROR", loadbalancer[constants.LOADBALANCER_ID])
db_lb = self.loadbalancer_repo.get( db_lb = self.loadbalancer_repo.get(
db_apis.get_session(), db_apis.get_session(),
id=loadbalancer[constants.LOADBALANCER_ID]) id=loadbalancer[constants.LOADBALANCER_ID])
@ -1085,6 +1087,12 @@ class MarkLBActiveInDB(BaseDatabaseTask):
except Exception: except Exception:
LOG.warning("Error updating listener %s provisioning " LOG.warning("Error updating listener %s provisioning "
"status", listener.id) "status", listener.id)
for pool in db_lb.pools:
try:
self._mark_pool_status(pool, constants.ERROR)
except Exception:
LOG.warning("Error updating POOL %s provisioning "
"status", pool.id)
class MarkLBActiveInDBByListener(BaseDatabaseTask): class MarkLBActiveInDBByListener(BaseDatabaseTask):

View File

@ -160,7 +160,6 @@ class TestLoadBalancerFlows(base.TestCase):
self.assertEqual(4, len(amp_flow.provides)) self.assertEqual(4, len(amp_flow.provides))
self.assertEqual(2, len(amp_flow.requires)) self.assertEqual(2, len(amp_flow.requires))
# Test mark_active=False
amp_flow = self.LBFlow.get_post_lb_amp_association_flow( amp_flow = self.LBFlow.get_post_lb_amp_association_flow(
'123', constants.TOPOLOGY_ACTIVE_STANDBY) '123', constants.TOPOLOGY_ACTIVE_STANDBY)

View File

@ -1139,13 +1139,15 @@ class TestDatabaseTasks(base.TestCase):
provisioning_status=constants.ACTIVE), provisioning_status=constants.ACTIVE),
mock.call('TEST', listeners[1].id, mock.call('TEST', listeners[1].id,
provisioning_status=constants.ACTIVE)]) provisioning_status=constants.ACTIVE)])
self.assertEqual(2, repo.PoolRepository.update.call_count) self.assertEqual(5, repo.PoolRepository.update.call_count)
repo.PoolRepository.update.has_calls( repo.PoolRepository.update.assert_has_calls(
[mock.call('TEST', default_pool.id, [mock.call('TEST', default_pool.id,
provisioning_status=constants.ACTIVE), provisioning_status=constants.ACTIVE),
mock.call('TEST', redirect_pool.id, mock.call('TEST', redirect_pool.id,
provisioning_status=constants.ACTIVE),
mock.call('TEST', unused_pool.id,
provisioning_status=constants.ACTIVE)]) provisioning_status=constants.ACTIVE)])
self.assertEqual(4, repo.MemberRepository.update.call_count) self.assertEqual(8, repo.MemberRepository.update.call_count)
repo.MemberRepository.update.has_calls( repo.MemberRepository.update.has_calls(
[mock.call('TEST', members1[0].id, [mock.call('TEST', members1[0].id,
provisioning_status=constants.ACTIVE), provisioning_status=constants.ACTIVE),
@ -1155,7 +1157,7 @@ class TestDatabaseTasks(base.TestCase):
provisioning_status=constants.ACTIVE), provisioning_status=constants.ACTIVE),
mock.call('TEST', members2[1].id, mock.call('TEST', members2[1].id,
provisioning_status=constants.ACTIVE)]) provisioning_status=constants.ACTIVE)])
self.assertEqual(1, repo.HealthMonitorRepository.update.call_count) self.assertEqual(2, repo.HealthMonitorRepository.update.call_count)
repo.HealthMonitorRepository.update.has_calls( repo.HealthMonitorRepository.update.has_calls(
[mock.call('TEST', health_monitor.id, [mock.call('TEST', health_monitor.id,
provisioning_status=constants.ACTIVE)]) provisioning_status=constants.ACTIVE)])
@ -1184,13 +1186,13 @@ class TestDatabaseTasks(base.TestCase):
provisioning_status=constants.ERROR), provisioning_status=constants.ERROR),
mock.call('TEST', listeners[1].id, mock.call('TEST', listeners[1].id,
provisioning_status=constants.ERROR)]) provisioning_status=constants.ERROR)])
self.assertEqual(2, repo.PoolRepository.update.call_count) self.assertEqual(5, repo.PoolRepository.update.call_count)
repo.PoolRepository.update.has_calls( repo.PoolRepository.update.has_calls(
[mock.call('TEST', default_pool.id, [mock.call('TEST', default_pool.id,
provisioning_status=constants.ERROR), provisioning_status=constants.ERROR),
mock.call('TEST', redirect_pool.id, mock.call('TEST', redirect_pool.id,
provisioning_status=constants.ERROR)]) provisioning_status=constants.ERROR)])
self.assertEqual(4, repo.MemberRepository.update.call_count) self.assertEqual(8, repo.MemberRepository.update.call_count)
repo.MemberRepository.update.has_calls( repo.MemberRepository.update.has_calls(
[mock.call('TEST', members1[0].id, [mock.call('TEST', members1[0].id,
provisioning_status=constants.ERROR), provisioning_status=constants.ERROR),
@ -1200,7 +1202,7 @@ class TestDatabaseTasks(base.TestCase):
provisioning_status=constants.ERROR), provisioning_status=constants.ERROR),
mock.call('TEST', members2[1].id, mock.call('TEST', members2[1].id,
provisioning_status=constants.ERROR)]) provisioning_status=constants.ERROR)])
self.assertEqual(1, repo.HealthMonitorRepository.update.call_count) self.assertEqual(2, repo.HealthMonitorRepository.update.call_count)
repo.HealthMonitorRepository.update.has_calls( repo.HealthMonitorRepository.update.has_calls(
[mock.call('TEST', health_monitor.id, [mock.call('TEST', health_monitor.id,
provisioning_status=constants.ERROR)]) provisioning_status=constants.ERROR)])

View File

@ -183,7 +183,6 @@ class TestLoadBalancerFlows(base.TestCase):
self.assertEqual(2, len(amp_flow.requires), amp_flow.requires) self.assertEqual(2, len(amp_flow.requires), amp_flow.requires)
self.assertEqual(4, len(amp_flow.provides), amp_flow.provides) self.assertEqual(4, len(amp_flow.provides), amp_flow.provides)
# Test mark_active=False
amp_flow = self.LBFlow.get_post_lb_amp_association_flow( amp_flow = self.LBFlow.get_post_lb_amp_association_flow(
'123', constants.TOPOLOGY_ACTIVE_STANDBY) '123', constants.TOPOLOGY_ACTIVE_STANDBY)

View File

@ -1274,6 +1274,8 @@ class TestDatabaseTasks(base.TestCase):
[mock.call('TEST', default_pool.id, [mock.call('TEST', default_pool.id,
provisioning_status=constants.ACTIVE), provisioning_status=constants.ACTIVE),
mock.call('TEST', redirect_pool.id, mock.call('TEST', redirect_pool.id,
provisioning_status=constants.ACTIVE),
mock.call('TEST', unused_pool.id,
provisioning_status=constants.ACTIVE)]) provisioning_status=constants.ACTIVE)])
repo.HealthMonitorRepository.update.has_calls( repo.HealthMonitorRepository.update.has_calls(
[mock.call('TEST', health_monitor.id, [mock.call('TEST', health_monitor.id,
@ -1306,8 +1308,11 @@ class TestDatabaseTasks(base.TestCase):
[mock.call('TEST', default_pool.id, [mock.call('TEST', default_pool.id,
provisioning_status=constants.ERROR), provisioning_status=constants.ERROR),
mock.call('TEST', redirect_pool.id, mock.call('TEST', redirect_pool.id,
provisioning_status=constants.ERROR)]) provisioning_status=constants.ERROR),
self.assertEqual(1, repo.HealthMonitorRepository.update.call_count) mock.call('TEST', unused_pool.id,
provisioning_status=constants.ERROR)
])
self.assertEqual(2, repo.HealthMonitorRepository.update.call_count)
repo.HealthMonitorRepository.update.has_calls( repo.HealthMonitorRepository.update.has_calls(
[mock.call('TEST', health_monitor.id, [mock.call('TEST', health_monitor.id,
provisioning_status=constants.ERROR)]) provisioning_status=constants.ERROR)])

View File

@ -0,0 +1,5 @@
---
fixes:
- |
Fixed a bug that didn't set the correct provisioning_status for unattached
pools when creating a fully-populated load balancer.