blob: b144c7c49a6bdadf3f48f0948ef2e2a7b8e6fc75 [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)
46 self.admin_backups_client.wait_for_backup_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
Chris Hoge7579c1a2015-02-26 14:12:15 -080062 @test.idempotent_id('a66eb488-8ee1-47d4-8e9f-575a095728c6')
raiesmh08f04da342014-02-28 17:14:43 +053063 def test_volume_backup_create_get_detailed_list_restore_delete(self):
64 # Create backup
Giulio Fidente74b08ad2014-01-18 04:02:51 +010065 backup_name = data_utils.rand_name('Backup')
bkopilov62d21752016-06-08 10:16:11 +030066 create_backup = self.admin_backups_client.create_backup
Ghanshyam4a9e3032015-12-10 17:50:54 +090067 backup = create_backup(volume_id=self.volume['id'],
John Warren6cadeee2015-08-13 17:00:56 +000068 name=backup_name)['backup']
bkopilov62d21752016-06-08 10:16:11 +030069 self.addCleanup(self.admin_backups_client.delete_backup,
Giulio Fidente74b08ad2014-01-18 04:02:51 +010070 backup['id'])
raiesmh08f04da342014-02-28 17:14:43 +053071 self.assertEqual(backup_name, backup['name'])
Yaroslav Lobankoved3a35b2016-03-24 22:41:30 -050072 waiters.wait_for_volume_status(self.admin_volume_client,
73 self.volume['id'], 'available')
bkopilov62d21752016-06-08 10:16:11 +030074 self.admin_backups_client.wait_for_backup_status(backup['id'],
75 'available')
Giulio Fidente74b08ad2014-01-18 04:02:51 +010076
raiesmh08f04da342014-02-28 17:14:43 +053077 # Get a given backup
bkopilov62d21752016-06-08 10:16:11 +030078 backup = self.admin_backups_client.show_backup(backup['id'])['backup']
raiesmh08f04da342014-02-28 17:14:43 +053079 self.assertEqual(backup_name, backup['name'])
Giulio Fidente74b08ad2014-01-18 04:02:51 +010080
raiesmh08f04da342014-02-28 17:14:43 +053081 # Get all backups with detail
bkopilov62d21752016-06-08 10:16:11 +030082 backups = self.admin_backups_client.list_backups(
83 detail=True)['backups']
raiesmh08f04da342014-02-28 17:14:43 +053084 self.assertIn((backup['name'], backup['id']),
85 [(m['name'], m['id']) for m in backups])
86
87 # Restore backup
bkopilov62d21752016-06-08 10:16:11 +030088 restore = self.admin_backups_client.restore_backup(
John Warren6cadeee2015-08-13 17:00:56 +000089 backup['id'])['restore']
raiesmh08f04da342014-02-28 17:14:43 +053090
91 # Delete backup
Chandan Kumaree3f4bd2014-10-29 23:09:29 +053092 self.addCleanup(self.admin_volume_client.delete_volume,
Giulio Fidente74b08ad2014-01-18 04:02:51 +010093 restore['volume_id'])
raiesmh08f04da342014-02-28 17:14:43 +053094 self.assertEqual(backup['id'], restore['backup_id'])
bkopilov62d21752016-06-08 10:16:11 +030095 self.admin_backups_client.wait_for_backup_status(backup['id'],
96 'available')
Yaroslav Lobankoved3a35b2016-03-24 22:41:30 -050097 waiters.wait_for_volume_status(self.admin_volume_client,
98 restore['volume_id'], 'available')
jun xieebc3da32014-11-18 14:34:56 +080099
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +0000100 @test.idempotent_id('a99c54a1-dd80-4724-8a13-13bf58d4068d')
101 def test_volume_backup_export_import(self):
Gorka Eguileor9de20c12015-08-13 11:16:43 +0200102 """Test backup export import functionality.
103
104 Cinder allows exporting DB backup information through its API so it can
105 be imported back in case of a DB loss.
106 """
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +0000107 # Create backup
108 backup_name = data_utils.rand_name('Backup')
bkopilov62d21752016-06-08 10:16:11 +0300109 backup = (self.admin_backups_client.create_backup(
Ghanshyam4a9e3032015-12-10 17:50:54 +0900110 volume_id=self.volume['id'], name=backup_name)['backup'])
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +0000111 self.addCleanup(self._delete_backup, backup['id'])
112 self.assertEqual(backup_name, backup['name'])
bkopilov62d21752016-06-08 10:16:11 +0300113 self.admin_backups_client.wait_for_backup_status(backup['id'],
114 'available')
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +0000115
116 # Export Backup
bkopilov62d21752016-06-08 10:16:11 +0300117 export_backup = (self.admin_backups_client.export_backup(backup['id'])
John Warren6cadeee2015-08-13 17:00:56 +0000118 ['backup-record'])
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +0000119 self.assertIn('backup_service', export_backup)
120 self.assertIn('backup_url', export_backup)
121 self.assertTrue(export_backup['backup_service'].startswith(
122 'cinder.backup.drivers'))
123 self.assertIsNotNone(export_backup['backup_url'])
124
Gorka Eguileor9de20c12015-08-13 11:16:43 +0200125 # NOTE(geguileo): Backups are imported with the same backup id
126 # (important for incremental backups among other things), so we cannot
127 # import the exported backup information as it is, because that Backup
128 # ID already exists. So we'll fake the data by changing the backup id
129 # in the exported backup DB info we have retrieved before importing it
130 # back.
131 new_id = data_utils.rand_uuid()
132 new_url = self._modify_backup_url(
133 export_backup['backup_url'], {'id': new_id})
134
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +0000135 # Import Backup
bkopilov62d21752016-06-08 10:16:11 +0300136 import_backup = self.admin_backups_client.import_backup(
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +0000137 backup_service=export_backup['backup_service'],
Gorka Eguileor9de20c12015-08-13 11:16:43 +0200138 backup_url=new_url)['backup']
139
140 # NOTE(geguileo): We delete both backups, but only one of those
141 # deletions will delete data from the backup back-end because they
142 # were both pointing to the same backend data.
143 self.addCleanup(self._delete_backup, new_id)
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +0000144 self.assertIn("id", import_backup)
Gorka Eguileor9de20c12015-08-13 11:16:43 +0200145 self.assertEqual(new_id, import_backup['id'])
bkopilov62d21752016-06-08 10:16:11 +0300146 self.admin_backups_client.wait_for_backup_status(import_backup['id'],
147 'available')
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +0000148
149 # Verify Import Backup
bkopilov62d21752016-06-08 10:16:11 +0300150 backups = self.admin_backups_client.list_backups(
151 detail=True)['backups']
Gorka Eguileor9de20c12015-08-13 11:16:43 +0200152 self.assertIn(new_id, [b['id'] for b in backups])
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +0000153
154 # Restore backup
bkopilov62d21752016-06-08 10:16:11 +0300155 restore = self.admin_backups_client.restore_backup(
Gorka Eguileor9de20c12015-08-13 11:16:43 +0200156 backup['id'])['restore']
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +0000157 self.addCleanup(self.admin_volume_client.delete_volume,
158 restore['volume_id'])
Gorka Eguileor9de20c12015-08-13 11:16:43 +0200159 self.assertEqual(backup['id'], restore['backup_id'])
Yaroslav Lobankoved3a35b2016-03-24 22:41:30 -0500160 waiters.wait_for_volume_status(self.admin_volume_client,
161 restore['volume_id'], 'available')
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +0000162
163 # Verify if restored volume is there in volume list
John Warren6177c9e2015-08-19 20:00:17 +0000164 volumes = self.admin_volume_client.list_volumes()['volumes']
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +0000165 self.assertIn(restore['volume_id'], [v['id'] for v in volumes])
bkopilov62d21752016-06-08 10:16:11 +0300166 self.admin_backups_client.wait_for_backup_status(import_backup['id'],
167 'available')
ravikumar-venkatesan18c1d0e2015-03-18 11:28:37 +0000168
bkopilov19fc5fd2016-07-06 12:02:18 +0300169 @test.idempotent_id('47a35425-a891-4e13-961c-c45deea21e94')
170 def test_volume_backup_reset_status(self):
171 # Create a backup
172 backup_name = data_utils.rand_name('Backup')
173 backup = self.admin_backups_client.create_backup(
174 volume_id=self.volume['id'], name=backup_name)['backup']
175 self.addCleanup(self.admin_backups_client.delete_backup,
176 backup['id'])
177 self.assertEqual(backup_name, backup['name'])
178 self.admin_backups_client.wait_for_backup_status(backup['id'],
179 'available')
180 # Reset backup status to error
181 self.admin_backups_client.reset_backup_status(backup_id=backup['id'],
182 status="error")
183 self.admin_backups_client.wait_for_backup_status(backup['id'],
184 'error')
185
jun xieebc3da32014-11-18 14:34:56 +0800186
lkuchlan9dea88e2016-06-07 17:12:01 +0300187class VolumesBackupsAdminV1Test(VolumesBackupsAdminV2Test):
jun xieebc3da32014-11-18 14:34:56 +0800188 _api_version = 1