Merge "Convert create_backup v3 plugin to v2.1 API"

This commit is contained in:
Jenkins
2014-08-28 09:07:47 +00:00
committed by Gerrit Code Review
5 changed files with 25 additions and 25 deletions

View File

@@ -1,7 +1,7 @@
{
"create_backup": {
"createBackup": {
"name": "Backup 1",
"backup_type": "daily",
"rotation": 1
}
}
}

View File

@@ -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)

View File

@@ -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,
}

View File

@@ -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,

View File

@@ -1,5 +1,5 @@
{
"create_backup": {
"createBackup": {
"name": "Backup 1",
"backup_type": "daily",
"rotation": 1