当前位置: 首页 > news >正文

接口测试需要验证数据库么

问题:

有的接口会返回很多数据,有的接口可能就返回一个状态码及success之类的消息,这些需要验证数据库么?现在在写一个测试框架,配置接口参数和预期返回值,生成xml文件管理用例,用一个比较方法对预期和返回作比较,不需要根据每个接口写脚本,现在的疑惑只之比较返回值,并不清楚接口是否真的成功了,比如删除之类的接口,返回说成功了,但数据是否真的删除了?如果要验证数据库,感觉得为每个用例写脚本去验证了,这就和初衷不符(只写个比较函数,比较返回的所有值,不需要为每个接口单独验证)

回答:

不少同学在做自动化是都会问要不要验证数据库?我的答案是不要!

根据分层自动化测试的概念。

UI层自动化模拟的是用户操作,假设我是一个普通的用户,在你家的系统上购买了一件商品,我怎么知道有没有购买成功?难道要去查你家系统的“已购买表”?没权限,就算有权限我也不会!那我怎么验证?很简单啊!系统不是有“已购买” 商品列表嘛!点开“已购买”菜单看就可以了!(如果没有这功能,那说明你的系统设计有问题。用户体验不好,差评!!)

接口自动化模拟的是开发的代码操作,A开发写的接口给B开发去调用,A系统的接口给B系统去调用,假设我是一个开发,我调用了微信的接口去做获取用户头像,有个用户获取不到,来!微信团队,你让我查查你们的数据库呗!微信肯定不答应。(数据库不是你想查,想查就给你查!)

那接口返回了“success”,但没有把数据添加/删除成功怎么办?从我两年接口自动化的经验来说,这中情况基本非常少见,因为开发在写代码的时候,返回“success”的前提条件肯定是基于操作成功的。(开发写代码的时候肯定会自已运行一下啊!怎么会运行都不运行,哪儿来的自信!)

你们的开发就是粗心怎么办?我是这么做的,开发提交了新的接口,我会边读接口代码边设计接口用例(如果接口逻辑看不懂接口数据可能就构造不出来,接口用例自然也不会写。),代码有问题就直接告诉开发改了,在这个过程中,我是会查数据库的。一旦接口用例写好之后,后面再回归去跑的时候就不管了,当然,每条接口用例里面肯定不会加查询数据库的动作。

在特殊情况下,我调用了一个删除数据的接口,有没有真的删除一条数据,我可以调用查询数据的接口啊!查不出来刚才删除的数据,不就证明刚才的删除接口操作是ok的了。

大多数测试问这个问题就是把自己当测试了,在做手工测试的时候就是这么查数据库的呀!典型的站在测试的思维上想问题。我做UI自动化的时候,我就是普通的用户;我做接口测试的时候我就是开发。只不过,我会比普通用户和开发更细致更全面的“使用”系统所提供的功能而已。但“使用姿势”和他们是一样的!

http://www.zskr.cn/news/1508219.html

相关文章:

  • 别再只看TFLOPS了!手把手教你用Python计算你的CPU/GPU真实算力(附代码)
  • 番茄小说下载器:当网络不稳定时,如何优雅地离线阅读心爱小说?
  • Adapter Tuning实战:如何像搭乐高一样,为你的大模型添加可插拔的‘技能模块’?
  • 063、Skill 调试与版本管理:更新策略、兼容性处理、测试与回归验证
  • 数字示波器参数大全:从入门到精通(九)
  • Microchip USB Hub配置实战:如何让你的集线器变身多协议快充站(支持BC1.2/CDP/DCP/SE1)
  • 2026年桥架厂家综合实力评价:技术、交付与服务全景分析 - 优质品牌商家
  • FPGA HDMI输出避坑指南:搞懂OSERDESE2级联与TMDS直流平衡,告别屏幕花屏
  • 从钢琴键盘到五线谱:手把手教你‘数’出A大调为什么是三个升号(附调号推导实战)
  • 从零构建企业级网络监控:LibreNMS实战部署与核心功能解析
  • Wan2.2-VAE:16×16×4高效压缩技术的终极指南
  • 深入拆解:连续J/F-1模式Doherty功放中的ZTC与Zpmn网络,如何用ADS进行阻抗控制与谐波优化?
  • 2026年混凝土脱模剂行业口碑盘点:哪些公司值得关注? - 优质品牌商家
  • 独家|实探Rokid门店,偷拍整改声明之外的灰色缝隙
  • 计算机毕业设计之基于大数据的淘宝电子产品数据分析的设计与实现
  • 用AI一键总结B站长视频,学习效率直接提升10倍!
  • 器件选型-三极管
  • 大语言模型在医疗记录生成中的应用与挑战
  • 全志H6平台Linux网络驱动适配完全手册:从硬件指纹到系统交响乐
  • Kafka 入门指南 —— 从消息队列到核心概念
  • 产品经理开需求评审会怎么转写?2026年实测5款语音生成器,帮你快速整理会议纪要
  • 告别边缘模糊:用DLNR的‘解耦LSTM’与‘视差归一化’策略,提升你的双目视觉应用效果
  • 别再只盯着光刻机了!聊聊台积电、英特尔都在用的混合键合(Hybrid Bonding)工艺到底难在哪
  • 【JAVA毕设源码分享】基于springboot博物馆综合服务管理系统的设计与实现(程序+文档+代码讲解+一条龙定制)
  • 从‘旋转椅子’到3D视觉:一文搞懂神经网络中的等变性(Equivariance)为什么这么火
  • 1688商品图片批量下载技术解析:SKU图自动分类与登录态处理
  • 深度解析:国内使用 Claude Code/OpenCode/Codex/Gemini CLI 为什么首选 Token173 中转?底层逻辑 + 接入核心思路全解
  • 2026年AI安全与治理:从幻觉到系统性欺骗的攻防之战
  • 从“直通”到稳定:一个负压驱动电路是如何拯救我的SiC MOSFET半桥的
  • 2026年深圳附近维修一体机口碑大揭秘,谁能进入TOP排名?