Merge "Convert create_backup v3 plugin to v2.1 API"
This commit is contained in:
@@ -1,7 +1,7 @@
|
||||
{
|
||||
"create_backup": {
|
||||
"createBackup": {
|
||||
"name": "Backup 1",
|
||||
"backup_type": "daily",
|
||||
"rotation": 1
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@@ -35,7 +35,7 @@ class CreateBackupController(wsgi.Controller):
|
||||
self.compute_api = compute.API()
|
||||
|
||||
@extensions.expected_errors((400, 403, 404, 409))
|
||||
@wsgi.action('create_backup')
|
||||
@wsgi.action('createBackup')
|
||||
@validation.schema(create_backup.create_backup)
|
||||
def _create_backup(self, req, id, body):
|
||||
"""Backup a server instance.
|
||||
@@ -50,7 +50,7 @@ class CreateBackupController(wsgi.Controller):
|
||||
"""
|
||||
context = req.environ["nova.context"]
|
||||
authorize(context)
|
||||
entity = body["create_backup"]
|
||||
entity = body["createBackup"]
|
||||
|
||||
image_name = entity["name"]
|
||||
backup_type = entity["backup_type"]
|
||||
@@ -69,7 +69,7 @@ class CreateBackupController(wsgi.Controller):
|
||||
backup_type, rotation, extra_properties=props)
|
||||
except exception.InstanceInvalidState as state_error:
|
||||
common.raise_http_conflict_for_instance_invalid_state(state_error,
|
||||
'create_backup')
|
||||
'createBackup')
|
||||
|
||||
resp = webob.Response(status_int=202)
|
||||
|
||||
|
@@ -18,7 +18,7 @@ from nova.api.validation import parameter_types
|
||||
create_backup = {
|
||||
'type': 'object',
|
||||
'properties': {
|
||||
'create_backup': {
|
||||
'createBackup': {
|
||||
'type': 'object',
|
||||
'properties': {
|
||||
'name': parameter_types.name,
|
||||
@@ -39,6 +39,6 @@ create_backup = {
|
||||
'additionalProperties': False,
|
||||
},
|
||||
},
|
||||
'required': ['create_backup'],
|
||||
'required': ['createBackup'],
|
||||
'additionalProperties': False,
|
||||
}
|
||||
|
@@ -50,7 +50,7 @@ class CreateBackupTests(admin_only_action_common.CommonMixin,
|
||||
def test_create_backup_with_metadata(self):
|
||||
metadata = {'123': 'asdf'}
|
||||
body = {
|
||||
'create_backup': {
|
||||
'createBackup': {
|
||||
'name': 'Backup 1',
|
||||
'backup_type': 'daily',
|
||||
'rotation': 1,
|
||||
@@ -76,7 +76,7 @@ class CreateBackupTests(admin_only_action_common.CommonMixin,
|
||||
def test_create_backup_no_name(self):
|
||||
# Name is required for backups.
|
||||
body = {
|
||||
'create_backup': {
|
||||
'createBackup': {
|
||||
'backup_type': 'daily',
|
||||
'rotation': 1,
|
||||
},
|
||||
@@ -87,7 +87,7 @@ class CreateBackupTests(admin_only_action_common.CommonMixin,
|
||||
def test_create_backup_no_rotation(self):
|
||||
# Rotation is required for backup requests.
|
||||
body = {
|
||||
'create_backup': {
|
||||
'createBackup': {
|
||||
'name': 'Backup 1',
|
||||
'backup_type': 'daily',
|
||||
},
|
||||
@@ -100,7 +100,7 @@ class CreateBackupTests(admin_only_action_common.CommonMixin,
|
||||
for backup requests
|
||||
"""
|
||||
body = {
|
||||
'create_backup': {
|
||||
'createBackup': {
|
||||
'name': 'Backup 1',
|
||||
'backup_type': 'daily',
|
||||
'rotation': -1,
|
||||
@@ -111,7 +111,7 @@ class CreateBackupTests(admin_only_action_common.CommonMixin,
|
||||
|
||||
def test_create_backup_negative_rotation_with_string_number(self):
|
||||
body = {
|
||||
'create_backup': {
|
||||
'createBackup': {
|
||||
'name': 'Backup 1',
|
||||
'backup_type': 'daily',
|
||||
'rotation': '-1',
|
||||
@@ -123,7 +123,7 @@ class CreateBackupTests(admin_only_action_common.CommonMixin,
|
||||
def test_create_backup_no_backup_type(self):
|
||||
# Backup Type (daily or weekly) is required for backup requests.
|
||||
body = {
|
||||
'create_backup': {
|
||||
'createBackup': {
|
||||
'name': 'Backup 1',
|
||||
'rotation': 1,
|
||||
},
|
||||
@@ -133,7 +133,7 @@ class CreateBackupTests(admin_only_action_common.CommonMixin,
|
||||
|
||||
def test_create_backup_non_dict_metadata(self):
|
||||
body = {
|
||||
'create_backup': {
|
||||
'createBackup': {
|
||||
'name': 'Backup 1',
|
||||
'backup_type': 'daily',
|
||||
'rotation': 1,
|
||||
@@ -144,14 +144,14 @@ class CreateBackupTests(admin_only_action_common.CommonMixin,
|
||||
self.assertEqual(400, res.status_int)
|
||||
|
||||
def test_create_backup_bad_entity(self):
|
||||
body = {'create_backup': 'go'}
|
||||
body = {'createBackup': 'go'}
|
||||
res = self._make_request(self._make_url(), body)
|
||||
self.assertEqual(400, res.status_int)
|
||||
|
||||
def test_create_backup_rotation_is_zero(self):
|
||||
# The happy path for creating backups if rotation is zero.
|
||||
body = {
|
||||
'create_backup': {
|
||||
'createBackup': {
|
||||
'name': 'Backup 1',
|
||||
'backup_type': 'daily',
|
||||
'rotation': 0,
|
||||
@@ -175,7 +175,7 @@ class CreateBackupTests(admin_only_action_common.CommonMixin,
|
||||
def test_create_backup_rotation_is_positive(self):
|
||||
# The happy path for creating backups if rotation is positive.
|
||||
body = {
|
||||
'create_backup': {
|
||||
'createBackup': {
|
||||
'name': 'Backup 1',
|
||||
'backup_type': 'daily',
|
||||
'rotation': 1,
|
||||
@@ -198,7 +198,7 @@ class CreateBackupTests(admin_only_action_common.CommonMixin,
|
||||
|
||||
def test_create_backup_rotation_is_string_number(self):
|
||||
body = {
|
||||
'create_backup': {
|
||||
'createBackup': {
|
||||
'name': 'Backup 1',
|
||||
'backup_type': 'daily',
|
||||
'rotation': '1',
|
||||
@@ -221,37 +221,37 @@ class CreateBackupTests(admin_only_action_common.CommonMixin,
|
||||
|
||||
def test_create_backup_raises_conflict_on_invalid_state(self):
|
||||
body_map = {
|
||||
'create_backup': {
|
||||
'createBackup': {
|
||||
'name': 'Backup 1',
|
||||
'backup_type': 'daily',
|
||||
'rotation': 1,
|
||||
},
|
||||
}
|
||||
args_map = {
|
||||
'create_backup': (
|
||||
'createBackup': (
|
||||
('Backup 1', 'daily', 1), {'extra_properties': {}}
|
||||
),
|
||||
}
|
||||
common.check_img_metadata_properties_quota(self.context, {})
|
||||
self._test_invalid_state('create_backup', method='backup',
|
||||
self._test_invalid_state('createBackup', method='backup',
|
||||
body_map=body_map,
|
||||
compute_api_args_map=args_map)
|
||||
|
||||
def test_create_backup_with_non_existed_instance(self):
|
||||
body_map = {
|
||||
'create_backup': {
|
||||
'createBackup': {
|
||||
'name': 'Backup 1',
|
||||
'backup_type': 'daily',
|
||||
'rotation': 1,
|
||||
},
|
||||
}
|
||||
common.check_img_metadata_properties_quota(self.context, {})
|
||||
self._test_non_existing_instance('create_backup',
|
||||
self._test_non_existing_instance('createBackup',
|
||||
body_map=body_map)
|
||||
|
||||
def test_create_backup_with_invalid_create_backup(self):
|
||||
body = {
|
||||
'create_backupup': {
|
||||
'createBackupup': {
|
||||
'name': 'Backup 1',
|
||||
'backup_type': 'daily',
|
||||
'rotation': 1,
|
||||
|
@@ -1,5 +1,5 @@
|
||||
{
|
||||
"create_backup": {
|
||||
"createBackup": {
|
||||
"name": "Backup 1",
|
||||
"backup_type": "daily",
|
||||
"rotation": 1
|
||||
|
Reference in New Issue
Block a user