do not need to config extract_binds if only want to validate results

This commit is contained in:
httprunner
2017-06-29 17:19:06 +08:00
parent 1bca625f42
commit bfa2227d10
8 changed files with 70 additions and 105 deletions

View File

@@ -23,7 +23,36 @@ class ResponseObject(object):
'body': self.parsed_body() 'body': self.parsed_body()
} }
def extract_response(self, extract_binds, delimiter='.'): def extract_field(self, field, delimiter='.'):
""" extract field from requests.Response
@param (str) field of requests.Response object, and may be joined by delimiter
"status_code"
"content"
"headers.content-type"
"content.person.name.first_name"
"""
try:
field += "."
# string.split(sep=None, maxsplit=-1) -> list of strings
# e.g. "content.person.name" => ["content", "person.name"]
top_query, sub_query = field.split(delimiter, 1)
if top_query in ["body", "content", "text"]:
json_content = self.parsed_body()
else:
json_content = getattr(self.resp_obj, top_query)
if sub_query:
# e.g. key: resp_headers_content_type, sub_query = "content-type"
return utils.query_json(json_content, sub_query)
else:
# e.g. key: resp_status_code, resp_content
return json_content
except AttributeError:
raise exception.ParamsError("invalid extract_binds!")
def extract_response(self, extract_binds):
""" extract content from requests.Response """ extract content from requests.Response
@param (dict) extract_binds @param (dict) extract_binds
{ {
@@ -33,35 +62,15 @@ class ResponseObject(object):
"resp_content_person_first_name": "content.person.name.first_name" "resp_content_person_first_name": "content.person.name.first_name"
} }
""" """
extract_binds_dict = {} extracted_variables_mapping = {}
for key, value in extract_binds.items(): for key, field in extract_binds.items():
if not isinstance(value, utils.string_type): if not isinstance(field, utils.string_type):
raise exception.ParamsError("invalid extract_binds!") raise exception.ParamsError("invalid extract_binds!")
try: extracted_variables_mapping[key] = self.extract_field(field)
value += "."
# string.split(sep=None, maxsplit=-1) -> list of strings
# e.g. "content.person.name" => ["content", "person.name"]
top_query, sub_query = value.split(delimiter, 1)
if top_query in ["body", "content", "text"]: return extracted_variables_mapping
json_content = self.parsed_body()
else:
json_content = getattr(self.resp_obj, top_query)
if sub_query:
# e.g. key: resp_headers_content_type, sub_query = "content-type"
answer = utils.query_json(json_content, sub_query)
extract_binds_dict[key] = answer
else:
# e.g. key: resp_status_code, resp_content
extract_binds_dict[key] = json_content
except AttributeError:
raise exception.ParamsError("invalid extract_binds!")
return extract_binds_dict
def validate(self, validators, variables_mapping): def validate(self, validators, variables_mapping):
""" Bind named validators to value within the context. """ Bind named validators to value within the context.
@@ -87,15 +96,16 @@ class ResponseObject(object):
for validator_key, validator_dict in validators.items(): for validator_key, validator_dict in validators.items():
try: try:
value = variables_mapping[validator_key] validator_dict["value"] = variables_mapping[validator_key]
validator_dict["value"] = value
expected_value = validator_dict["expected"]
except KeyError: except KeyError:
raise exception.ParamsError("invalid validator %s" % validator_key) validator_dict["value"] = self.extract_field(validator_key)
if "expected" not in validator_dict:
raise exception.ParamsError("expected not specified in validator")
match_expected = utils.match_expected( match_expected = utils.match_expected(
value, validator_dict["value"],
expected_value, validator_dict["expected"],
validator_dict.get("comparator", "eq") validator_dict.get("comparator", "eq")
) )

View File

@@ -77,8 +77,8 @@ class TestRunner(object):
resp_obj = response.ResponseObject(resp) resp_obj = response.ResponseObject(resp)
extract_binds = testcase.get("extract_binds", {}) extract_binds = testcase.get("extract_binds", {})
extract_binds_dict = resp_obj.extract_response(extract_binds) extracted_variables_mapping = resp_obj.extract_response(extract_binds)
self.context.update_variables(extract_binds_dict) self.context.update_variables(extracted_variables_mapping)
validators = testcase.get("validators", {}) validators = testcase.get("validators", {})
diff_content_dict = resp_obj.validate(validators, self.context.variables) diff_content_dict = resp_obj.validate(validators, self.context.variables)

View File

@@ -21,12 +21,9 @@
authorization: "${authorization}" authorization: "${authorization}"
random: "${random}" random: "${random}"
data: "${data}" data: "${data}"
extract_binds:
resp_status_code: status_code
resp_body_success: content.success
validators: validators:
resp_status_code: {"comparator": "eq", "expected": 201} status_code: {"comparator": "eq", "expected": 201}
resp_body_success: {"comparator": "eq", "expected": true} content.success: {"comparator": "eq", "expected": true}
- test: - test:
name: create user which does not exist name: create user which does not exist
@@ -50,9 +47,6 @@
authorization: "${authorization}" authorization: "${authorization}"
random: "${random}" random: "${random}"
data: "${data}" data: "${data}"
extract_binds:
resp_status_code: status_code
resp_body_success: content.success
validators: validators:
resp_status_code: {"comparator": "eq", "expected": 500} status_code: {"comparator": "eq", "expected": 500}
resp_body_success: {"comparator": "eq", "expected": false} content.success: {"comparator": "eq", "expected": false}

View File

@@ -25,12 +25,9 @@
authorization: "${authorization}" authorization: "${authorization}"
random: "${random}" random: "${random}"
data: "${data}" data: "${data}"
extract_binds:
resp_status_code: status_code
resp_body_success: content.success
validators: validators:
resp_status_code: {"comparator": "eq", "expected": 201} status_code: {"comparator": "eq", "expected": 201}
resp_body_success: {"comparator": "eq", "expected": true} content.success: {"comparator": "eq", "expected": true}
- test: - test:
name: create user which does not exist name: create user which does not exist
@@ -45,9 +42,6 @@
authorization: "${authorization}" authorization: "${authorization}"
random: "${random}" random: "${random}"
data: "${data}" data: "${data}"
extract_binds:
resp_status_code: status_code
resp_body_success: content.success
validators: validators:
resp_status_code: {"comparator": "eq", "expected": 500} status_code: {"comparator": "eq", "expected": 500}
resp_body_success: {"comparator": "eq", "expected": false} content.success: {"comparator": "eq", "expected": false}

View File

@@ -15,14 +15,9 @@
"password": "123456" "password": "123456"
} }
}, },
"extract_binds": {
"resp_status_code": "status_code",
"resp_body_success": "content.success",
"resp_body_msg": "content.msg"
},
"validators": { "validators": {
"resp_status_code": {"comparator": "eq", "expected": 201}, "status_code": {"comparator": "eq", "expected": 201},
"resp_body_success": {"comparator": "eq", "expected": true} "content.success": {"comparator": "eq", "expected": true}
} }
} }
}, },
@@ -42,13 +37,9 @@
"password": "123456" "password": "123456"
} }
}, },
"extract_binds": {
"resp_status_code": "status_code",
"resp_body_success": "content.success"
},
"validators": { "validators": {
"resp_status_code": {"comparator": "eq", "expected": 500}, "status_code": {"comparator": "eq", "expected": 500},
"resp_body_success": {"comparator": "eq", "expected": false} "content.success": {"comparator": "eq", "expected": false}
} }
} }
} }

View File

@@ -10,13 +10,9 @@
json: json:
name: "user1" name: "user1"
password: "123456" password: "123456"
extract_binds:
resp_status_code: status_code
resp_body_success: content.success
resp_body_msg: content.msg
validators: validators:
resp_status_code: {"comparator": "eq", "expected": 201} status_code: {"comparator": "eq", "expected": 201}
resp_body_success: {"comparator": "eq", "expected": true} content.success: {"comparator": "eq", "expected": true}
- test: - test:
name: create user which existed name: create user which existed
@@ -30,9 +26,6 @@
json: json:
name: "user1" name: "user1"
password: "123456" password: "123456"
extract_binds:
resp_status_code: status_code
resp_body_success: content.success
validators: validators:
resp_status_code: {"comparator": "eq", "expected": 500} status_code: {"comparator": "eq", "expected": 500}
resp_body_success: {"comparator": "eq", "expected": false} content.success: {"comparator": "eq", "expected": false}

View File

@@ -14,14 +14,9 @@
"password": "123456" "password": "123456"
} }
}, },
"extract_binds": {
"resp_status_code": "status_code",
"resp_body_success": "content.success",
"resp_body_msg": "content.msg"
},
"validators": { "validators": {
"resp_status_code": {"comparator": "eq", "expected": 201}, "status_code": {"comparator": "eq", "expected": 201},
"resp_body_success": {"comparator": "eq", "expected": true} "content.success": {"comparator": "eq", "expected": true}
} }
} }
}, },
@@ -39,13 +34,9 @@
"password": "123456" "password": "123456"
} }
}, },
"extract_binds": {
"resp_status_code": "status_code",
"resp_body_success": "content.success"
},
"validators": { "validators": {
"resp_status_code": {"comparator": "eq", "expected": 500}, "status_code": {"comparator": "eq", "expected": 500},
"resp_body_success": {"comparator": "eq", "expected": false} "content.success": {"comparator": "eq", "expected": false}
} }
} }
} }

View File

@@ -8,14 +8,10 @@
json: json:
name: user1 name: user1
password: 123456 password: 123456
extract_binds:
resp_status_code: status_code
resp_body_success: content.success
resp_headers_content_type: headers.content-type
validators: validators:
resp_status_code: {"comparator": "eq", "expected": 201} status_code: {"comparator": "eq", "expected": 201}
resp_headers_content_type: {"comparator": "eq", "expected": "application/json"} headers.content-type: {"comparator": "eq", "expected": "application/json"}
resp_body_success: {"comparator": "eq", "expected": true} content.success: {"comparator": "eq", "expected": true}
- test: - test:
name: create user which existed name: create user which existed
@@ -27,11 +23,7 @@
json: json:
name: user1 name: user1
password: 123456 password: 123456
extract_binds:
resp_status_code: status_code
resp_body_success: content.success
resp_headers_content_type: headers.content-type
validators: validators:
resp_status_code: {"comparator": "eq", "expected": 500} status_code: {"comparator": "eq", "expected": 500}
resp_headers_content_type: {"comparator": "eq", "expected": "application/json"} headers.content-type: {"comparator": "eq", "expected": "application/json"}
resp_body_success: {"comparator": "eq", "expected": false} content.success: {"comparator": "eq", "expected": false}