Port API admin action tests to Python 3
* Replace ast.literal_eval(response.body) with response.json * Use oslo_serialization.jsonutils.dump_as_bytes() to encode the response to JSON as bytes for the HTTP body. * tests-py3.txt: add cinder.tests.unit.api.contrib.test_admin_actions Partial-Implements: blueprint cinder-python3 Change-Id: Ib30c701b9dbbcc774dfc5f19a7174ab318006206
This commit is contained in:
parent
08b6b23cad
commit
34b0ea07c4
@ -10,8 +10,6 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
import ast
|
|
||||||
|
|
||||||
import fixtures
|
import fixtures
|
||||||
import mock
|
import mock
|
||||||
from oslo_concurrency import lockutils
|
from oslo_concurrency import lockutils
|
||||||
@ -77,8 +75,7 @@ class AdminActionsTest(test.TestCase):
|
|||||||
req = webob.Request.blank('/v2/fake/volumes/%s/action' % volume['id'])
|
req = webob.Request.blank('/v2/fake/volumes/%s/action' % volume['id'])
|
||||||
req.method = 'POST'
|
req.method = 'POST'
|
||||||
req.headers['content-type'] = 'application/json'
|
req.headers['content-type'] = 'application/json'
|
||||||
req.body = \
|
req.body = jsonutils.dump_as_bytes({'os-reset_status': updated_status})
|
||||||
jsonutils.dumps({'os-reset_status': updated_status})
|
|
||||||
req.environ['cinder.context'] = ctx
|
req.environ['cinder.context'] = ctx
|
||||||
resp = req.get_response(app())
|
resp = req.get_response(app())
|
||||||
return resp
|
return resp
|
||||||
@ -88,8 +85,7 @@ class AdminActionsTest(test.TestCase):
|
|||||||
snapshot.id)
|
snapshot.id)
|
||||||
req.method = 'POST'
|
req.method = 'POST'
|
||||||
req.headers['content-type'] = 'application/json'
|
req.headers['content-type'] = 'application/json'
|
||||||
req.body = \
|
req.body = jsonutils.dump_as_bytes({'os-reset_status': updated_status})
|
||||||
jsonutils.dumps({'os-reset_status': updated_status})
|
|
||||||
req.environ['cinder.context'] = ctx
|
req.environ['cinder.context'] = ctx
|
||||||
resp = req.get_response(app())
|
resp = req.get_response(app())
|
||||||
return resp
|
return resp
|
||||||
@ -98,8 +94,7 @@ class AdminActionsTest(test.TestCase):
|
|||||||
req = webob.Request.blank('/v2/fake/backups/%s/action' % backup['id'])
|
req = webob.Request.blank('/v2/fake/backups/%s/action' % backup['id'])
|
||||||
req.method = 'POST'
|
req.method = 'POST'
|
||||||
req.headers['content-type'] = 'application/json'
|
req.headers['content-type'] = 'application/json'
|
||||||
req.body = \
|
req.body = jsonutils.dump_as_bytes({'os-reset_status': updated_status})
|
||||||
jsonutils.dumps({'os-reset_status': updated_status})
|
|
||||||
req.environ['cinder.context'] = ctx
|
req.environ['cinder.context'] = ctx
|
||||||
resp = req.get_response(app())
|
resp = req.get_response(app())
|
||||||
return resp
|
return resp
|
||||||
@ -297,8 +292,8 @@ class AdminActionsTest(test.TestCase):
|
|||||||
'missing-volume-id')
|
'missing-volume-id')
|
||||||
req.method = 'POST'
|
req.method = 'POST'
|
||||||
req.headers['content-type'] = 'application/json'
|
req.headers['content-type'] = 'application/json'
|
||||||
req.body = jsonutils.dumps({'os-reset_status': {'status':
|
body = {'os-reset_status': {'status': 'available'}}
|
||||||
'available'}})
|
req.body = jsonutils.dump_as_bytes(body)
|
||||||
req.environ['cinder.context'] = ctx
|
req.environ['cinder.context'] = ctx
|
||||||
resp = req.get_response(app())
|
resp = req.get_response(app())
|
||||||
self.assertEqual(404, resp.status_int)
|
self.assertEqual(404, resp.status_int)
|
||||||
@ -384,7 +379,7 @@ class AdminActionsTest(test.TestCase):
|
|||||||
req = webob.Request.blank('/v2/fake/volumes/%s/action' % volume['id'])
|
req = webob.Request.blank('/v2/fake/volumes/%s/action' % volume['id'])
|
||||||
req.method = 'POST'
|
req.method = 'POST'
|
||||||
req.headers['content-type'] = 'application/json'
|
req.headers['content-type'] = 'application/json'
|
||||||
req.body = jsonutils.dumps({'os-force_delete': {}})
|
req.body = jsonutils.dump_as_bytes({'os-force_delete': {}})
|
||||||
# attach admin context to request
|
# attach admin context to request
|
||||||
req.environ['cinder.context'] = ctx
|
req.environ['cinder.context'] = ctx
|
||||||
resp = req.get_response(app())
|
resp = req.get_response(app())
|
||||||
@ -411,7 +406,7 @@ class AdminActionsTest(test.TestCase):
|
|||||||
req = webob.Request.blank(path)
|
req = webob.Request.blank(path)
|
||||||
req.method = 'POST'
|
req.method = 'POST'
|
||||||
req.headers['content-type'] = 'application/json'
|
req.headers['content-type'] = 'application/json'
|
||||||
req.body = jsonutils.dumps({'os-force_delete': {}})
|
req.body = jsonutils.dump_as_bytes({'os-force_delete': {}})
|
||||||
# attach admin context to request
|
# attach admin context to request
|
||||||
req.environ['cinder.context'] = ctx
|
req.environ['cinder.context'] = ctx
|
||||||
resp = req.get_response(app())
|
resp = req.get_response(app())
|
||||||
@ -451,9 +446,9 @@ class AdminActionsTest(test.TestCase):
|
|||||||
req.method = 'POST'
|
req.method = 'POST'
|
||||||
req.headers['content-type'] = 'application/json'
|
req.headers['content-type'] = 'application/json'
|
||||||
# request status of 'error'
|
# request status of 'error'
|
||||||
req.body = jsonutils.dumps({'os-force_detach':
|
body = {'os-force_detach': {'attachment_id': attachment['id'],
|
||||||
{'attachment_id': attachment['id'],
|
'connector': connector}}
|
||||||
'connector': connector}})
|
req.body = jsonutils.dump_as_bytes(body)
|
||||||
# attach admin context to request
|
# attach admin context to request
|
||||||
req.environ['cinder.context'] = ctx
|
req.environ['cinder.context'] = ctx
|
||||||
# make request
|
# make request
|
||||||
@ -509,9 +504,9 @@ class AdminActionsTest(test.TestCase):
|
|||||||
req.method = 'POST'
|
req.method = 'POST'
|
||||||
req.headers['content-type'] = 'application/json'
|
req.headers['content-type'] = 'application/json'
|
||||||
# request status of 'error'
|
# request status of 'error'
|
||||||
req.body = jsonutils.dumps({'os-force_detach':
|
body = {'os-force_detach': {'attachment_id': attachment['id'],
|
||||||
{'attachment_id': attachment['id'],
|
'connector': connector}}
|
||||||
'connector': connector}})
|
req.body = jsonutils.dump_as_bytes(body)
|
||||||
# attach admin context to request
|
# attach admin context to request
|
||||||
req.environ['cinder.context'] = ctx
|
req.environ['cinder.context'] = ctx
|
||||||
# make request
|
# make request
|
||||||
@ -569,8 +564,8 @@ class AdminActionsTest(test.TestCase):
|
|||||||
volume['id'])
|
volume['id'])
|
||||||
req.method = 'POST'
|
req.method = 'POST'
|
||||||
req.headers['content-type'] = 'application/json'
|
req.headers['content-type'] = 'application/json'
|
||||||
req.body = jsonutils.dumps({'os-force_detach':
|
body = {'os-force_detach': {'attachment_id': 'fake'}}
|
||||||
{'attachment_id': 'fake'}})
|
req.body = jsonutils.dump_as_bytes(body)
|
||||||
# attach admin context to request
|
# attach admin context to request
|
||||||
req.environ['cinder.context'] = ctx
|
req.environ['cinder.context'] = ctx
|
||||||
# make request
|
# make request
|
||||||
@ -586,8 +581,8 @@ class AdminActionsTest(test.TestCase):
|
|||||||
volume['id'])
|
volume['id'])
|
||||||
req.method = 'POST'
|
req.method = 'POST'
|
||||||
req.headers['content-type'] = 'application/json'
|
req.headers['content-type'] = 'application/json'
|
||||||
req.body = jsonutils.dumps({'os-force_detach':
|
body = {'os-force_detach': {'attachment_id': 'fake'}}
|
||||||
{'attachment_id': 'fake'}})
|
req.body = jsonutils.dump_as_bytes(body)
|
||||||
# attach admin context to request
|
# attach admin context to request
|
||||||
req.environ['cinder.context'] = ctx
|
req.environ['cinder.context'] = ctx
|
||||||
# make request
|
# make request
|
||||||
@ -604,9 +599,9 @@ class AdminActionsTest(test.TestCase):
|
|||||||
volume['id'])
|
volume['id'])
|
||||||
req.method = 'POST'
|
req.method = 'POST'
|
||||||
req.headers['content-type'] = 'application/json'
|
req.headers['content-type'] = 'application/json'
|
||||||
req.body = jsonutils.dumps({'os-force_detach':
|
body = {'os-force_detach': {'attachment_id': 'fake',
|
||||||
{'attachment_id': 'fake',
|
'connector': connector}}
|
||||||
'connector': connector}})
|
req.body = jsonutils.dump_as_bytes(body)
|
||||||
|
|
||||||
# attach admin context to request
|
# attach admin context to request
|
||||||
req.environ['cinder.context'] = ctx
|
req.environ['cinder.context'] = ctx
|
||||||
@ -656,9 +651,9 @@ class AdminActionsTest(test.TestCase):
|
|||||||
volume['id'])
|
volume['id'])
|
||||||
req.method = 'POST'
|
req.method = 'POST'
|
||||||
req.headers['content-type'] = 'application/json'
|
req.headers['content-type'] = 'application/json'
|
||||||
req.body = jsonutils.dumps({'os-force_detach':
|
body = {'os-force_detach': {'attachment_id': 'fake',
|
||||||
{'attachment_id': 'fake',
|
'connector': connector}}
|
||||||
'connector': connector}})
|
req.body = jsonutils.dump_as_bytes(body)
|
||||||
# attach admin context to request
|
# attach admin context to request
|
||||||
req.environ['cinder.context'] = ctx
|
req.environ['cinder.context'] = ctx
|
||||||
# make request
|
# make request
|
||||||
@ -820,7 +815,7 @@ class AdminActionsTest(test.TestCase):
|
|||||||
req.headers['content-type'] = 'application/json'
|
req.headers['content-type'] = 'application/json'
|
||||||
body = {'os-migrate_volume': {'host': host,
|
body = {'os-migrate_volume': {'host': host,
|
||||||
'force_host_copy': force_host_copy}}
|
'force_host_copy': force_host_copy}}
|
||||||
req.body = jsonutils.dumps(body)
|
req.body = jsonutils.dump_as_bytes(body)
|
||||||
req.environ['cinder.context'] = ctx
|
req.environ['cinder.context'] = ctx
|
||||||
resp = req.get_response(app())
|
resp = req.get_response(app())
|
||||||
# verify status
|
# verify status
|
||||||
@ -868,7 +863,7 @@ class AdminActionsTest(test.TestCase):
|
|||||||
req.headers['content-type'] = 'application/json'
|
req.headers['content-type'] = 'application/json'
|
||||||
body = {'os-migrate_volume': {'host': host,
|
body = {'os-migrate_volume': {'host': host,
|
||||||
'force_host_copy': False}}
|
'force_host_copy': False}}
|
||||||
req.body = jsonutils.dumps(body)
|
req.body = jsonutils.dump_as_bytes(body)
|
||||||
req.environ['cinder.context'] = ctx
|
req.environ['cinder.context'] = ctx
|
||||||
resp = req.get_response(app())
|
resp = req.get_response(app())
|
||||||
# verify status
|
# verify status
|
||||||
@ -922,12 +917,13 @@ class AdminActionsTest(test.TestCase):
|
|||||||
req.headers['content-type'] = 'application/json'
|
req.headers['content-type'] = 'application/json'
|
||||||
body = {'new_volume': new_volume['id'], 'error': error}
|
body = {'new_volume': new_volume['id'], 'error': error}
|
||||||
if no_body:
|
if no_body:
|
||||||
req.body = jsonutils.dumps({'': body})
|
body = {'': body}
|
||||||
else:
|
else:
|
||||||
req.body = jsonutils.dumps({'os-migrate_volume_completion': body})
|
body = {'os-migrate_volume_completion': body}
|
||||||
|
req.body = jsonutils.dump_as_bytes(body)
|
||||||
req.environ['cinder.context'] = ctx
|
req.environ['cinder.context'] = ctx
|
||||||
resp = req.get_response(app())
|
resp = req.get_response(app())
|
||||||
resp_dict = ast.literal_eval(resp.body)
|
resp_dict = resp.json
|
||||||
# verify status
|
# verify status
|
||||||
self.assertEqual(expected_status, resp.status_int)
|
self.assertEqual(expected_status, resp.status_int)
|
||||||
if expected_id:
|
if expected_id:
|
||||||
@ -1024,7 +1020,7 @@ class AdminActionsTest(test.TestCase):
|
|||||||
req = webob.Request.blank('/v2/fake/backups/%s/action' % id)
|
req = webob.Request.blank('/v2/fake/backups/%s/action' % id)
|
||||||
req.method = 'POST'
|
req.method = 'POST'
|
||||||
req.headers['Content-Type'] = 'application/json'
|
req.headers['Content-Type'] = 'application/json'
|
||||||
req.body = jsonutils.dumps({'os-force_delete': {}})
|
req.body = jsonutils.dump_as_bytes({'os-force_delete': {}})
|
||||||
req.environ['cinder.context'] = ctx
|
req.environ['cinder.context'] = ctx
|
||||||
res = req.get_response(app())
|
res = req.get_response(app())
|
||||||
|
|
||||||
@ -1062,7 +1058,7 @@ class AdminActionsTest(test.TestCase):
|
|||||||
req = webob.Request.blank('/v2/fake/backups/%s/action' % id)
|
req = webob.Request.blank('/v2/fake/backups/%s/action' % id)
|
||||||
req.method = 'POST'
|
req.method = 'POST'
|
||||||
req.headers['Content-Type'] = 'application/json'
|
req.headers['Content-Type'] = 'application/json'
|
||||||
req.body = jsonutils.dumps({'os-force_delete': {}})
|
req.body = jsonutils.dump_as_bytes({'os-force_delete': {}})
|
||||||
req.environ['cinder.context'] = ctx
|
req.environ['cinder.context'] = ctx
|
||||||
res = req.get_response(app())
|
res = req.get_response(app())
|
||||||
self.assertEqual(405, res.status_int)
|
self.assertEqual(405, res.status_int)
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
cinder.tests.unit.api.contrib.test_admin_actions
|
||||||
cinder.tests.unit.api.contrib.test_availability_zones
|
cinder.tests.unit.api.contrib.test_availability_zones
|
||||||
cinder.tests.unit.api.contrib.test_capabilities
|
cinder.tests.unit.api.contrib.test_capabilities
|
||||||
cinder.tests.unit.api.contrib.test_extended_snapshot_attributes
|
cinder.tests.unit.api.contrib.test_extended_snapshot_attributes
|
||||||
|
Loading…
Reference in New Issue
Block a user