summaryrefslogtreecommitdiff
path: root/nova/tests/unit/objects/test_instance.py
diff options
context:
space:
mode:
authorZuul <zuul@review.opendev.org>2020-08-11 19:04:51 +0000
committerGerrit Code Review <review@openstack.org>2020-08-11 19:04:51 +0000
commit8f7dc3d8700a37956abf567d170ad42863baa4d7 (patch)
tree3f627dc82977cb180e9ec338e94719c23d43c651 /nova/tests/unit/objects/test_instance.py
parent3c76d999da1efb83ad4c003ec118a117c2cbb2f2 (diff)
parent6a7a78a44ea19497ea3e331ddd672f95cd49c50e (diff)
downloadnova-8f7dc3d8700a37956abf567d170ad42863baa4d7.tar.gz
Merge "objects: Update keypairs when saving an instance" into stable/queens
Diffstat (limited to 'nova/tests/unit/objects/test_instance.py')
-rw-r--r--nova/tests/unit/objects/test_instance.py24
1 files changed, 20 insertions, 4 deletions
diff --git a/nova/tests/unit/objects/test_instance.py b/nova/tests/unit/objects/test_instance.py
index 14798e36de..45d54f6201 100644
--- a/nova/tests/unit/objects/test_instance.py
+++ b/nova/tests/unit/objects/test_instance.py
@@ -683,14 +683,30 @@ class _TestInstanceObject(object):
inst.numa_topology = None
inst.migration_context = None
inst.vcpu_model = test_vcpu_model.fake_vcpumodel
- inst.save()
+ inst.keypairs = objects.KeyPairList(
+ objects=[objects.KeyPair(name='foo')])
+
json_vcpu_model = jsonutils.dumps(
test_vcpu_model.fake_vcpumodel.obj_to_primitive())
- expected_vals = {'numa_topology': None,
- 'migration_context': None,
- 'vcpu_model': json_vcpu_model}
+ json_keypairs = jsonutils.dumps(inst.keypairs.obj_to_primitive())
+
+ # Check changed fields in the instance object
+ self.assertIn('keypairs', inst.obj_what_changed())
+ self.assertEqual({'objects'}, inst.keypairs.obj_what_changed())
+
+ inst.save()
+
+ expected_vals = {
+ 'numa_topology': None,
+ 'migration_context': None,
+ 'vcpu_model': json_vcpu_model,
+ 'keypairs': json_keypairs,
+ }
mock_update.assert_called_once_with(self.context, inst.uuid,
expected_vals)
+ # Verify that the record of changed fields has been cleared
+ self.assertNotIn('keypairs', inst.obj_what_changed())
+ self.assertEqual(set(), inst.keypairs.obj_what_changed())
@mock.patch.object(notifications, 'send_update')
@mock.patch.object(cells_rpcapi.CellsAPI, 'instance_update_from_api')