From abf6d356b3162b63c239325761f949b3f87725e4 Mon Sep 17 00:00:00 2001 From: Ruby Loo Date: Tue, 18 Jul 2017 09:45:24 -0400 Subject: [PATCH] Rename 'remove_unavail_fields' parameter Renames the parameter 'remove_unavail_fields' to 'remove_unavailable_fields'. This is a follow up to 8e7d795db5e614de6a3d8dd19ff26f869c8e9f9a. Change-Id: I57f7bde85e959f3edeb878089057bfcd26672570 Partial-Bug: #1526283 --- ironic/objects/base.py | 41 +++++++++++++---------- ironic/tests/unit/objects/test_objects.py | 15 +++++---- 2 files changed, 31 insertions(+), 25 deletions(-) diff --git a/ironic/objects/base.py b/ironic/objects/base.py index 78dfedde98..a51b12c471 100644 --- a/ironic/objects/base.py +++ b/ironic/objects/base.py @@ -80,7 +80,8 @@ class IronicObject(object_base.VersionedObject): self[field] != loaded_object[field]): self[field] = loaded_object[field] - def _convert_to_version(self, target_version, remove_unavail_fields=True): + def _convert_to_version(self, target_version, + remove_unavailable_fields=True): """Convert to the target version. Subclasses should redefine this method, to do the conversion of the @@ -90,57 +91,61 @@ class IronicObject(object_base.VersionedObject): the same, older, or newer than the version of the object. This is used for DB interactions as well as for serialization/deserialization. - The remove_unavail_fields flag is used to distinguish these two cases: + The remove_unavailable_fields flag is used to distinguish these two + cases: 1) For serialization/deserialization, we need to remove the unavailable fields, because the service receiving the object may not know about - these fields. remove_unavail_fields is set to True in this case. + these fields. remove_unavailable_fields is set to True in this case. 2) For DB interactions, we need to set the unavailable fields to their appropriate values so that these fields are saved in the DB. (If they are not set, the VersionedObject magic will not know to - save/update them to the DB.) remove_unavail_fields is set to False - in this case. + save/update them to the DB.) remove_unavailable_fields is set to + False in this case. :param target_version: the desired version of the object - :param remove_unavail_fields: True to remove fields that are + :param remove_unavailable_fields: True to remove fields that are unavailable in the target version; set this to True when (de)serializing. False to set the unavailable fields to appropriate values; set this to False for DB interactions. """ pass - def convert_to_version(self, target_version, remove_unavail_fields=True): + def convert_to_version(self, target_version, + remove_unavailable_fields=True): """Convert this object to the target version. Convert the object to the target version. The target version may be the same, older, or newer than the version of the object. This is used for DB interactions as well as for serialization/deserialization. - The remove_unavail_fields flag is used to distinguish these two cases: + The remove_unavailable_fields flag is used to distinguish these two + cases: 1) For serialization/deserialization, we need to remove the unavailable fields, because the service receiving the object may not know about - these fields. remove_unavail_fields is set to True in this case. + these fields. remove_unavailable_fields is set to True in this case. 2) For DB interactions, we need to set the unavailable fields to their appropriate values so that these fields are saved in the DB. (If they are not set, the VersionedObject magic will not know to - save/update them to the DB.) remove_unavail_fields is set to False - in this case. + save/update them to the DB.) remove_unavailable_fields is set to + False in this case. _convert_to_version() does the actual work. :param target_version: the desired version of the object - :param remove_unavail_fields: True to remove fields that are + :param remove_unavailable_fields: True to remove fields that are unavailable in the target version; set this to True when (de)serializing. False to set the unavailable fields to appropriate values; set this to False for DB interactions. """ if self.VERSION != target_version: self._convert_to_version( - target_version, remove_unavail_fields=remove_unavail_fields) - if remove_unavail_fields: + target_version, + remove_unavailable_fields=remove_unavailable_fields) + if remove_unavailable_fields: # NOTE(rloo): We changed the object, but don't keep track of # any of these changes, since it is inaccurate anyway (because # it doesn't keep track of any 'changed' unavailable fields). @@ -257,7 +262,7 @@ class IronicObject(object_base.VersionedObject): # convert to the latest version obj.VERSION = db_version obj.convert_to_version(obj.__class__.VERSION, - remove_unavail_fields=False) + remove_unavailable_fields=False) return obj @@ -302,7 +307,7 @@ class IronicObject(object_base.VersionedObject): if target_version != self.VERSION: # Convert the object so we can save it in the target version. self.convert_to_version(target_version, - remove_unavail_fields=False) + remove_unavailable_fields=False) changes = self.obj_get_changes() # NOTE(rloo): Since this object doesn't keep track of the version that @@ -350,7 +355,7 @@ class IronicObjectSerializer(object_base.VersionedObjectSerializer): # we don't want any changes obj.convert_to_version( obj.__class__.VERSION, - remove_unavail_fields=not self.is_server) + remove_unavailable_fields=not self.is_server) return obj def serialize_entity(self, context, entity): @@ -385,7 +390,7 @@ class IronicObjectSerializer(object_base.VersionedObjectSerializer): # older object version. We need to backport/convert to target # version before serialization. entity.convert_to_version(target_version, - remove_unavail_fields=True) + remove_unavailable_fields=True) return super(IronicObjectSerializer, self).serialize_entity( context, entity) diff --git a/ironic/tests/unit/objects/test_objects.py b/ironic/tests/unit/objects/test_objects.py index b4892b0163..c1fdec285a 100644 --- a/ironic/tests/unit/objects/test_objects.py +++ b/ironic/tests/unit/objects/test_objects.py @@ -90,11 +90,12 @@ class MyObj(base.IronicObject, object_base.VersionedObjectDictCompat): self.save() self.foo = 42 - def _convert_to_version(self, target_version, remove_unavail_fields=True): + def _convert_to_version(self, target_version, + remove_unavailable_fields=True): if target_version == '1.5': self.missing = 'foo' elif self.missing: - if remove_unavail_fields: + if remove_unavailable_fields: delattr(self, 'missing') else: self.missing = '' @@ -387,7 +388,7 @@ class _TestObject(object): # no changes obj = MyObj(self.context) self.assertEqual('1.5', obj.VERSION) - obj.convert_to_version('1.5', remove_unavail_fields=False) + obj.convert_to_version('1.5', remove_unavailable_fields=False) self.assertEqual('1.5', obj.VERSION) self.assertEqual(obj.__class__.VERSION, obj.VERSION) self.assertEqual({}, obj.obj_get_changes()) @@ -395,7 +396,7 @@ class _TestObject(object): def test_convert_to_version_new(self): obj = MyObj(self.context) obj.VERSION = '1.4' - obj.convert_to_version('1.5', remove_unavail_fields=False) + obj.convert_to_version('1.5', remove_unavailable_fields=False) self.assertEqual('1.5', obj.VERSION) self.assertEqual(obj.__class__.VERSION, obj.VERSION) self.assertEqual({'missing': 'foo'}, obj.obj_get_changes()) @@ -404,7 +405,7 @@ class _TestObject(object): obj = MyObj(self.context) obj.missing = 'something' obj.obj_reset_changes() - obj.convert_to_version('1.4', remove_unavail_fields=True) + obj.convert_to_version('1.4', remove_unavailable_fields=True) self.assertEqual('1.4', obj.VERSION) self.assertEqual({}, obj.obj_get_changes()) @@ -412,7 +413,7 @@ class _TestObject(object): obj = MyObj(self.context) obj.missing = 'something' obj.obj_reset_changes() - obj.convert_to_version('1.4', remove_unavail_fields=False) + obj.convert_to_version('1.4', remove_unavailable_fields=False) self.assertEqual('1.4', obj.VERSION) self.assertEqual({'missing': ''}, obj.obj_get_changes()) @@ -945,7 +946,7 @@ class TestObjectSerializer(test_base.TestCase): serializer = base.IronicObjectSerializer(is_server=is_server) serializer._process_object(self.context, primitive) mock_convert.assert_called_once_with( - mock.ANY, '1.5', remove_unavail_fields=not is_server) + mock.ANY, '1.5', remove_unavailable_fields=not is_server) def test__process_object_convert_api(self): self._test__process_object_convert(False)