【人工智能学习260612-软件测试篇】小工具实现 [特殊字符] Prompt工程 + RAG思路 + API调用 + 自动化测试

把前面的能力真正串起来,做一个"更像工具"的版本👇

✅ 输入接口文档

✅ 自动生成测试用例(给人看)

✅ 自动生成 pytest 脚本(可执行)

✅ 自动跑测试 + 出报告

而且我会控制在:一个脚本 + 可直接跑


✅ 一、最终效果(你会得到什么)

你只需要准备一个文件:

👉 api_doc.txt

写你的接口文档,比如:

复制代码
接口名称:登录接口
地址:https://api.xxx.com/login
方法:POST
请求头:Content-Type: application/json
参数:
{
  "username": "string",
  "password": "string"
}
规则:
- 密码错误提示
- 连续5次失败锁定

然后执行:

复制代码
python run_ai_test.py

👉 自动生成:

  • ✅ test_cases.txt(测试用例)
  • ✅ test_api.py(测试脚本)
  • ✅ report.html(测试报告)

✅ 二、完整代码(轻量但够用)

直接复制用👇

python 复制代码
import subprocess
from openai import OpenAI

client = OpenAI(api_key="你的API_KEY")

# ====== 读取接口文档 ======
with open("api_doc.txt", "r", encoding="utf-8") as f:
    api_doc = f.read()

# ====== 1. 生成测试用例 ======
case_prompt = f"""
你是一名资深测试工程师,请基于以下接口文档生成测试用例:

{api_doc}

要求:
1. 覆盖正常、异常、边界场景
2. 包含参数校验
3. 输出清晰结构(标题 + 步骤 + 预期结果)
"""

case_resp = client.chat.completions.create(
    model="gpt-5.4",
    messages=[{"role": "user", "content": case_prompt}]
)

test_cases = case_resp.choices[0].message.content

with open("test_cases.txt", "w", encoding="utf-8") as f:
    f.write(test_cases)

print("✅ 测试用例已生成")

# ====== 2. 生成pytest代码 ======
code_prompt = f"""
你是一名测试开发工程师,请基于以下接口文档生成pytest代码:

{api_doc}

要求:
1. 使用 requests + pytest
2. 包含正常和异常测试
3. 必须包含断言
4. 代码可直接运行
5. 不要解释,只输出代码
"""

code_resp = client.chat.completions.create(
    model="gpt-5.4",
    messages=[{"role": "user", "content": code_prompt}]
)

test_code = code_resp.choices[0].message.content

# 防止AI返回 ```python 代码块
test_code = test_code.replace("```python", "").replace("```", "")

with open("test_api.py", "w", encoding="utf-8") as f:
    f.write(test_code)

print("✅ 测试脚本已生成")

# ====== 3. 执行测试 ======
subprocess.run("pytest test_api.py --html=report.html", shell=True)

print("✅ 测试完成,报告:report.html")

✅ 三、你已经实现了什么(很关键)

这个小工具本质是:

👉 Prompt工程 + RAG思路 + API调用 + 自动化测试

你已经覆盖了:

  • ✅ Prompt(生成用例)
  • ✅ RAG(基于文档生成)
  • ✅ API(调用AI)
  • ✅ 自动化测试(pytest)

✅ 四、可以立刻加的3个升级(很简单但很加分)


✅ 升级1:多接口支持(推荐)

api_doc.txt 改成:

👉 一个文件多个接口(用分隔符)

比如:

复制代码
===接口1===
...

===接口2===
...

然后循环生成


✅ 升级2:自动总结测试报告(很实用)

执行完 pytest 后加一步:

python 复制代码
with open("report.html", "r", encoding="utf-8") as f:
    report = f.read()

summary_prompt = f"""
请总结以下测试报告结果,给出:
1. 通过情况
2. 失败原因分析
3. 是否建议上线

{report[:3000]}
"""

👉 自动变汇报材料


✅ 升级3:让代码更"工程化"

在 prompt 里加一句:

👉

"请按分层结构生成(base + test)"


✅ 五、你现在处在什么水平(实话)

做到这一步你已经不是:

👉 "会用AI的人"

而是:

👉 能用AI做工具的人


✅ 如果你还想再往上走一步(我建议)

下一步可以做👇

👉 ✅ 做一个简单UI(输入文档→点按钮→出报告)

👉 ✅ 或接入你们测试流程(CI/CD)


相关推荐
一次旅行3 小时前
AI 前沿日报 | 2026年7月3日 星期五
人工智能·github·ai编程
A15362554 小时前
装配具身机器人品牌推荐 工业装配场景选型指南与艾利特方案
大数据·人工智能·机器人
LLWZAI4 小时前
想要稳定变现,先跨过朱雀 AI 这道门槛
大数据·人工智能
安吉升科技4 小时前
商业场景智能客流统计摄像系统的关键技术机理解析
人工智能
古城小栈4 小时前
为啥说:训练用BF16,推理用FP16
人工智能·算法·机器学习
KaMeidebaby4 小时前
卡梅德生物技术快报|蛋白 N 端测序在重组贻贝融合蛋白表征中的应用,解决原核表达序列偏移工艺难题
前端·人工智能·物联网·算法·百度
TMT星球4 小时前
从像素复刻到行动控制:具身世界模型的底层逻辑探索
人工智能·深度学习·机器学习
ccimao63164 小时前
散户做财报整理、研报阅读、复盘记录,各类AI工具适配环节梳理
大数据·人工智能
派叔4 小时前
老字号营销服务商技术解构:三类方案的架构逻辑与选型评估
大数据·人工智能·搜索引擎·架构·产品运营·流量运营
Byron__4 小时前
AI学习_06_短期记忆与长期记忆
人工智能·python·学习