blob: ff28b50c7f981967cccb94e8c05fb13894a95e73 [file] [log] [blame]
Giulio Fidente74b08ad2014-01-18 04:02:51 +01001# Copyright 2014 OpenStack Foundation
2# All Rights Reserved.
3#
4# Licensed under the Apache License, Version 2.0 (the "License"); you may
5# not use this file except in compliance with the License. You may obtain
6# a copy of the License at
7#
8# http://www.apache.org/licenses/LICENSE-2.0
9#
10# Unless required by applicable law or agreed to in writing, software
11# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
12# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
13# License for the specific language governing permissions and limitations
14# under the License.
15
Gorka Eguileor9de20c12015-08-13 11:16:43 +020016import base64
17import six
18
19from oslo_serialization import jsonutils as json
20
Masayuki Igawa1edf94f2014-03-04 18:34:16 +090021from tempest.api.volume import base
Fei Long Wangd39431f2015-05-14 11:30:48 +120022from tempest.common.utils import data_utils
Yaroslav Lobankoved3a35b2016-03-24 22:41:30 -050023from tempest.common import waiters
Giulio Fidente74b08ad2014-01-18 04:02:51 +010024from tempest import config
Giulio Fidente74b08ad2014-01-18 04:02:51 +010025from tempest import test
26
27CONF = config.CONF
Giulio Fidente74b08ad2014-01-18 04:02:51 +010028
29
lkuchlan9dea88e2016-06-07 17:12:01 +030030class VolumesBackupsAdminV2Test(base.BaseVolumeAdminTest):
Giulio Fidente74b08ad2014-01-18 04:02:51 +010031
32 @classmethod
Rohan Kanade05749152015-01-30 17:15:18 +053033 def skip_checks(cls):
lkuchlan9dea88e2016-06-07 17:12:01 +030034 super(VolumesBackupsAdminV2Test, cls).skip_checks()
Giulio Fidente74b08ad2014-01-18 04:02:51 +010035 if not CONF.volume_feature_enabled.backup:
36 raise cls.skipException("Cinder backup feature disabled")
37
Rohan Kanade05749152015-01-30 17:15:18 +053038 @classmethod
39 def resource_setup(cls):
lkuchlan9dea88e2016-06-07 17:12:01 +030040 super(VolumesBackupsAdminV2Test, cls).resource_setup()
Rohan Kanade05749152015-01-30 17:15:18 +053041
Giulio Fidente74b08ad2014-01-18 04:02:51 +010042 cls.volume = cls.create_volume()
43
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +000044 def _delete_backup(self, backup_id):
bkopilov62d21752016-06-08 10:16:11 +030045 self.admin_backups_client.delete_backup(backup_id)
Ken'ichi Ohmichi153b3d92016-08-03 14:35:46 -070046 self.admin_backups_client.wait_for_resource_deletion(backup_id)
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +000047
Gorka Eguileor9de20c12015-08-13 11:16:43 +020048 def _decode_url(self, backup_url):
49 return json.loads(base64.decodestring(backup_url))
50
51 def _encode_backup(self, backup):
52 retval = json.dumps(backup)
53 if six.PY3:
54 retval = retval.encode('utf-8')
55 return base64.encodestring(retval)
56
57 def _modify_backup_url(self, backup_url, changes):
58 backup = self._decode_url(backup_url)
59 backup.update(changes)
60 return self._encode_backup(backup)
61
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +000062 @test.idempotent_id('a99c54a1-dd80-4724-8a13-13bf58d4068d')
63 def test_volume_backup_export_import(self):
Gorka Eguileor9de20c12015-08-13 11:16:43 +020064 """Test backup export import functionality.
65
66 Cinder allows exporting DB backup information through its API so it can
67 be imported back in case of a DB loss.
68 """
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +000069 # Create backup
70 backup_name = data_utils.rand_name('Backup')
bkopilov62d21752016-06-08 10:16:11 +030071 backup = (self.admin_backups_client.create_backup(
Ghanshyam4a9e3032015-12-10 17:50:54 +090072 volume_id=self.volume['id'], name=backup_name)['backup'])
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +000073 self.addCleanup(self._delete_backup, backup['id'])
74 self.assertEqual(backup_name, backup['name'])
bkopilov62d21752016-06-08 10:16:11 +030075 self.admin_backups_client.wait_for_backup_status(backup['id'],
76 'available')
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +000077
78 # Export Backup
bkopilov62d21752016-06-08 10:16:11 +030079 export_backup = (self.admin_backups_client.export_backup(backup['id'])
John Warren6cadeee2015-08-13 17:00:56 +000080 ['backup-record'])
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +000081 self.assertIn('backup_service', export_backup)
82 self.assertIn('backup_url', export_backup)
83 self.assertTrue(export_backup['backup_service'].startswith(
84 'cinder.backup.drivers'))
85 self.assertIsNotNone(export_backup['backup_url'])
86
Gorka Eguileor9de20c12015-08-13 11:16:43 +020087 # NOTE(geguileo): Backups are imported with the same backup id
88 # (important for incremental backups among other things), so we cannot
89 # import the exported backup information as it is, because that Backup
90 # ID already exists. So we'll fake the data by changing the backup id
91 # in the exported backup DB info we have retrieved before importing it
92 # back.
93 new_id = data_utils.rand_uuid()
94 new_url = self._modify_backup_url(
95 export_backup['backup_url'], {'id': new_id})
96
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +000097 # Import Backup
bkopilov62d21752016-06-08 10:16:11 +030098 import_backup = self.admin_backups_client.import_backup(
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +000099 backup_service=export_backup['backup_service'],
Gorka Eguileor9de20c12015-08-13 11:16:43 +0200100 backup_url=new_url)['backup']
101
102 # NOTE(geguileo): We delete both backups, but only one of those
103 # deletions will delete data from the backup back-end because they
104 # were both pointing to the same backend data.
105 self.addCleanup(self._delete_backup, new_id)
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +0000106 self.assertIn("id", import_backup)
Gorka Eguileor9de20c12015-08-13 11:16:43 +0200107 self.assertEqual(new_id, import_backup['id'])
bkopilov62d21752016-06-08 10:16:11 +0300108 self.admin_backups_client.wait_for_backup_status(import_backup['id'],
109 'available')
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +0000110
111 # Verify Import Backup
bkopilov62d21752016-06-08 10:16:11 +0300112 backups = self.admin_backups_client.list_backups(
113 detail=True)['backups']
Gorka Eguileor9de20c12015-08-13 11:16:43 +0200114 self.assertIn(new_id, [b['id'] for b in backups])
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +0000115
116 # Restore backup
bkopilov62d21752016-06-08 10:16:11 +0300117 restore = self.admin_backups_client.restore_backup(
Gorka Eguileor9de20c12015-08-13 11:16:43 +0200118 backup['id'])['restore']
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +0000119 self.addCleanup(self.admin_volume_client.delete_volume,
120 restore['volume_id'])
Gorka Eguileor9de20c12015-08-13 11:16:43 +0200121 self.assertEqual(backup['id'], restore['backup_id'])
Yaroslav Lobankoved3a35b2016-03-24 22:41:30 -0500122 waiters.wait_for_volume_status(self.admin_volume_client,
123 restore['volume_id'], 'available')
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +0000124
125 # Verify if restored volume is there in volume list
John Warren6177c9e2015-08-19 20:00:17 +0000126 volumes = self.admin_volume_client.list_volumes()['volumes']
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +0000127 self.assertIn(restore['volume_id'], [v['id'] for v in volumes])
bkopilov62d21752016-06-08 10:16:11 +0300128 self.admin_backups_client.wait_for_backup_status(import_backup['id'],
129 'available')
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +0000130
bkopilov19fc5fd2016-07-06 12:02:18 +0300131 @test.idempotent_id('47a35425-a891-4e13-961c-c45deea21e94')
132 def test_volume_backup_reset_status(self):
133 # Create a backup
134 backup_name = data_utils.rand_name('Backup')
135 backup = self.admin_backups_client.create_backup(
136 volume_id=self.volume['id'], name=backup_name)['backup']
137 self.addCleanup(self.admin_backups_client.delete_backup,
138 backup['id'])
139 self.assertEqual(backup_name, backup['name'])
140 self.admin_backups_client.wait_for_backup_status(backup['id'],
141 'available')
142 # Reset backup status to error
143 self.admin_backups_client.reset_backup_status(backup_id=backup['id'],
144 status="error")
145 self.admin_backups_client.wait_for_backup_status(backup['id'],
146 'error')
147
jun xieebc3da32014-11-18 14:34:56 +0800148
lkuchlan9dea88e2016-06-07 17:12:01 +0300149class VolumesBackupsAdminV1Test(VolumesBackupsAdminV2Test):
jun xieebc3da32014-11-18 14:34:56 +0800150 _api_version = 1