mirror of
https://github.com/httprunner/httprunner.py.git
synced 2026-05-07 06:12:46 +08:00
66 lines
2.1 KiB
Python
66 lines
2.1 KiB
Python
# NOTICE: Generated By HttpRunner.
|
|
import json
|
|
import os
|
|
import time
|
|
|
|
import pytest
|
|
from loguru import logger
|
|
|
|
from httprunner.utils import get_platform, ExtendJSONEncoder
|
|
|
|
|
|
@pytest.fixture(scope="session", autouse=True)
|
|
def session_fixture(request):
|
|
"""setup and teardown each task"""
|
|
logger.info("start running testcases ...")
|
|
|
|
start_at = time.time()
|
|
|
|
yield
|
|
|
|
logger.info("task finished, generate task summary for --save-tests")
|
|
|
|
summary = {
|
|
"success": True,
|
|
"stat": {
|
|
"testcases": {"total": 0, "success": 0, "fail": 0},
|
|
"teststeps": {"total": 0, "failures": 0, "successes": 0},
|
|
},
|
|
"time": {"start_at": start_at, "duration": time.time() - start_at},
|
|
"platform": get_platform(),
|
|
"details": [],
|
|
}
|
|
|
|
for item in request.node.items:
|
|
testcase_summary = item.instance.get_summary()
|
|
summary["success"] &= testcase_summary.success
|
|
|
|
summary["stat"]["testcases"]["total"] += 1
|
|
summary["stat"]["teststeps"]["total"] += len(testcase_summary.step_results)
|
|
if testcase_summary.success:
|
|
summary["stat"]["testcases"]["success"] += 1
|
|
summary["stat"]["teststeps"]["successes"] += len(
|
|
testcase_summary.step_results
|
|
)
|
|
else:
|
|
summary["stat"]["testcases"]["fail"] += 1
|
|
summary["stat"]["teststeps"]["successes"] += (
|
|
len(testcase_summary.step_results) - 1
|
|
)
|
|
summary["stat"]["teststeps"]["failures"] += 1
|
|
|
|
testcase_summary_json = testcase_summary.dict()
|
|
testcase_summary_json["records"] = testcase_summary_json.pop("step_results")
|
|
summary["details"].append(testcase_summary_json)
|
|
|
|
summary_path = os.path.join(
|
|
os.getcwd(), "examples/postman_echo/logs/request_methods/hardcode.summary.json"
|
|
)
|
|
summary_dir = os.path.dirname(summary_path)
|
|
os.makedirs(summary_dir, exist_ok=True)
|
|
|
|
with open(summary_path, "w", encoding="utf-8") as f:
|
|
json.dump(summary, f, indent=4, ensure_ascii=False, cls=ExtendJSONEncoder)
|
|
|
|
logger.info(f"generated task summary: {summary_path}")
|