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:
Jesse Keating 2015-05-04 15:05:19 -07:00
parent 5b6b824739
commit 613b498ca9
2 changed files with 17 additions and 18 deletions

View File

@ -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."""

View File

@ -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,