Merge pull request #1374 from xucong053/bugfix

fix: failed to load json/data content in api reference
fix: ensure complete summary results
This commit is contained in:
debugtalk
2022-06-21 11:07:20 +08:00
committed by GitHub
7 changed files with 23 additions and 12 deletions

View File

@@ -47,7 +47,11 @@ func (path *APIPath) ToAPI() (*API, error) {
if err != nil {
return nil, err
}
// 1. deal with request body compatibility
convertCompatRequestBody(api.Request)
// 2. deal with validators compatibility
err = convertCompatValidator(api.Validators)
// 3. deal with extract expr including hyphen
convertExtract(api.Extract)
return api, err
}

View File

@@ -182,16 +182,7 @@ func (tc *TCase) MakeCompat() (err error) {
}()
for _, step := range tc.TestSteps {
// 1. deal with request body compatibility
if step.Request != nil && step.Request.Body == nil {
if step.Request.Json != nil {
step.Request.Headers["Content-Type"] = "application/json; charset=utf-8"
step.Request.Body = step.Request.Json
step.Request.Json = nil
} else if step.Request.Data != nil {
step.Request.Body = step.Request.Data
step.Request.Data = nil
}
}
convertCompatRequestBody(step.Request)
// 2. deal with validators compatibility
err = convertCompatValidator(step.Validators)
@@ -205,6 +196,19 @@ func (tc *TCase) MakeCompat() (err error) {
return nil
}
func convertCompatRequestBody(request *Request) {
if request != nil && request.Body == nil {
if request.Json != nil {
request.Headers["Content-Type"] = "application/json; charset=utf-8"
request.Body = request.Json
request.Json = nil
} else if request.Data != nil {
request.Body = request.Data
request.Data = nil
}
}
}
func convertCompatValidator(Validators []interface{}) (err error) {
for i, iValidator := range Validators {
if _, ok := iValidator.(Validator); ok {

View File

@@ -67,7 +67,7 @@ class SessionRunner(object):
self.root_dir = self.root_dir or self.__project_meta.RootDir
self.__log_path = os.path.join(self.root_dir, "logs", f"{self.case_id}.run.log")
self.__step_results.clear()
self.__step_results = self.__step_results or []
self.session = self.session or HttpSession()
self.parser = self.parser or Parser(self.__project_meta.functions)

View File

@@ -81,6 +81,7 @@ def run_step_request(runner: HttpRunner, step: TStep) -> StepResult:
"""run teststep: request"""
step_result = StepResult(
name=step.name,
step_type="request",
success=False,
)
start_time = time.time()

View File

@@ -47,6 +47,7 @@ def run_step_sql_request(runner: HttpRunner, step: TStep) -> StepResult:
step_result = StepResult(
name=step.name,
step_type="sql",
success=False,
)
step_variables = runner.merge_step_variables(step.variables)

View File

@@ -10,7 +10,7 @@ from httprunner.step_request import call_hooks
def run_step_testcase(runner: HttpRunner, step: TStep) -> StepResult:
"""run teststep: referenced testcase"""
step_result = StepResult(name=step.name)
step_result = StepResult(name=step.name, step_type="testcase")
step_variables = runner.merge_step_variables(step.variables)
step_export = step.export

View File

@@ -57,6 +57,7 @@ def run_step_thrift_request(runner: HttpRunner, step: TStep) -> StepResult:
step_result = StepResult(
name=step.name,
step_type="thrift",
success=False,
)
step_variables = runner.merge_step_variables(step.variables)