From a9b102dba62539c687e5ce2c98cc661ad3d917ee Mon Sep 17 00:00:00 2001 From: Luan Nunes Utimura Date: Tue, 7 Mar 2023 10:57:33 -0300 Subject: [PATCH] Add location parameter for volume backup creation These patches add the `location` parameter in python-cinderclient's `backup-create` command and in python-openstackclient's `volume backup create` command to allow the optional specification of volume backup locations. The unit tests for both clients were updated accordingly. Test Plan: PASS - Build python-cinderclient package PASS - Build python-openstackclient package PASS - Verify that the `--location` parameter is available for use in both clients when creating volume backups Story: 2010317 Task: 47616 Signed-off-by: Luan Nunes Utimura Change-Id: If821fe402f1d34d89e978028d46916651dc700e6 --- ...parameter-for-volume-backup-creation.patch | 270 ++++++++++++++++++ .../python-cinderclient/debian/patches/series | 1 + ...parameter-for-volume-backup-creation.patch | 125 ++++++++ .../debian/patches/series | 1 + 4 files changed, 397 insertions(+) create mode 100644 openstack/python-cinderclient/debian/patches/0001-Add-location-parameter-for-volume-backup-creation.patch create mode 100644 openstack/python-cinderclient/debian/patches/series create mode 100644 openstack/python-openstackclient/debian/patches/0002-Add-location-parameter-for-volume-backup-creation.patch diff --git a/openstack/python-cinderclient/debian/patches/0001-Add-location-parameter-for-volume-backup-creation.patch b/openstack/python-cinderclient/debian/patches/0001-Add-location-parameter-for-volume-backup-creation.patch new file mode 100644 index 00000000..e3992e98 --- /dev/null +++ b/openstack/python-cinderclient/debian/patches/0001-Add-location-parameter-for-volume-backup-creation.patch @@ -0,0 +1,270 @@ +From b9ea3db2bde72c11b5da6222c57d7ccb80143724 Mon Sep 17 00:00:00 2001 +From: Luan Nunes Utimura +Date: Mon, 6 Mar 2023 09:25:12 -0300 +Subject: [PATCH] Add location parameter for volume backup creation + +This change adds the `location` parameter in python-cinderclient's +`volume backup create` command to allow the optional specification of +volume backup locations. + +This change also updates the unit tests accordingly. + +Signed-off-by: Luan Nunes Utimura +--- + cinderclient/tests/unit/v2/test_shell.py | 5 ++++ + .../tests/unit/v2/test_volume_backups.py | 6 ++++ + cinderclient/tests/unit/v3/test_shell.py | 20 ++++++++++++- + cinderclient/v2/shell.py | 7 ++++- + cinderclient/v2/volume_backups.py | 5 ++-- + cinderclient/v3/shell.py | 5 ++++ + cinderclient/v3/volume_backups.py | 30 +++++++++++-------- + 7 files changed, 62 insertions(+), 16 deletions(-) + +diff --git a/cinderclient/tests/unit/v2/test_shell.py b/cinderclient/tests/unit/v2/test_shell.py +index f6f6355..95a3af9 100644 +--- a/cinderclient/tests/unit/v2/test_shell.py ++++ b/cinderclient/tests/unit/v2/test_shell.py +@@ -379,6 +379,11 @@ class ShellTest(utils.TestCase): + self.run_command('backup-create 1234 --snapshot-id 4321') + self.assert_called('POST', '/backups') + ++ def test_backup_location(self): ++ self.run_command('backup-create 1234 ' ++ '--location nfs://10.10.10.10:/exports/backups') ++ self.assert_called('POST', '/backups') ++ + def test_multiple_backup_delete(self): + self.run_command('backup-delete 1234 5678') + self.assert_called_anytime('DELETE', '/backups/1234') +diff --git a/cinderclient/tests/unit/v2/test_volume_backups.py b/cinderclient/tests/unit/v2/test_volume_backups.py +index 700c440..09f1c0e 100644 +--- a/cinderclient/tests/unit/v2/test_volume_backups.py ++++ b/cinderclient/tests/unit/v2/test_volume_backups.py +@@ -52,6 +52,12 @@ class VolumeBackupsTest(utils.TestCase): + '3c706gbg-c074-51d9-9575-385119gcdfg5') + cs.assert_called('POST', '/backups') + ++ def test_create_location(self): ++ cs.backups.create('2b695faf-b963-40c8-8464-274008fbcef4', ++ None, None, None, False, False, None, ++ 'nfs://10.10.10.10:/exports/backups') ++ cs.assert_called('POST', '/backups') ++ + def test_get(self): + backup_id = '76a17945-3c6f-435c-975b-b5685db10b62' + back = cs.backups.get(backup_id) +diff --git a/cinderclient/tests/unit/v3/test_shell.py b/cinderclient/tests/unit/v3/test_shell.py +index 0332ae3..6464a73 100644 +--- a/cinderclient/tests/unit/v3/test_shell.py ++++ b/cinderclient/tests/unit/v3/test_shell.py +@@ -1254,7 +1254,23 @@ class ShellTest(utils.TestCase): + 'incremental': False, + 'force': False, + 'snapshot_id': None, +- }} ++ 'location': None, }} ++ self.assert_called('POST', '/backups', body=expected) ++ ++ def test_backup_with_location(self): ++ self.run_command('--os-volume-api-version 3.42 backup-create ' ++ '--name 1234 ' ++ '--location nfs://10.10.10.10:/exports/backups 1234') ++ expected = { ++ 'backup': { ++ 'volume_id': 1234, ++ 'container': None, ++ 'name': '1234', ++ 'description': None, ++ 'incremental': False, ++ 'force': False, ++ 'snapshot_id': None, ++ 'location': 'nfs://10.10.10.10:/exports/backups', }} + self.assert_called('POST', '/backups', body=expected) + + def test_backup_with_metadata(self): +@@ -1267,6 +1283,7 @@ class ShellTest(utils.TestCase): + 'incremental': False, + 'force': False, + 'snapshot_id': None, ++ 'location': None, + 'metadata': {'foo': 'bar'}, }} + self.assert_called('POST', '/backups', body=expected) + +@@ -1280,6 +1297,7 @@ class ShellTest(utils.TestCase): + 'incremental': False, + 'force': False, + 'snapshot_id': None, ++ 'location': None, + 'availability_zone': 'AZ2'}} + self.assert_called('POST', '/backups', body=expected) + +diff --git a/cinderclient/v2/shell.py b/cinderclient/v2/shell.py +index d41e014..a975f02 100644 +--- a/cinderclient/v2/shell.py ++++ b/cinderclient/v2/shell.py +@@ -1162,6 +1162,10 @@ def do_retype(cs, args): + metavar='', + default=None, + help='ID of snapshot to backup. Default=None.') ++@utils.arg('--location', ++ metavar='', ++ default=None, ++ help='Backup location. Default=None') + def do_backup_create(cs, args): + """Creates a volume backup.""" + if args.display_name is not None: +@@ -1177,7 +1181,8 @@ def do_backup_create(cs, args): + args.description, + args.incremental, + args.force, +- args.snapshot_id) ++ args.snapshot_id, ++ args.location) + + info = {"volume_id": volume.id} + info.update(backup._info) +diff --git a/cinderclient/v2/volume_backups.py b/cinderclient/v2/volume_backups.py +index bcf3e01..0a4f1c1 100644 +--- a/cinderclient/v2/volume_backups.py ++++ b/cinderclient/v2/volume_backups.py +@@ -46,7 +46,7 @@ class VolumeBackupManager(base.ManagerWithFind): + def create(self, volume_id, container=None, + name=None, description=None, + incremental=False, force=False, +- snapshot_id=None): ++ snapshot_id=None, location=None): + """Creates a volume backup. + + :param volume_id: The ID of the volume to backup. +@@ -66,7 +66,8 @@ class VolumeBackupManager(base.ManagerWithFind): + 'description': description, + 'incremental': incremental, + 'force': force, +- 'snapshot_id': snapshot_id, }} ++ 'snapshot_id': snapshot_id, ++ 'location': location, }} + return self._create('/backups', body, 'backup') + + def get(self, backup_id): +diff --git a/cinderclient/v3/shell.py b/cinderclient/v3/shell.py +index eaded7e..cfafe87 100644 +--- a/cinderclient/v3/shell.py ++++ b/cinderclient/v3/shell.py +@@ -2466,6 +2466,10 @@ def do_service_get_log(cs, args): + metavar='', + default=None, + help='ID of snapshot to backup. Default=None.') ++@utils.arg('--location', ++ metavar='', ++ default=None, ++ help='Backup location. Default=None') + @utils.arg('--metadata', + nargs='*', + metavar='', +@@ -2500,6 +2504,7 @@ def do_backup_create(cs, args): + args.incremental, + args.force, + args.snapshot_id, ++ location=args.location, + **kwargs) + info = {"volume_id": volume.id} + info.update(backup._info) +diff --git a/cinderclient/v3/volume_backups.py b/cinderclient/v3/volume_backups.py +index 7dd8560..66525af 100644 +--- a/cinderclient/v3/volume_backups.py ++++ b/cinderclient/v3/volume_backups.py +@@ -43,7 +43,7 @@ class VolumeBackupManager(volume_backups.VolumeBackupManager): + def create(self, volume_id, container=None, + name=None, description=None, + incremental=False, force=False, +- snapshot_id=None): ++ snapshot_id=None, location=None): + """Creates a volume backup. + + :param volume_id: The ID of the volume to backup. +@@ -55,17 +55,19 @@ class VolumeBackupManager(volume_backups.VolumeBackupManager): + :param snapshot_id: The ID of the snapshot to backup. This should + be a snapshot of the src volume, when specified, + the new backup will be based on the snapshot. ++ :param location: The backup location. + :rtype: :class:`VolumeBackup` + """ + return self._create_backup(volume_id, container, name, description, +- incremental, force, snapshot_id) ++ incremental, force, snapshot_id, ++ location=location) + + @api_versions.wraps("3.43") # noqa: F811 + def create(self, volume_id, container=None, # noqa + name=None, description=None, + incremental=False, force=False, +- snapshot_id=None, +- metadata=None): ++ snapshot_id=None, metadata=None, ++ location=None): + """Creates a volume backup. + + :param volume_id: The ID of the volume to backup. +@@ -74,28 +76,30 @@ class VolumeBackupManager(volume_backups.VolumeBackupManager): + :param description: The description of the backup. + :param incremental: Incremental backup. + :param force: If True, allows an in-use volume to be backed up. +- :param metadata: Key Value pairs + :param snapshot_id: The ID of the snapshot to backup. This should + be a snapshot of the src volume, when specified, + the new backup will be based on the snapshot. ++ :param metadata: Key Value pairs ++ :param location: The backup location. + :rtype: :class:`VolumeBackup` + """ + # pylint: disable=function-redefined + return self._create_backup(volume_id, container, name, description, +- incremental, force, snapshot_id, metadata) ++ incremental, force, snapshot_id, metadata, ++ location=location) + + @api_versions.wraps("3.51") # noqa: F811 + def create(self, volume_id, container=None, name=None, description=None, # noqa + incremental=False, force=False, snapshot_id=None, metadata=None, +- availability_zone=None): ++ availability_zone=None, location=None): + return self._create_backup(volume_id, container, name, description, + incremental, force, snapshot_id, metadata, +- availability_zone) ++ availability_zone, location=location) + + def _create_backup(self, volume_id, container=None, name=None, + description=None, incremental=False, force=False, +- snapshot_id=None, metadata=None, +- availability_zone=None): ++ snapshot_id=None, metadata=None, availability_zone=None, ++ location=None): + """Creates a volume backup. + + :param volume_id: The ID of the volume to backup. +@@ -104,10 +108,11 @@ class VolumeBackupManager(volume_backups.VolumeBackupManager): + :param description: The description of the backup. + :param incremental: Incremental backup. + :param force: If True, allows an in-use volume to be backed up. +- :param metadata: Key Value pairs + :param snapshot_id: The ID of the snapshot to backup. This should + be a snapshot of the src volume, when specified, + the new backup will be based on the snapshot. ++ :param location: The backup location. ++ :param metadata: Key Value pairs + :param availability_zone: The AZ where we want the backup stored. + :rtype: :class:`VolumeBackup` + """ +@@ -118,7 +123,8 @@ class VolumeBackupManager(volume_backups.VolumeBackupManager): + 'description': description, + 'incremental': incremental, + 'force': force, +- 'snapshot_id': snapshot_id, }} ++ 'snapshot_id': snapshot_id, ++ 'location': location, }} + if metadata: + body['backup']['metadata'] = metadata + if availability_zone: +-- +2.25.1 + diff --git a/openstack/python-cinderclient/debian/patches/series b/openstack/python-cinderclient/debian/patches/series new file mode 100644 index 00000000..e96b9227 --- /dev/null +++ b/openstack/python-cinderclient/debian/patches/series @@ -0,0 +1 @@ +0001-Add-location-parameter-for-volume-backup-creation.patch diff --git a/openstack/python-openstackclient/debian/patches/0002-Add-location-parameter-for-volume-backup-creation.patch b/openstack/python-openstackclient/debian/patches/0002-Add-location-parameter-for-volume-backup-creation.patch new file mode 100644 index 00000000..1bfc6b8a --- /dev/null +++ b/openstack/python-openstackclient/debian/patches/0002-Add-location-parameter-for-volume-backup-creation.patch @@ -0,0 +1,125 @@ +From fdcd730533f402daa0487995d1fa57b0867bf2b4 Mon Sep 17 00:00:00 2001 +From: Luan Nunes Utimura +Date: Mon, 6 Mar 2023 09:52:22 -0300 +Subject: [PATCH] Add location parameter for volume backup creation + +This change adds the `location` parameter in python-openstackclient's +`volume backup create` command to allow the optional specification of +volume backup locations. + +This change also updates the unit tests accordingly. + +Signed-off-by: Luan Nunes Utimura +--- + openstackclient/tests/unit/volume/v2/fakes.py | 1 + + .../tests/unit/volume/v2/test_volume_backup.py | 8 ++++++++ + openstackclient/volume/v2/volume_backup.py | 6 ++++++ + 3 files changed, 15 insertions(+) + +diff --git a/openstackclient/tests/unit/volume/v2/fakes.py b/openstackclient/tests/unit/volume/v2/fakes.py +index 5f18990e..62b5d5cb 100644 +--- a/openstackclient/tests/unit/volume/v2/fakes.py ++++ b/openstackclient/tests/unit/volume/v2/fakes.py +@@ -548,6 +548,7 @@ class FakeBackup(object): + "size": random.randint(1, 20), + "status": "error", + "availability_zone": 'zone' + uuid.uuid4().hex, ++ "location": 'location-' + uuid.uuid4().hex, + } + + # Overwrite default attributes. +diff --git a/openstackclient/tests/unit/volume/v2/test_volume_backup.py b/openstackclient/tests/unit/volume/v2/test_volume_backup.py +index 4e1f7ee1..9417fe77 100644 +--- a/openstackclient/tests/unit/volume/v2/test_volume_backup.py ++++ b/openstackclient/tests/unit/volume/v2/test_volume_backup.py +@@ -49,6 +49,7 @@ class TestBackupCreate(TestBackup): + 'container', + 'description', + 'id', ++ 'location', + 'name', + 'object_count', + 'size', +@@ -61,6 +62,7 @@ class TestBackupCreate(TestBackup): + new_backup.container, + new_backup.description, + new_backup.id, ++ new_backup.location, + new_backup.name, + new_backup.object_count, + new_backup.size, +@@ -87,6 +89,7 @@ class TestBackupCreate(TestBackup): + "--force", + "--incremental", + "--snapshot", self.new_backup.snapshot_id, ++ "--location", self.new_backup.location, + self.new_backup.volume_id, + ] + verifylist = [ +@@ -96,6 +99,7 @@ class TestBackupCreate(TestBackup): + ("force", True), + ("incremental", True), + ("snapshot", self.new_backup.snapshot_id), ++ ("location", self.new_backup.location), + ("volume", self.new_backup.volume_id), + ] + parsed_args = self.check_parser(self.cmd, arglist, verifylist) +@@ -110,6 +114,7 @@ class TestBackupCreate(TestBackup): + force=True, + incremental=True, + snapshot_id=self.new_backup.snapshot_id, ++ location=self.new_backup.location, + ) + self.assertEqual(self.columns, columns) + self.assertEqual(self.data, data) +@@ -137,6 +142,7 @@ class TestBackupCreate(TestBackup): + force=False, + incremental=False, + snapshot_id=None, ++ location=None, + ) + self.assertEqual(self.columns, columns) + self.assertEqual(self.data, data) +@@ -492,6 +498,7 @@ class TestBackupShow(TestBackup): + 'container', + 'description', + 'id', ++ 'location', + 'name', + 'object_count', + 'size', +@@ -504,6 +511,7 @@ class TestBackupShow(TestBackup): + backup.container, + backup.description, + backup.id, ++ backup.location, + backup.name, + backup.object_count, + backup.size, +diff --git a/openstackclient/volume/v2/volume_backup.py b/openstackclient/volume/v2/volume_backup.py +index c336f6c9..5de4f7f3 100644 +--- a/openstackclient/volume/v2/volume_backup.py ++++ b/openstackclient/volume/v2/volume_backup.py +@@ -87,6 +87,11 @@ class CreateVolumeBackup(command.ShowOne): + metavar="", + help=_("Snapshot to backup (name or ID)") + ) ++ parser.add_argument( ++ "--location", ++ metavar="", ++ help=_("Optional backup location") ++ ) + parser.add_argument( + '--force', + action='store_true', +@@ -117,6 +122,7 @@ class CreateVolumeBackup(command.ShowOne): + force=parsed_args.force, + incremental=parsed_args.incremental, + snapshot_id=snapshot_id, ++ location=parsed_args.location, + ) + backup._info.pop("links", None) + return zip(*sorted(backup._info.items())) +-- +2.25.1 + diff --git a/openstack/python-openstackclient/debian/patches/series b/openstack/python-openstackclient/debian/patches/series index 911ab6be..49726339 100644 --- a/openstack/python-openstackclient/debian/patches/series +++ b/openstack/python-openstackclient/debian/patches/series @@ -1 +1,2 @@ 0001-Add-plugin-entry-point-sorting-mechanism.patch +0002-Add-location-parameter-for-volume-backup-creation.patch