summaryrefslogtreecommitdiff
path: root/openstackclient/tests
diff options
context:
space:
mode:
authorwhoami-rajat <rajatdhasmana@gmail.com>2022-11-17 18:35:01 +0530
committerwhoami-rajat <rajatdhasmana@gmail.com>2022-11-21 20:30:09 +0530
commitbd0727c4f897289722ba639930c9e979cfee534a (patch)
tree6a07561a2dba008cf573c2b6473b70161e4d7fbb /openstackclient/tests
parent56b0f6de0e950cf23aeb25ff234b307e3857dcfa (diff)
downloadpython-openstackclient-bd0727c4f897289722ba639930c9e979cfee534a.tar.gz
Add option to create volume from backup
Support for creating a volume from backup was added in microversio 3.47. This patch adds a --backup option to the volume create command to add that support. Change-Id: Ib26d2d335475d9aacbf77c0fd7b7cda2ba743943
Diffstat (limited to 'openstackclient/tests')
-rw-r--r--openstackclient/tests/unit/volume/v2/test_volume.py73
1 files changed, 73 insertions, 0 deletions
diff --git a/openstackclient/tests/unit/volume/v2/test_volume.py b/openstackclient/tests/unit/volume/v2/test_volume.py
index f802f637..ef9c2fab 100644
--- a/openstackclient/tests/unit/volume/v2/test_volume.py
+++ b/openstackclient/tests/unit/volume/v2/test_volume.py
@@ -16,6 +16,7 @@ import argparse
from unittest import mock
from unittest.mock import call
+from cinderclient import api_versions
from osc_lib.cli import format_columns
from osc_lib import exceptions
from osc_lib import utils
@@ -47,6 +48,9 @@ class TestVolume(volume_fakes.TestVolume):
self.snapshots_mock = self.app.client_manager.volume.volume_snapshots
self.snapshots_mock.reset_mock()
+ self.backups_mock = self.app.client_manager.volume.backups
+ self.backups_mock.reset_mock()
+
self.types_mock = self.app.client_manager.volume.volume_types
self.types_mock.reset_mock()
@@ -129,6 +133,7 @@ class TestVolumeCreate(TestVolume):
source_volid=None,
consistencygroup_id=None,
scheduler_hints=None,
+ backup_id=None,
)
self.assertEqual(self.columns, columns)
@@ -174,6 +179,7 @@ class TestVolumeCreate(TestVolume):
source_volid=None,
consistencygroup_id=consistency_group.id,
scheduler_hints={'k': 'v'},
+ backup_id=None,
)
self.assertEqual(self.columns, columns)
@@ -210,6 +216,7 @@ class TestVolumeCreate(TestVolume):
source_volid=None,
consistencygroup_id=None,
scheduler_hints=None,
+ backup_id=None,
)
self.assertEqual(self.columns, columns)
@@ -248,6 +255,7 @@ class TestVolumeCreate(TestVolume):
source_volid=None,
consistencygroup_id=None,
scheduler_hints=None,
+ backup_id=None,
)
self.assertEqual(self.columns, columns)
@@ -286,6 +294,7 @@ class TestVolumeCreate(TestVolume):
source_volid=None,
consistencygroup_id=None,
scheduler_hints=None,
+ backup_id=None,
)
self.assertEqual(self.columns, columns)
@@ -323,11 +332,72 @@ class TestVolumeCreate(TestVolume):
source_volid=None,
consistencygroup_id=None,
scheduler_hints=None,
+ backup_id=None,
+ )
+
+ self.assertEqual(self.columns, columns)
+ self.assertCountEqual(self.datalist, data)
+
+ def test_volume_create_with_backup(self):
+ backup = volume_fakes.create_one_backup()
+ self.new_volume.backup_id = backup.id
+ arglist = [
+ '--backup', self.new_volume.backup_id,
+ self.new_volume.name,
+ ]
+ verifylist = [
+ ('backup', self.new_volume.backup_id),
+ ('name', self.new_volume.name),
+ ]
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
+
+ self.backups_mock.get.return_value = backup
+
+ self.app.client_manager.volume.api_version = \
+ api_versions.APIVersion('3.47')
+
+ # In base command class ShowOne in cliff, abstract method take_action()
+ # returns a two-part tuple with a tuple of column names and a tuple of
+ # data to be shown.
+ columns, data = self.cmd.take_action(parsed_args)
+
+ self.volumes_mock.create.assert_called_once_with(
+ size=backup.size,
+ snapshot_id=None,
+ name=self.new_volume.name,
+ description=None,
+ volume_type=None,
+ availability_zone=None,
+ metadata=None,
+ imageRef=None,
+ source_volid=None,
+ consistencygroup_id=None,
+ scheduler_hints=None,
+ backup_id=backup.id,
)
self.assertEqual(self.columns, columns)
self.assertCountEqual(self.datalist, data)
+ def test_volume_create_with_backup_pre_347(self):
+ backup = volume_fakes.create_one_backup()
+ self.new_volume.backup_id = backup.id
+ arglist = [
+ '--backup', self.new_volume.backup_id,
+ self.new_volume.name,
+ ]
+ verifylist = [
+ ('backup', self.new_volume.backup_id),
+ ('name', self.new_volume.name),
+ ]
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
+
+ self.backups_mock.get.return_value = backup
+
+ exc = self.assertRaises(exceptions.CommandError, self.cmd.take_action,
+ parsed_args)
+ self.assertIn("--os-volume-api-version 3.47 or greater", str(exc))
+
def test_volume_create_with_bootable_and_readonly(self):
arglist = [
'--bootable',
@@ -361,6 +431,7 @@ class TestVolumeCreate(TestVolume):
source_volid=None,
consistencygroup_id=None,
scheduler_hints=None,
+ backup_id=None,
)
self.assertEqual(self.columns, columns)
@@ -403,6 +474,7 @@ class TestVolumeCreate(TestVolume):
source_volid=None,
consistencygroup_id=None,
scheduler_hints=None,
+ backup_id=None,
)
self.assertEqual(self.columns, columns)
@@ -454,6 +526,7 @@ class TestVolumeCreate(TestVolume):
source_volid=None,
consistencygroup_id=None,
scheduler_hints=None,
+ backup_id=None,
)
self.assertEqual(2, mock_error.call_count)