refactor: query json content

This commit is contained in:
debugtalk
2018-07-25 17:32:12 +08:00
parent fe9d5c497b
commit dee51b6682
7 changed files with 32 additions and 22 deletions

View File

@@ -201,13 +201,8 @@ class Context(object):
# format 1/2/3
check_value = self.eval_content(check_item)
else:
try:
# format 4/5
check_value = resp_obj.extract_field(check_item)
except exceptions.ParseResponseFailure:
msg = "failed to extract check item from response!\n"
msg += "response content: {}".format(resp_obj.content)
raise exceptions.ParseResponseFailure(msg)
# format 4/5
check_value = resp_obj.extract_field(check_item)
validator["check_value"] = check_value

View File

@@ -12,7 +12,7 @@ class MyBaseFailure(BaseException):
class ValidationFailure(MyBaseFailure):
pass
class ParseResponseFailure(MyBaseFailure):
class ExtractFailure(MyBaseFailure):
pass

View File

@@ -143,6 +143,9 @@ class ResponseObject(object):
if isinstance(body, (dict, list)):
# content = {"xxx": 123}, content.xxx
return utils.query_json(body, sub_query)
elif sub_query.isdigit():
# content = "abcdefg", content.3 => d
return utils.query_json(body, sub_query)
else:
# content = "<html>abcdefg</html>", content.xxx
err_msg = u"ParamsError: Failed to extract attribute from response body! => {}\n".format(field)
@@ -171,8 +174,8 @@ class ResponseObject(object):
msg += "\t=> {}".format(value)
logger.log_debug(msg)
# TODO: unify ParseResponseFailure type
except (exceptions.ParseResponseFailure, TypeError):
# TODO: remove except here
except (TypeError):
logger.log_error("failed to extract field: {}".format(field))
raise

View File

@@ -184,7 +184,7 @@ class Runner(object):
try:
self.context.validate(validators, resp_obj)
except (exceptions.ParamsError, \
exceptions.ValidationFailure, exceptions.ParseResponseFailure):
exceptions.ValidationFailure, exceptions.ExtractFailure):
# log request
err_req_msg = "request: \n"
err_req_msg += "headers: {}\n".format(parsed_request.pop("headers", {}))

View File

@@ -17,7 +17,7 @@ from datetime import datetime
import yaml
from httprunner import exceptions, logger
from httprunner.compat import OrderedDict, is_py2, is_py3
from httprunner.compat import OrderedDict, is_py2, is_py3, str
from requests.structures import CaseInsensitiveDict
SECRET_KEY = "DebugTalk"
@@ -186,20 +186,28 @@ def query_json(json_content, query, delimiter='.'):
}
@param (str) query
"person.name.first_name" => "Leo"
"person.name.first_name.0" => "L"
"person.cities.0" => "Guangzhou"
@return queried result
"""
raise_flag = False
response_body = u"from: {}\n".format(json_content)
try:
for key in query.split(delimiter):
if isinstance(json_content, list):
if isinstance(json_content, (list, str)):
json_content = json_content[int(key)]
elif isinstance(json_content, dict):
json_content = json_content[key]
else:
raise exceptions.ParseResponseFailure(
"response content is in text format! failed to query key {}!".format(key))
raise_flag = True
except (KeyError, ValueError, IndexError):
raise exceptions.ParseResponseFailure("failed to query json when extracting response!")
raise_flag = True
if raise_flag:
err_msg = u"ExtractFailure: Failed to extract! => {}\n".format(query)
err_msg += response_body
logger.log_error(err_msg)
raise exceptions.ExtractFailure(err_msg)
return json_content