基于Skills的接口自动化测试方案|新增 MySQL 断言,实现接口 + 数据库双校验

哈喽,我是 Raina。

上篇我们讲了基于Skills的接口自动化测试方案,新增多接口串联自然语言场景用例的实现思路,实现了从 "单接口测试" 到 "完整业务流程自动化" 的升级。感兴趣的可以看下这篇文章:

但在实际使用中,还存在一个很常见的痛点:断言能力单一,不支持 MySQL 数据库校验,无法覆盖数据层结果验证。

所以我在这个方案也优化新增了一个核心能力:AI 自动连接 MySQL,执行 SQL 断言,做到接口返回校验 + 数据库数据校验双保险,提高测试结果的准确性。

数据库断言的核心作用

在接口自动化里,接口调用成功、返回参数正常,不代表后台数据一定正确入库。有可能接口提示成功,但数据库没新增、没更新、字段值不对、状态流转异常等问题。

数据库断言的作用:

  • 执行完接口用例后,自动执行 SQL 查询
  • 自动对比库中数据是否符合预期
  • 实现:接口返回 + 数据库数据双重校验
  • 彻底避免:业务成功、数据不对的 "假成功"

比如:新增订单后,校验订单表是否生成对应记录、订单状态是否正确;编辑信息后,校验数据库字段是否同步更新;删除后校验数据是否已置为失效或删除。

这也是企业级接口自动化必须具备的稳定性能力。

本方案的Mysql断言整体逻辑

实操全流程

1、Skill&项目&依赖安装

本方案整体Skills 如下:

导入 Raina提供的 skill 包合集到 AI 工具里面(cursor或claude code等都支持的)

2、生成接口文档

如果已经有接口文档的话,就不需要执行该 skill,本skill 的目的是基于已有的项目代码,生成接口文档

生成的接口文档如下:

3、生成项目配置

输入:

输出:config/.env 文件

内部文件可以看到,DB断言配置信息:

DB_ASSERT_ENABLED,该字段指的是是否开启db断言处理,默认为 false,

如果我们需要进行db断言处理的话,要开启db断言处理以及填写相关信息

4、自然语言场景用例生成

输入:

输出:自然语言场景用例json文件

5、测试用例生成

输入:

执行该步骤的时候,会去判断config/.env文件中的属性:DB_ASSERT_ENABLED=true

如果数据库信息配置成功,那么该skill则会先去拉取数据库表结构,用于db断言

产出db_schema.json文件

在生成完表结构文件后,AI会基于该文件,进行用例和db断言语句的编写

用例部分截图:

db断言语句:

6、执行用例

AI会自动执行脚本

7、生成报告

启动之后,查看结果

我们可以看到allure日志中,对sql进行了执行和校验

总结

该文章讲解如何在基于Skill实现接口自动化测试的方案中加入 MySQL 断言,实现接口 + 数据库双层验证,让自动化流程更严谨、更贴合企业级测试标准。截止到目前,整套方案已经实现了从「接口文档→用例生成→框架初始化→配置修改→代码生成→用例执行→Allure 报告」全流程Skill封装。

后续Raina也会持续迭代这套接口自动化Skills体系,解决更多实际应用中的痛点实战场景、配置技巧与落地避坑经验,助力大家将接口自动化真正运用到工作中,切实提升测试效率、减少重复回归工作量。

相关推荐
ccddsdsdfsdf2 小时前
DBeaver怎么链接mongoDB
数据库·mongodb
丷丩3 小时前
Postgresql基础实践教程(十一)各种Join
数据库·postgresql·join
星夜夏空993 小时前
FreeRTOS学习(4)——内存映射
数据库·学习·mongodb
TheRouter4 小时前
AI Agent 记忆体系建设实战:短期、长期与工作记忆的工程实现
数据库·人工智能·oracle
Omics Pro4 小时前
首个!外源天然产物综合性代谢图谱
数据库·人工智能·算法·机器学习·r语言
JAVA面经实录9175 小时前
Hibernate面试题库
数据库·oracle·hibernate
迷枫7126 小时前
DM8 目录结构与常用排查入口梳理
服务器·数据库
Mr.Daozhi7 小时前
RAG 进阶实战:跑通 Demo 后我连续翻了 6 次车,逐一修复才真正可用(含 Gradio Web 版)
前端·数据库·langchain·大模型·gradio·rag·科研工具
小程故事多_807 小时前
Claude Code自定义workflow skills用法
数据库·人工智能·智能体
大鹏说大话7 小时前
SQL 排序与分组实战:解决“分组后取最新数据“
android·java·数据库