summaryrefslogtreecommitdiff
path: root/openstackclient/tests
diff options
context:
space:
mode:
authorStephen Finucane <sfinucan@redhat.com>2020-11-18 11:27:30 +0000
committerStephen Finucane <sfinucan@redhat.com>2021-01-08 18:01:29 +0000
commit2b073c2034acdabb8d4097b7f2c0408e53fe2d63 (patch)
tree78bf2a9c9ee1a2a2a50fa6d3ffca7a67ca62f3ea /openstackclient/tests
parent64c2a1a453fce8f4e2e7e8441692af007c176459 (diff)
downloadpython-openstackclient-2b073c2034acdabb8d4097b7f2c0408e53fe2d63.tar.gz
Add 'server unshelve --wait' option
This was recently added to the 'server shelve' command. Add it now for the 'unshelve' command. Change-Id: I633dd85b60cf70b4f8610f414d82669dd6a53111 Signed-off-by: Stephen Finucane <sfinucan@redhat.com>
Diffstat (limited to 'openstackclient/tests')
-rw-r--r--openstackclient/tests/unit/compute/v2/test_server.py80
1 files changed, 51 insertions, 29 deletions
diff --git a/openstackclient/tests/unit/compute/v2/test_server.py b/openstackclient/tests/unit/compute/v2/test_server.py
index 9ad6d155..2c0cadfc 100644
--- a/openstackclient/tests/unit/compute/v2/test_server.py
+++ b/openstackclient/tests/unit/compute/v2/test_server.py
@@ -6969,6 +6969,9 @@ class TestServerUnshelve(TestServer):
self.methods = {
'unshelve': None,
}
+ self.attrs = {
+ 'status': 'SHELVED',
+ }
def test_unshelve_one_server(self):
self.run_method_with_servers('unshelve', 1)
@@ -6976,55 +6979,74 @@ class TestServerUnshelve(TestServer):
def test_unshelve_multi_servers(self):
self.run_method_with_servers('unshelve', 3)
- def test_unshelve_server_with_specified_az(self):
- server = compute_fakes.FakeServer.create_one_server()
+ def test_unshelve_with_specified_az(self):
+ self.app.client_manager.compute.api_version = \
+ api_versions.APIVersion('2.77')
+
+ server = compute_fakes.FakeServer.create_one_server(
+ attrs=self.attrs, methods=self.methods)
+ self.servers_mock.get.return_value = server
arglist = [
- server.id,
'--availability-zone', "foo-az",
+ server.id,
]
verifylist = [
('availability_zone', "foo-az"),
('server', [server.id])
]
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
- ex = self.assertRaises(exceptions.CommandError,
- self.cmd.take_action,
- parsed_args)
- self.assertIn(
- '--os-compute-api-version 2.77 or greater is required', str(ex))
-
-class TestServerUnshelveV277(TestServerUnshelve):
-
- def setUp(self):
- super(TestServerUnshelveV277, self).setUp()
-
- self.server = compute_fakes.FakeServer.create_one_server(
- methods=self.methods)
-
- # This is the return value for utils.find_resource()
- self.servers_mock.get.return_value = self.server
+ self.cmd.take_action(parsed_args)
- # Get the command object to test
- self.cmd = server.UnshelveServer(self.app, None)
+ self.servers_mock.get.assert_called_with(server.id)
+ server.unshelve.assert_called_with(availability_zone="foo-az")
- def test_specified_az_to_unshelve_with_v277(self):
- self.app.client_manager.compute.api_version = api_versions.APIVersion(
- '2.77')
+ def test_unshelve_with_specified_az_pre_v277(self):
+ self.app.client_manager.compute.api_version = \
+ api_versions.APIVersion('2.76')
+ server = compute_fakes.FakeServer.create_one_server(
+ attrs=self.attrs, methods=self.methods)
arglist = [
+ server.id,
'--availability-zone', "foo-az",
- self.server.id,
]
verifylist = [
('availability_zone', "foo-az"),
- ('server', [self.server.id])
+ ('server', [server.id])
]
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
+ ex = self.assertRaises(
+ exceptions.CommandError,
+ self.cmd.take_action,
+ parsed_args)
+ self.assertIn(
+ '--os-compute-api-version 2.77 or greater is required', str(ex))
- self.cmd.take_action(parsed_args)
- self.servers_mock.get.assert_called_with(self.server.id)
- self.server.unshelve.assert_called_with(availability_zone="foo-az")
+ @mock.patch.object(common_utils, 'wait_for_status', return_value=True)
+ def test_unshelve_with_wait(self, mock_wait_for_status):
+ server = compute_fakes.FakeServer.create_one_server(
+ attrs=self.attrs, methods=self.methods)
+ self.servers_mock.get.return_value = server
+
+ arglist = ['--wait', server.name]
+ verifylist = [
+ ('server', [server.name]),
+ ('wait', True),
+ ]
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
+
+ result = self.cmd.take_action(parsed_args)
+ self.assertIsNone(result)
+
+ self.servers_mock.get.assert_called_once_with(server.name)
+ server.unshelve.assert_called_once_with()
+ mock_wait_for_status.assert_called_once_with(
+ self.servers_mock.get,
+ server.id,
+ callback=mock.ANY,
+ success_status=('active', 'shutoff'),
+ )
class TestServerGeneral(TestServer):