From 0ac1227f692e412023ded40312da4540a60c8855 Mon Sep 17 00:00:00 2001 From: wangzh21 Date: Mon, 4 Jun 2018 19:20:55 +0800 Subject: [PATCH] Fix Deployable get_by_host 1.Fix get_by_host. 2.Add missing configs of placement. Change-Id: I4452371d02fface1adbc322cb75cc39e32062303 --- cyborg/conf/default.py | 8 ++++++++ cyborg/objects/deployable.py | 12 +++++++----- cyborg/tests/unit/objects/test_deployable.py | 17 +++++++++++++++++ .../unit/services/test_placement_client.py | 2 ++ 4 files changed, 34 insertions(+), 5 deletions(-) diff --git a/cyborg/conf/default.py b/cyborg/conf/default.py index e4033831..520e6daf 100644 --- a/cyborg/conf/default.py +++ b/cyborg/conf/default.py @@ -102,6 +102,14 @@ placement_opts = [ cfg.IntOpt('timeout', default=None, help=_('Timeout for inactive connections (in seconds)')), + cfg.BoolOpt('split_loggers', + default=False, + help=_('Split the logging of requests across multiple loggers ' + 'instead of just one. Defaults to False.')), + cfg.IntOpt('collect_timing', + default=False, + help=_('Whether or not to collect per-method timing information' + ' for each API call. (optional,defaults to False')), ] diff --git a/cyborg/objects/deployable.py b/cyborg/objects/deployable.py index 7746f9dd..645fc5df 100644 --- a/cyborg/objects/deployable.py +++ b/cyborg/objects/deployable.py @@ -97,11 +97,13 @@ class Deployable(base.CyborgObject, object_base.VersionedObjectDictCompat): def get_by_host(cls, context, host): """Get a Deployable by host.""" db_deps = cls.dbapi.deployable_get_by_host(context, host) - query = {"deployable_id": db_deps.id} - attr_get_list = Attribute.get_by_filter(context, - query) - db_deps.attributes_list = attr_get_list - return cls._from_db_object_list(db_deps, context) + obj_dpl_list = cls._from_db_object_list(db_deps, context) + for obj_dpl in obj_dpl_list: + query = {"deployable_id": obj_dpl.id} + attr_get_list = Attribute.get_by_filter(context, + query) + obj_dpl.attributes_list = attr_get_list + return obj_dpl_list @classmethod def list(cls, context): diff --git a/cyborg/tests/unit/objects/test_deployable.py b/cyborg/tests/unit/objects/test_deployable.py index 226ad8dc..89ee308f 100644 --- a/cyborg/tests/unit/objects/test_deployable.py +++ b/cyborg/tests/unit/objects/test_deployable.py @@ -278,6 +278,23 @@ class _TestDeployableObject(DbTestCase): self.assertEqual(len(dpl_get_list), 1) self.assertEqual(dpl_get_list[0].uuid, dpl2.uuid) + def test_get_by_host(self): + dep1 = self.fake_deployable + dep2 = self.fake_deployable2 + fake_hostname = 'host_name' + dep_obj1 = objects.Deployable(context=self.context, + **dep1) + dep_obj2 = objects.Deployable(context=self.context, + **dep2) + dep_obj1.create(self.context) + dep_obj2.create(self.context) + + dep_obj1.save(self.context) + dep_obj2.save(self.context) + dep_objs = objects.Deployable.get_by_host(self.context, fake_hostname) + self.assertEqual(dep_objs[0].host, fake_hostname) + self.assertEqual(dep_objs[1].host, fake_hostname) + class TestDeployableObject(test_objects._LocalTest, _TestDeployableObject): diff --git a/cyborg/tests/unit/services/test_placement_client.py b/cyborg/tests/unit/services/test_placement_client.py index 87084c56..27756f1e 100644 --- a/cyborg/tests/unit/services/test_placement_client.py +++ b/cyborg/tests/unit/services/test_placement_client.py @@ -42,6 +42,8 @@ class PlacementAPIClientTestCase(base.DietTestCase): load_auth_mock.assert_called_once_with(cfg.CONF, 'placement') ks_sess_mock.assert_called_once_with(auth=load_auth_mock.return_value, cert=None, + collect_timing=False, + split_loggers=False, timeout=None, verify=True)