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:
Victor Stinner 2015-10-07 23:44:46 +02:00
parent 08b6b23cad
commit 34b0ea07c4
2 changed files with 32 additions and 35 deletions

View File

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

View File

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