summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorZuul <zuul@review.opendev.org>2019-10-22 21:16:35 +0000
committerGerrit Code Review <review@openstack.org>2019-10-22 21:16:35 +0000
commitd2e809f12086171d227a06fd7ea19e0e36ed12f8 (patch)
tree8195ba9d1dea2d46737c4b6e13ac617837aa4054
parent5eedf36db63ed5edc2315faa85bd95eb201eaefe (diff)
parent3a20c1b1e6c60e4966a967911350a8422d4d2242 (diff)
downloadpython-openstackclient-d2e809f12086171d227a06fd7ea19e0e36ed12f8.tar.gz
Merge "Fix: Restore output 'VolumeBackupsRestore' object is not iterable" into stable/queens
-rw-r--r--openstackclient/tests/functional/volume/v2/test_backup.py58
-rw-r--r--openstackclient/tests/unit/volume/v2/test_backup.py6
-rw-r--r--openstackclient/volume/v2/backup.py4
3 files changed, 65 insertions, 3 deletions
diff --git a/openstackclient/tests/functional/volume/v2/test_backup.py b/openstackclient/tests/functional/volume/v2/test_backup.py
new file mode 100644
index 00000000..e4890b00
--- /dev/null
+++ b/openstackclient/tests/functional/volume/v2/test_backup.py
@@ -0,0 +1,58 @@
+# 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.
+
+import json
+import uuid
+
+from openstackclient.tests.functional.volume.v2 import common
+
+
+class VolumeBackupTests(common.BaseVolumeTests):
+ """Functional tests for volume backups. """
+
+ def setUp(self):
+ super(VolumeBackupTests, self).setUp()
+ self.backup_enabled = False
+ serv_list = json.loads(self.openstack('volume service list -f json'))
+ for service in serv_list:
+ if service['Binary'] == 'cinder-backup':
+ if service['Status'] == 'enabled':
+ self.backup_enabled = True
+
+ def test_volume_backup_restore(self):
+ """Test restore backup"""
+ if not self.backup_enabled:
+ self.skipTest('Backup service is not enabled')
+ vol_id = uuid.uuid4().hex
+ # create a volume
+ json.loads(self.openstack(
+ 'volume create -f json ' +
+ '--size 1 ' +
+ vol_id
+ ))
+ # create a backup
+ backup = json.loads(self.openstack(
+ 'volume backup create -f json ' +
+ vol_id
+ ))
+
+ self.wait_for_status("volume", vol_id, "available")
+ self.wait_for_status("backup", backup['id'], "available")
+ # restore the backup
+ backup_restored = json.loads(self.openstack(
+ 'volume backup restore -f json %s %s'
+ % (backup['id'], vol_id)))
+ self.assertEqual(backup_restored['backup_id'], backup['id'])
+ self.wait_for_status("backup", backup['id'], "available")
+ self.wait_for_status("volume", backup_restored['volume_id'],
+ "available")
+ self.addCleanup(self.openstack, 'volume delete %s' % vol_id)
diff --git a/openstackclient/tests/unit/volume/v2/test_backup.py b/openstackclient/tests/unit/volume/v2/test_backup.py
index a8e81c7e..9a2ce718 100644
--- a/openstackclient/tests/unit/volume/v2/test_backup.py
+++ b/openstackclient/tests/unit/volume/v2/test_backup.py
@@ -367,7 +367,9 @@ class TestBackupRestore(TestBackup):
self.backups_mock.get.return_value = self.backup
self.volumes_mock.get.return_value = self.volume
- self.restores_mock.restore.return_value = None
+ self.restores_mock.restore.return_value = (
+ volume_fakes.FakeVolume.create_one_volume(
+ {'id': self.volume['id']}))
# Get the command object to mock
self.cmd = backup.RestoreVolumeBackup(self.app, None)
@@ -385,7 +387,7 @@ class TestBackupRestore(TestBackup):
result = self.cmd.take_action(parsed_args)
self.restores_mock.restore.assert_called_with(self.backup.id,
self.backup.volume_id)
- self.assertIsNone(result)
+ self.assertIsNotNone(result)
class TestBackupSet(TestBackup):
diff --git a/openstackclient/volume/v2/backup.py b/openstackclient/volume/v2/backup.py
index 60633a70..d4aec8d7 100644
--- a/openstackclient/volume/v2/backup.py
+++ b/openstackclient/volume/v2/backup.py
@@ -319,7 +319,9 @@ class RestoreVolumeBackup(command.ShowOne):
backup = utils.find_resource(volume_client.backups, parsed_args.backup)
destination_volume = utils.find_resource(volume_client.volumes,
parsed_args.volume)
- return volume_client.restores.restore(backup.id, destination_volume.id)
+ backup = volume_client.restores.restore(backup.id,
+ destination_volume.id)
+ return zip(*sorted(six.iteritems(backup._info)))
class RestoreBackup(RestoreVolumeBackup):