summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--nova/compute/resource_tracker.py5
-rw-r--r--nova/tests/compute/test_resource_tracker.py9
2 files changed, 13 insertions, 1 deletions
diff --git a/nova/compute/resource_tracker.py b/nova/compute/resource_tracker.py
index 1c653b8ca..c784fd83d 100644
--- a/nova/compute/resource_tracker.py
+++ b/nova/compute/resource_tracker.py
@@ -503,7 +503,10 @@ class ResourceTracker(object):
resources['running_vms'] = 0
for instance in instances:
- self._update_usage_from_instance(resources, instance)
+ if instance['vm_state'] == vm_states.DELETED:
+ continue
+ else:
+ self._update_usage_from_instance(resources, instance)
def _find_orphaned_instances(self):
"""Given the set of instances and migrations already account for
diff --git a/nova/tests/compute/test_resource_tracker.py b/nova/tests/compute/test_resource_tracker.py
index 3f3962c8f..92edd34b5 100644
--- a/nova/tests/compute/test_resource_tracker.py
+++ b/nova/tests/compute/test_resource_tracker.py
@@ -601,6 +601,15 @@ class InstanceClaimTestCase(BaseTrackerTestCase):
self.tracker.update_usage(self.context, instance)
self.assertEqual(1, self.tracker.compute_node['vcpus_used'])
+ def test_skip_deleted_instances(self):
+ # ensure that the audit process skips instances that have vm_state
+ # DELETED, but the DB record is not yet deleted.
+ self._fake_instance(vm_state=vm_states.DELETED, host=self.host)
+ self.tracker.update_available_resource(self.context)
+
+ self.assertEqual(0, self.tracker.compute_node['memory_mb_used'])
+ self.assertEqual(0, self.tracker.compute_node['local_gb_used'])
+
class ResizeClaimTestCase(BaseTrackerTestCase):