mirror of
https://github.com/httprunner/httprunner.git
synced 2026-06-08 09:19:41 +08:00
do not need to config extract_binds if only want to validate results
This commit is contained in:
@@ -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")
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|||||||
@@ -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)
|
||||||
|
|||||||
@@ -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}
|
||||||
|
|||||||
@@ -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}
|
||||||
|
|||||||
@@ -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}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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}
|
||||||
@@ -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}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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}
|
||||||
Reference in New Issue
Block a user