Adds regression test for bug LP#2085135
Related-Bug: #2085135 Change-Id: Id50413e2cff19bc3e510506ad2d7703c86155f59 Signed-off-by: Julien Le Jeune <julien.le-jeune@ovhcloud.com> (cherry picked from commit4073297ae3) (cherry picked from commitfb2706a8ba) (cherry picked from commit2674b64ba7)
This commit is contained in:
75
nova/tests/functional/regressions/test_bug_2085135.py
Normal file
75
nova/tests/functional/regressions/test_bug_2085135.py
Normal file
@@ -0,0 +1,75 @@
|
|||||||
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
# not use this file except in compliance with the License. You may obtain
|
||||||
|
# a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
# License for the specific language governing permissions and limitations
|
||||||
|
# under the License.
|
||||||
|
|
||||||
|
from nova import context
|
||||||
|
from nova.db.main import api as db
|
||||||
|
from nova import exception
|
||||||
|
from nova import objects
|
||||||
|
from nova.objects import host_mapping
|
||||||
|
from nova import test
|
||||||
|
from nova.tests import fixtures
|
||||||
|
from nova import utils
|
||||||
|
|
||||||
|
|
||||||
|
class HostMappingDiscoveryTestFail(test.TestCase):
|
||||||
|
"""Regression test for bug 2085135
|
||||||
|
"""
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
super().setUp()
|
||||||
|
self.ctxt = context.get_admin_context()
|
||||||
|
|
||||||
|
api_fixture = self.useFixture(fixtures.OSAPIFixture(
|
||||||
|
api_version='v2.1'))
|
||||||
|
self.admin_api = api_fixture.admin_api
|
||||||
|
self.admin_api.microversion = 'latest'
|
||||||
|
|
||||||
|
def test_discover_host_fail_after_service_deletion(self):
|
||||||
|
# Create compute
|
||||||
|
host_name = "compute-1"
|
||||||
|
service = self._start_compute(host_name)
|
||||||
|
|
||||||
|
# Store its node uuid
|
||||||
|
node_uuid = service.service_ref.compute_node.uuid
|
||||||
|
|
||||||
|
# Now delete its service
|
||||||
|
# It will delete the related compute node and host mapping
|
||||||
|
self.admin_api.api_delete(
|
||||||
|
'/os-services/%s' % service.service_ref.uuid)
|
||||||
|
# Check its deletion
|
||||||
|
self.assertRaises(exception.HostBinaryNotFound,
|
||||||
|
db.service_get_by_host_and_binary,
|
||||||
|
self.ctxt, host_name, 'nova-compute')
|
||||||
|
|
||||||
|
# Check that compute node and its mappings have correctly been deleted
|
||||||
|
with utils.temporary_mutation(self.ctxt, read_deleted='yes'):
|
||||||
|
node = db.compute_node_get_by_nodename(self.ctxt, host_name)
|
||||||
|
self.assertEqual(node['deleted'], node['id'])
|
||||||
|
self.assertRaises(exception.HostMappingNotFound,
|
||||||
|
objects.HostMapping.get_by_host,
|
||||||
|
self.ctxt, host_name)
|
||||||
|
|
||||||
|
# Now recreate the service and compute node by updating its resources
|
||||||
|
# like if the services restarts
|
||||||
|
service.manager.update_available_resource(self.ctxt)
|
||||||
|
|
||||||
|
# At this point, service and compute come back to life
|
||||||
|
# with the same compute uuid
|
||||||
|
node = db.compute_node_get_by_nodename(self.ctxt, host_name)
|
||||||
|
self.assertEqual(node['deleted'], 0)
|
||||||
|
self.assertEqual(node['uuid'], node_uuid)
|
||||||
|
|
||||||
|
# Bug #2085135: node should be unmapped and be discoverable
|
||||||
|
self.assertEqual(node['mapped'], 1)
|
||||||
|
mappings = host_mapping.discover_hosts(
|
||||||
|
self.ctxt, status_fn=lambda m: None)
|
||||||
|
self.assertEqual(0, len(mappings))
|
||||||
Reference in New Issue
Block a user