Add decode() function for string comparison.

A prefix of 'b' or 'B' is ignored in Python 2
But in py3 produce an instance of the bytes
type instead of the string type.

Due to which it gives following kind of error.
e.g.testtools.matchers._impl.MismatchError:
'unable to convert to int' not in
b'{"faultcode": "Client", "debuginfo": null,
"faultstring": "Invalid input for field/attribute limit.
Value: \'1.1\'. unable to convert to int"}'

Change-Id: I226e8f8c6afbbc94c6348a17099f02b9cf7907a8
Partially-Implements: blueprint mistral-py3
This commit is contained in:
hardik 2015-09-27 03:57:35 +05:30 committed by hparekh
parent aebd8e706b
commit 0ac5930bab
7 changed files with 25 additions and 18 deletions

View File

@ -102,7 +102,7 @@ class EnvironmentController(rest.RestController):
LOG.info("Create environment [env=%s]" % env)
self._validate_environment(
json.loads(wsme_pecan.pecan.request.body),
json.loads(wsme_pecan.pecan.request.body.decode()),
['name', 'description', 'variables']
)
@ -121,7 +121,7 @@ class EnvironmentController(rest.RestController):
LOG.info("Update environment [name=%s, env=%s]" % (env.name, env))
definition = json.loads(wsme_pecan.pecan.request.body)
definition = json.loads(wsme_pecan.pecan.request.body.decode())
definition.pop('name')
self._validate_environment(

View File

@ -304,7 +304,10 @@ class TestActionExecutionsController(base.FunctionalTest):
resp = self.app.delete('/v2/action_executions/123', expect_errors=True)
self.assertEqual(403, resp.status_int)
self.assertIn("Action execution deletion is not allowed", resp.body)
self.assertIn(
"Action execution deletion is not allowed",
resp.body.decode()
)
@mock.patch.object(db_api, 'get_action_execution', MOCK_ACTION)
def test_delete_action_exeuction_with_task(self):
@ -313,7 +316,10 @@ class TestActionExecutionsController(base.FunctionalTest):
resp = self.app.delete('/v2/action_executions/123', expect_errors=True)
self.assertEqual(403, resp.status_int)
self.assertIn("Only ad-hoc action execution can be deleted", resp.body)
self.assertIn(
"Only ad-hoc action execution can be deleted",
resp.body.decode()
)
@mock.patch.object(
db_api,
@ -328,5 +334,5 @@ class TestActionExecutionsController(base.FunctionalTest):
self.assertEqual(403, resp.status_int)
self.assertIn(
"Only completed action execution can be deleted",
resp.body
resp.body.decode()
)

View File

@ -303,7 +303,7 @@ class TestActionsController(base.FunctionalTest):
self.assertEqual(400, resp.status_int)
self.assertIn("Limit must be positive", resp.body)
self.assertIn("Limit must be positive", resp.body.decode())
def test_get_all_pagination_limit_not_integer(self):
resp = self.app.get(
@ -313,7 +313,7 @@ class TestActionsController(base.FunctionalTest):
self.assertEqual(400, resp.status_int)
self.assertIn("unable to convert to int", resp.body)
self.assertIn("unable to convert to int", resp.body.decode())
def test_get_all_pagination_invalid_sort_dirs_length(self):
resp = self.app.get(

View File

@ -274,7 +274,7 @@ class TestExecutionsController(base.FunctionalTest):
self.assertEqual(400, resp.status_int)
self.assertIn("Limit must be positive", resp.body)
self.assertIn("Limit must be positive", resp.body.decode())
def test_get_all_pagination_limit_not_integer(self):
resp = self.app.get(
@ -284,7 +284,7 @@ class TestExecutionsController(base.FunctionalTest):
self.assertEqual(400, resp.status_int)
self.assertIn("unable to convert to int", resp.body)
self.assertIn("unable to convert to int", resp.body.decode())
def test_get_all_pagination_invalid_sort_dirs_length(self):
resp = self.app.get(

View File

@ -146,7 +146,7 @@ class TestWorkbooksController(base.FunctionalTest):
)
self.assertEqual(400, resp.status_int)
self.assertIn("Invalid DSL", resp.body)
self.assertIn("Invalid DSL", resp.body.decode())
@mock.patch.object(workbooks, "create_workbook_v2", MOCK_WORKBOOK)
def test_post(self):
@ -179,7 +179,7 @@ class TestWorkbooksController(base.FunctionalTest):
)
self.assertEqual(400, resp.status_int)
self.assertIn("Invalid DSL", resp.body)
self.assertIn("Invalid DSL", resp.body.decode())
@mock.patch.object(db_api, "delete_workbook", MOCK_DELETE)
def test_delete(self):

View File

@ -254,7 +254,7 @@ class TestWorkflowsController(base.FunctionalTest):
)
self.assertEqual(400, resp.status_int)
self.assertIn("Invalid DSL", resp.body)
self.assertIn("Invalid DSL", resp.body.decode())
@mock.patch.object(db_api, "create_workflow_definition")
def test_post(self, mock_mtd):
@ -325,7 +325,7 @@ class TestWorkflowsController(base.FunctionalTest):
)
self.assertEqual(400, resp.status_int)
self.assertIn("Invalid DSL", resp.body)
self.assertIn("Invalid DSL", resp.body.decode())
@mock.patch.object(db_api, "delete_workflow_definition", MOCK_DELETE)
@mock.patch.object(db_api, "get_workflow_definition", MOCK_WF)
@ -398,7 +398,7 @@ class TestWorkflowsController(base.FunctionalTest):
self.assertEqual(400, resp.status_int)
self.assertIn("Limit must be positive", resp.body)
self.assertIn("Limit must be positive", resp.body.decode())
def test_get_all_pagination_limit_not_integer(self):
resp = self.app.get(
@ -408,7 +408,7 @@ class TestWorkflowsController(base.FunctionalTest):
self.assertEqual(400, resp.status_int)
self.assertIn("unable to convert to int", resp.body)
self.assertIn("unable to convert to int", resp.body.decode())
def test_get_all_pagination_invalid_sort_dirs_length(self):
resp = self.app.get(

View File

@ -14,6 +14,7 @@
import mock
from oslo_config import cfg
import six
from mistral import coordination
from mistral.tests import base
@ -94,7 +95,7 @@ class ServiceCoordinatorTest(base.BaseTest):
members = coordinator.get_members('fake_group')
self.assertEqual(1, len(members))
self.assertItemsEqual(('fake_id',), members)
self.assertItemsEqual((six.b('fake_id'),), members)
def test_join_group_and_leave_group(self):
cfg.CONF.set_default(
@ -113,7 +114,7 @@ class ServiceCoordinatorTest(base.BaseTest):
members_after = coordinator.get_members('fake_group')
self.assertEqual(1, len(members_before))
self.assertEqual(set(['fake_id']), members_before)
self.assertEqual(set([six.b('fake_id')]), members_before)
self.assertEqual(0, len(members_after))
self.assertEqual(set([]), members_after)
@ -144,4 +145,4 @@ class ServiceTest(base.BaseTest):
members = srv_coordinator.get_members('fake_group')
mock_get_identifier.assert_called_once_with()
self.assertEqual(set(['fake_id']), members)
self.assertEqual(set([six.b('fake_id')]), members)