summaryrefslogtreecommitdiff
path: root/openstackclient/tests/unit
diff options
context:
space:
mode:
authorStephen Finucane <sfinucan@redhat.com>2020-12-03 12:47:10 +0000
committerStephen Finucane <sfinucan@redhat.com>2021-01-08 12:14:43 +0000
commitd5026278ede4dbe8126839ec59ec4ca371e806a8 (patch)
treeec2f75cf1e4753df07ea63cdceacc89fbff5ddc3 /openstackclient/tests/unit
parentb34905722015646538c8557f9fa91fc2b5edffdb (diff)
downloadpython-openstackclient-d5026278ede4dbe8126839ec59ec4ca371e806a8.tar.gz
compute: Add 'server volume list' command
This replaces the old 'nova volume-attachments' command. Change-Id: Icb98766f98bd1f2469bdb6df62b4624711f98422 Signed-off-by: Stephen Finucane <sfinucan@redhat.com>
Diffstat (limited to 'openstackclient/tests/unit')
-rw-r--r--openstackclient/tests/unit/compute/v2/fakes.py60
-rw-r--r--openstackclient/tests/unit/compute/v2/test_server_volume.py167
2 files changed, 227 insertions, 0 deletions
diff --git a/openstackclient/tests/unit/compute/v2/fakes.py b/openstackclient/tests/unit/compute/v2/fakes.py
index b667c691..e4cf1045 100644
--- a/openstackclient/tests/unit/compute/v2/fakes.py
+++ b/openstackclient/tests/unit/compute/v2/fakes.py
@@ -1631,3 +1631,63 @@ class FakeServerMigration(object):
attrs, methods))
return migrations
+
+
+class FakeVolumeAttachment(object):
+ """Fake one or more volume attachments (BDMs)."""
+
+ @staticmethod
+ def create_one_volume_attachment(attrs=None, methods=None):
+ """Create a fake volume attachment.
+
+ :param Dictionary attrs:
+ A dictionary with all attributes
+ :param Dictionary methods:
+ A dictionary with all methods
+ :return:
+ A FakeResource object, with id, device, and so on
+ """
+ attrs = attrs or {}
+ methods = methods or {}
+
+ # Set default attributes.
+ volume_attachment_info = {
+ "id": uuid.uuid4().hex,
+ "device": "/dev/sdb",
+ "serverId": uuid.uuid4().hex,
+ "volumeId": uuid.uuid4().hex,
+ # introduced in API microversion 2.70
+ "tag": "foo",
+ # introduced in API microversion 2.79
+ "delete_on_termination": True,
+ }
+
+ # Overwrite default attributes.
+ volume_attachment_info.update(attrs)
+
+ volume_attachment = fakes.FakeResource(
+ info=copy.deepcopy(volume_attachment_info),
+ methods=methods,
+ loaded=True)
+ return volume_attachment
+
+ @staticmethod
+ def create_volume_attachments(attrs=None, methods=None, count=2):
+ """Create multiple fake volume attachments (BDMs).
+
+ :param Dictionary attrs:
+ A dictionary with all attributes
+ :param Dictionary methods:
+ A dictionary with all methods
+ :param int count:
+ The number of server migrations to fake
+ :return:
+ A list of FakeResource objects faking the volume attachments.
+ """
+ volume_attachments = []
+ for i in range(0, count):
+ volume_attachments.append(
+ FakeVolumeAttachment.create_one_volume_attachment(
+ attrs, methods))
+
+ return volume_attachments
diff --git a/openstackclient/tests/unit/compute/v2/test_server_volume.py b/openstackclient/tests/unit/compute/v2/test_server_volume.py
new file mode 100644
index 00000000..d09c2874
--- /dev/null
+++ b/openstackclient/tests/unit/compute/v2/test_server_volume.py
@@ -0,0 +1,167 @@
+# 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 novaclient import api_versions
+
+from openstackclient.compute.v2 import server_volume
+from openstackclient.tests.unit.compute.v2 import fakes as compute_fakes
+
+
+class TestServerVolume(compute_fakes.TestComputev2):
+
+ def setUp(self):
+ super().setUp()
+
+ # Get a shortcut to the compute client ServerManager Mock
+ self.servers_mock = self.app.client_manager.compute.servers
+ self.servers_mock.reset_mock()
+
+ # Get a shortcut to the compute client VolumeManager mock
+ self.servers_volumes_mock = self.app.client_manager.compute.volumes
+ self.servers_volumes_mock.reset_mock()
+
+
+class TestServerVolumeList(TestServerVolume):
+
+ def setUp(self):
+ super().setUp()
+
+ self.server = compute_fakes.FakeServer.create_one_server()
+ self.volume_attachments = (
+ compute_fakes.FakeVolumeAttachment.create_volume_attachments())
+
+ self.servers_mock.get.return_value = self.server
+ self.servers_volumes_mock.get_server_volumes.return_value = (
+ self.volume_attachments)
+
+ # Get the command object to test
+ self.cmd = server_volume.ListServerVolume(self.app, None)
+
+ def test_server_volume_list(self):
+ self.app.client_manager.compute.api_version = \
+ api_versions.APIVersion('2.1')
+
+ arglist = [
+ self.server.id,
+ ]
+ verifylist = [
+ ('server', self.server.id),
+ ]
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
+
+ columns, data = self.cmd.take_action(parsed_args)
+
+ self.assertEqual(('ID', 'Device', 'Server ID', 'Volume ID'), columns)
+ self.assertEqual(
+ (
+ (
+ self.volume_attachments[0].id,
+ self.volume_attachments[0].device,
+ self.volume_attachments[0].serverId,
+ self.volume_attachments[0].volumeId,
+ ),
+ (
+ self.volume_attachments[1].id,
+ self.volume_attachments[1].device,
+ self.volume_attachments[1].serverId,
+ self.volume_attachments[1].volumeId,
+ ),
+ ),
+ tuple(data),
+ )
+ self.servers_volumes_mock.get_server_volumes.assert_called_once_with(
+ self.server.id)
+
+ def test_server_volume_list_with_tags(self):
+ self.app.client_manager.compute.api_version = \
+ api_versions.APIVersion('2.70')
+
+ arglist = [
+ self.server.id,
+ ]
+ verifylist = [
+ ('server', self.server.id),
+ ]
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
+
+ columns, data = self.cmd.take_action(parsed_args)
+
+ self.assertEqual(
+ ('ID', 'Device', 'Server ID', 'Volume ID', 'Tag',), columns,
+ )
+ self.assertEqual(
+ (
+ (
+ self.volume_attachments[0].id,
+ self.volume_attachments[0].device,
+ self.volume_attachments[0].serverId,
+ self.volume_attachments[0].volumeId,
+ self.volume_attachments[0].tag,
+ ),
+ (
+ self.volume_attachments[1].id,
+ self.volume_attachments[1].device,
+ self.volume_attachments[1].serverId,
+ self.volume_attachments[1].volumeId,
+ self.volume_attachments[1].tag,
+ ),
+ ),
+ tuple(data),
+ )
+ self.servers_volumes_mock.get_server_volumes.assert_called_once_with(
+ self.server.id)
+
+ def test_server_volume_list_with_delete_on_attachment(self):
+ self.app.client_manager.compute.api_version = \
+ api_versions.APIVersion('2.79')
+
+ arglist = [
+ self.server.id,
+ ]
+ verifylist = [
+ ('server', self.server.id),
+ ]
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
+
+ columns, data = self.cmd.take_action(parsed_args)
+
+ self.assertEqual(
+ (
+ 'ID', 'Device', 'Server ID', 'Volume ID', 'Tag',
+ 'Delete On Termination?',
+ ),
+ columns,
+ )
+ self.assertEqual(
+ (
+ (
+ self.volume_attachments[0].id,
+ self.volume_attachments[0].device,
+ self.volume_attachments[0].serverId,
+ self.volume_attachments[0].volumeId,
+ self.volume_attachments[0].tag,
+ self.volume_attachments[0].delete_on_termination,
+ ),
+ (
+ self.volume_attachments[1].id,
+ self.volume_attachments[1].device,
+ self.volume_attachments[1].serverId,
+ self.volume_attachments[1].volumeId,
+ self.volume_attachments[1].tag,
+ self.volume_attachments[1].delete_on_termination,
+ ),
+ ),
+ tuple(data),
+ )
+ self.servers_volumes_mock.get_server_volumes.assert_called_once_with(
+ self.server.id)