Extend cluster events

This patch extends adds a new field 'instance_ids' in payloads of two
cluster events:
     - DBaaSClusterShrink (during start and end notification),
     - DBaaSClusterGrow (during end notification).

Moreover, additional end notifications after growing and shrinking
cluster have been added.

The purpose of this change if to enable better integration with
tools for monitoring resources usage.

Change-Id: I2c39b2c3bff65f88e46944eda22209bdc92803bc
Signed-off-by: Kasper Hasior <k.hasior@samsung.com>
Co-Authored-By: Kasper Hasior <k.hasior@samsung.com>
Story: #2005520
Task: #30639
This commit is contained in:
Bartosz Zurkowski 2019-04-29 12:45:10 +02:00 committed by Lingxian Kong
parent d5d84653cf
commit 59e8cb7e75
5 changed files with 64 additions and 6 deletions

View File

@ -0,0 +1,8 @@
---
features:
- Adds new fields "instance_ids", which is supposed to contain ids of
cluster instances, in payloads of two cluster events -
DBaaSClusterShrink and DBaaSClusterGrow. Moreover, additional end
notifications after growing and shrinking cluster have been added.
It allows better integration with tools for monitoring resources
usage.

View File

@ -331,7 +331,9 @@ class Cluster(object):
return self.grow(instances) return self.grow(instances)
elif action == 'shrink': elif action == 'shrink':
context.notification = DBaaSClusterShrink(context, request=req) context.notification = DBaaSClusterShrink(context, request=req)
with StartNotification(context, cluster_id=self.id): instance_ids = [instance['id'] for instance in param]
with StartNotification(context, cluster_id=self.id,
instance_ids=instance_ids):
instance_ids = [instance['id'] for instance in param] instance_ids = [instance['id'] for instance in param]
return self.shrink(instance_ids) return self.shrink(instance_ids)
elif action == "reset-status": elif action == "reset-status":

View File

@ -649,6 +649,10 @@ class DBaaSClusterGrow(DBaaSAPINotification):
def required_start_traits(self): def required_start_traits(self):
return ['cluster_id'] return ['cluster_id']
@abc.abstractmethod
def required_end_traits(self):
return ['cluster_id']
class DBaaSClusterShrink(DBaaSAPINotification): class DBaaSClusterShrink(DBaaSAPINotification):
@ -660,6 +664,10 @@ class DBaaSClusterShrink(DBaaSAPINotification):
def required_start_traits(self): def required_start_traits(self):
return ['cluster_id'] return ['cluster_id']
@abc.abstractmethod
def required_end_traits(self):
return ['cluster_id']
class DBaaSBackupCreate(DBaaSAPINotification): class DBaaSBackupCreate(DBaaSAPINotification):

View File

@ -428,10 +428,14 @@ class Manager(periodic_task.PeriodicTasks):
cluster_tasks.create_cluster(context, cluster_id) cluster_tasks.create_cluster(context, cluster_id)
def grow_cluster(self, context, cluster_id, new_instance_ids): def grow_cluster(self, context, cluster_id, new_instance_ids):
with EndNotification(context, cluster_id=cluster_id,
instance_ids=new_instance_ids):
cluster_tasks = models.load_cluster_tasks(context, cluster_id) cluster_tasks = models.load_cluster_tasks(context, cluster_id)
cluster_tasks.grow_cluster(context, cluster_id, new_instance_ids) cluster_tasks.grow_cluster(context, cluster_id, new_instance_ids)
def shrink_cluster(self, context, cluster_id, instance_ids): def shrink_cluster(self, context, cluster_id, instance_ids):
with EndNotification(context, cluster_id=cluster_id,
instance_ids=instance_ids):
cluster_tasks = models.load_cluster_tasks(context, cluster_id) cluster_tasks = models.load_cluster_tasks(context, cluster_id)
cluster_tasks.shrink_cluster(context, cluster_id, instance_ids) cluster_tasks.shrink_cluster(context, cluster_id, instance_ids)

View File

@ -14,7 +14,7 @@
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
from mock import Mock, patch, PropertyMock from mock import MagicMock, Mock, patch, PropertyMock
from proboscis.asserts import assert_equal from proboscis.asserts import assert_equal
from trove.backup.models import Backup from trove.backup.models import Backup
@ -274,6 +274,42 @@ class TestManager(trove_testtools.TestCase):
mock_tasks.delete_cluster.assert_called_with(self.context, mock_tasks.delete_cluster.assert_called_with(self.context,
'some-cluster-id') 'some-cluster-id')
def test_shrink_cluster_with_success(self):
self._assert_shrink_cluster(True)
def test_shrink_cluster_with_error(self):
self._assert_shrink_cluster(False)
@patch('trove.taskmanager.manager.EndNotification')
@patch('trove.taskmanager.manager.models.load_cluster_tasks')
def _assert_shrink_cluster(self, success, mock_load, mock_notification):
if success:
mock_load.side_effect = Mock()
else:
mock_load.side_effect = Exception
end_notification = MagicMock()
mock_notification.return_value = end_notification
context = Mock()
cluster_id = Mock()
instance_ids = Mock()
try:
self.manager.shrink_cluster(context, cluster_id, instance_ids)
self.assertTrue(success)
except Exception:
self.assertFalse(success)
mock_load.assert_called_once_with(context, cluster_id)
mock_notification.assert_called_once_with(context,
cluster_id=cluster_id,
instance_ids=instance_ids)
exit_error_type = end_notification.__exit__.call_args_list[0][0][0]
if success:
self.assertFalse(exit_error_type)
else:
self.assertTrue(exit_error_type)
class TestTaskManagerService(trove_testtools.TestCase): class TestTaskManagerService(trove_testtools.TestCase):
def test_app_factory(self): def test_app_factory(self):