Delete server after resize test
Explicitly deleting will prevent attempting to resize down an instance that was used for other resize tests. Every resize test will get its own server. Because there is now no potential to be resizing back and forth between flavor_ref and flavor_ref_alt we can do away with the code that tried to figure out what the direction should be. Resizes will now always be from flavor_ref to flavor_ref_alt, another protection against attempting to resize down. This does add extra work, deleting a server after each test and making a new one, however as it does away with resize direction ambiguity and happy accidental successes the performance hit is worth it. Change-Id: I7ba85c94d40927f31e1e07b9940e5a4ed1a7577f Closes-Bug: #1450648
This commit is contained in:
parent
5b6b824739
commit
613b498ca9
@ -333,6 +333,15 @@ class BaseComputeTest(tempest.test.BaseTestCase):
|
|||||||
cls.password = server['adminPass']
|
cls.password = server['adminPass']
|
||||||
return server['id']
|
return server['id']
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def delete_server(cls, server_id):
|
||||||
|
"""Deletes an existing server and waits for it to be gone."""
|
||||||
|
try:
|
||||||
|
cls.servers_client.delete_server(server_id)
|
||||||
|
cls.servers_client.wait_for_server_termination(server_id)
|
||||||
|
except Exception:
|
||||||
|
LOG.exception('Failed to delete server %s' % server_id)
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def delete_volume(cls, volume_id):
|
def delete_volume(cls, volume_id):
|
||||||
"""Deletes the given volume and waits for it to be gone."""
|
"""Deletes the given volume and waits for it to be gone."""
|
||||||
|
@ -181,27 +181,16 @@ class ServerActionsTestJSON(base.BaseV2ComputeTest):
|
|||||||
self.client.wait_for_server_status(self.server_id, 'SHUTOFF')
|
self.client.wait_for_server_status(self.server_id, 'SHUTOFF')
|
||||||
self.client.start(self.server_id)
|
self.client.start(self.server_id)
|
||||||
|
|
||||||
def _detect_server_image_flavor(self, server_id):
|
|
||||||
# Detects the current server image flavor ref.
|
|
||||||
server = self.client.get_server(server_id)
|
|
||||||
current_flavor = server['flavor']['id']
|
|
||||||
new_flavor_ref = self.flavor_ref_alt \
|
|
||||||
if current_flavor == self.flavor_ref else self.flavor_ref
|
|
||||||
return current_flavor, new_flavor_ref
|
|
||||||
|
|
||||||
def _test_resize_server_confirm(self, stop=False):
|
def _test_resize_server_confirm(self, stop=False):
|
||||||
# The server's RAM and disk space should be modified to that of
|
# The server's RAM and disk space should be modified to that of
|
||||||
# the provided flavor
|
# the provided flavor
|
||||||
|
|
||||||
previous_flavor_ref, new_flavor_ref = \
|
|
||||||
self._detect_server_image_flavor(self.server_id)
|
|
||||||
|
|
||||||
if stop:
|
if stop:
|
||||||
self.servers_client.stop(self.server_id)
|
self.servers_client.stop(self.server_id)
|
||||||
self.servers_client.wait_for_server_status(self.server_id,
|
self.servers_client.wait_for_server_status(self.server_id,
|
||||||
'SHUTOFF')
|
'SHUTOFF')
|
||||||
|
|
||||||
self.client.resize(self.server_id, new_flavor_ref)
|
self.client.resize(self.server_id, self.flavor_ref_alt)
|
||||||
self.client.wait_for_server_status(self.server_id, 'VERIFY_RESIZE')
|
self.client.wait_for_server_status(self.server_id, 'VERIFY_RESIZE')
|
||||||
|
|
||||||
self.client.confirm_resize(self.server_id)
|
self.client.confirm_resize(self.server_id)
|
||||||
@ -209,12 +198,16 @@ class ServerActionsTestJSON(base.BaseV2ComputeTest):
|
|||||||
self.client.wait_for_server_status(self.server_id, expected_status)
|
self.client.wait_for_server_status(self.server_id, expected_status)
|
||||||
|
|
||||||
server = self.client.get_server(self.server_id)
|
server = self.client.get_server(self.server_id)
|
||||||
self.assertEqual(new_flavor_ref, server['flavor']['id'])
|
self.assertEqual(self.flavor_ref_alt, server['flavor']['id'])
|
||||||
|
|
||||||
if stop:
|
if stop:
|
||||||
# NOTE(mriedem): tearDown requires the server to be started.
|
# NOTE(mriedem): tearDown requires the server to be started.
|
||||||
self.client.start(self.server_id)
|
self.client.start(self.server_id)
|
||||||
|
|
||||||
|
# NOTE(jlk): Explicitly delete the server to get a new one for later
|
||||||
|
# tests. Avoids resize down race issues.
|
||||||
|
self.addCleanup(self.delete_server, self.server_id)
|
||||||
|
|
||||||
@test.idempotent_id('1499262a-9328-4eda-9068-db1ac57498d2')
|
@test.idempotent_id('1499262a-9328-4eda-9068-db1ac57498d2')
|
||||||
@testtools.skipUnless(CONF.compute_feature_enabled.resize,
|
@testtools.skipUnless(CONF.compute_feature_enabled.resize,
|
||||||
'Resize not available.')
|
'Resize not available.')
|
||||||
@ -234,17 +227,14 @@ class ServerActionsTestJSON(base.BaseV2ComputeTest):
|
|||||||
# The server's RAM and disk space should return to its original
|
# The server's RAM and disk space should return to its original
|
||||||
# values after a resize is reverted
|
# values after a resize is reverted
|
||||||
|
|
||||||
previous_flavor_ref, new_flavor_ref = \
|
self.client.resize(self.server_id, self.flavor_ref_alt)
|
||||||
self._detect_server_image_flavor(self.server_id)
|
|
||||||
|
|
||||||
self.client.resize(self.server_id, new_flavor_ref)
|
|
||||||
self.client.wait_for_server_status(self.server_id, 'VERIFY_RESIZE')
|
self.client.wait_for_server_status(self.server_id, 'VERIFY_RESIZE')
|
||||||
|
|
||||||
self.client.revert_resize(self.server_id)
|
self.client.revert_resize(self.server_id)
|
||||||
self.client.wait_for_server_status(self.server_id, 'ACTIVE')
|
self.client.wait_for_server_status(self.server_id, 'ACTIVE')
|
||||||
|
|
||||||
server = self.client.get_server(self.server_id)
|
server = self.client.get_server(self.server_id)
|
||||||
self.assertEqual(previous_flavor_ref, server['flavor']['id'])
|
self.assertEqual(self.flavor_ref, server['flavor']['id'])
|
||||||
|
|
||||||
@test.idempotent_id('b963d4f1-94b3-4c40-9e97-7b583f46e470')
|
@test.idempotent_id('b963d4f1-94b3-4c40-9e97-7b583f46e470')
|
||||||
@testtools.skipUnless(CONF.compute_feature_enabled.snapshot,
|
@testtools.skipUnless(CONF.compute_feature_enabled.snapshot,
|
||||||
|
Loading…
Reference in New Issue
Block a user