遇到这3种接口测试问题,其实,你可以这么办~

 作为整个软件项目的必经环节,软件测试是不可缺少的“查漏补缺”环节。而作为软件测试中的重要一环——接口测试,几乎串联了整个项目所有的输入和输出环节。

前几年,我在做后端测试时,接触最多的正是接口测试。基于此,我想给大家分享一些我曾经碰到过的接口测试难题,希望抛砖引玉,给正在做测试的小伙伴们提供一些避雷方案。

1、未释放请求服务,导致APP执行任务失败

这个接口功能大概是这样的:

在这里插入图片描述

这是一个算法转换服务的接口。也就是说,我们需要把下单系统中的订单的产品信息,转换成生产系统的生产产品信息。然后根据转换后的订单,进行生产。

基于我们要做不同系统间的调用,所以我们可选择webserivce服务来做调用接口。在这个过程中,接口B将处理这些信息:

l 接收系统A传的参数

l 调用转换服务进行转换

l 转换成功把转换结果写入数据库

l 转换失败返回错误信息

测试这样的接口一般是先本地构造数据,用接口工具进行测试。在这里我们用的是soapui工具,然后就是用真实数据不同系统间进行联测。

当然如果前端功能已经实现,我们也可以直接用前端系统构造数据直接调用接口,这样构造出来的数据更直接。特别是参数比较多,比较复杂的时候,这样测试比直接用接口工具更快更省事。当然,即使我们直接这样测试,也不能取代联测。为什么呢?

因为你去别人的系统自己构造数据,构造的数据只是根据参数来的,不一定能把别个系统所有产品的特性覆盖全。

接下来,我们说说这个接口测试过程中,可能出现的问题。如果这个接口开发交付验收基本功能是正常的,但是一把代码部署到测试环境里,没运行多久,这个接口的APP任务就出现执行失败,这就有问题了。

即便我们认为一条失败了,问题是出在数据构造上。但如果多条连续失败,甚至之前执行成功的数据再次执行转换任务也失败了,那我们应该怎么办呢?

其实很简单,这个时候我们应该去服务器取日志,进行校验。如果发现是服务请求数超限,无法请求到服务,导致APP执行超时导致失败。那么,我们就应该请开发人员协助处理了。

假如此时,我们喊来开发小哥一起分析,发现是接口请求服务链接后,用完未进行释放(这个链接服务器是有一个数量限制的,达到一定量后就无法再进行新的链接)导致的,我们接下来又应该怎么处理呢?

当然就是请开发小哥调整一下代码处理方式,使每次请求用完后,都可以自动释放掉链接。这样处理以后,我们只需再重新测试,直到不存在此问题即可。
 

2、前后端就扣参数对不上,导致接口问题

假如前后端接口参数code对不上,导致数据读取、接收不到或转换,运算结果失败,我们应该怎么处理呢?

这个是接口测试中常见的一个问题,特别是涉及到不同系统间调用接口传参数时,很容易出现这样的问题。

日常工作中,当测试页面功能时涉及到一个接口,功能大概是这样的:查询产品的目录价,成交展示出来。当时前台入参可能是这样的:

l Productname:

l Productversion:

l Productcode:

l Listprice:

l Netprice:

后台返回参数是这样的:

l Productname:

l Productversion:

l Productcode:

l Listprice:

l Net_price:

如果单独用接口工具测试这两边的参数,数据展示是没有问题的。但只要前后台联测,就出现所有产品成交价都是0。遇到这样的情况,我们应该怎么办?

只要我们对比两边消息体的参数,就不难发现,两边参数成交价的名称code写的不一致的。这也就是导致前台读取不到后台传过来的值,默认展示为0的原因了。

类似这样的问题还有很多。

比如:前端系统想要参数1的值,而后台传过来的,却是参数2的值,导致前端在拿过这个值进行逻辑判断或运算的时候,怎么都不对。

再比如:两边取值都是一样的,但是在业务上,这个值就是取的不对,这样即使测试没问题,在实际应用中,结果也是不对的。这个时候,就要求我们需要加深对业务知识的理解了。

为了避免我们在做测试时,遇到这样的问题,我给大家做了一下总结:

1)接到这种传参数的测试时,一定要先做静态测试,核对两边的参数code;

2)对于接到参数取值相关的任务时,在做测试前,两边一定要沟通核对数值及其代表的含义;

3)要提前熟悉业务,看清楚每一个存储的参数表示的含义,确保业务传值正确。

3、参数判断少了特殊情况,导致查询结果不对

这个问题也是接口测试中常见的问题之一。多数情况下,这个问题是由于开发人员对当前产品业务了解不够造成的。

我印象比较深的一次,是一个关于权限优化的需求。记得当时有一个紧急版本要上线,我们的任务是:优化权限的判断逻辑,提高查询性能。

这个功能大概是这样的,当前登录人所在公司有分公司,那么,他同时可以查看分公司的订单。逻辑如下:

在这里插入图片描述

分析一下这个功能,主要有以下几种场景:

情况1:登录人所在公司,只有一个总公司,没有分公司。且总公司有订单,当前登录人可以查看所在公司的订单;

情况2:登录人所在公司是总公司。且该公司有多个分公司,每个分公司都有订单,总公司没有订单,当前登录人可以查看到所有分公司的订单;

情况3:登录人所在总公司有多个分公司,总公司和分公司都有订单,当前登录人可以查看总公司和分公司的所有订单;

情况4:登录人所在公司是总公司且其下有多个分公司,分公司没有订单,只有总公司有订单。当前登录人可以查看到总公司订单。

场景分析完后,接下来,我们就是需要据场景,构造数据进行测试了。

这里,我主要就【情况1】的场景给大家做一个分析。假设在【情况1】里:一进行场景测试,就出现:因为明明有订单的,页面上却展示空白。

这是怎么回事呢?

此时,我们需要先用postman调用后台接口看看。假如后台接口返回的数据是正常确的,那接下来怎么处理呢?这就需要我们回头去服务器查日志了。当我们发现只有一个总公司,没有分公司时,分公司对应的参数都是空的,程序就直接跳过没再执行后面的查询了。根据这种情况,只需我们找开发人员加一个接口:判断分公司是否有值。没有值时,直接跳过,计算总公司的数据即可。

当然,接口测试常见的问题还有:内存溢出、性能问题、查询接口还会涉及到安全问题,等等。这些问题都要根据接口的实际功能,进行分析和有针对性的测试,这里就不一一列举了。感兴趣的小伙伴也可以在留言区留言,提出问题,我们共同探讨,共同进步。

学习上

作为一个软件测试的过来人,我想尽自己最大的努力,帮助每一个伙伴都能顺利找到工作。所以我整理了下面这份资源,现在免费分享给大家,有需要的小伙伴可以关注【公众号:开心螺蛳粉】自提!

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。在这里插入图片描述

在这里插入图片描述

行动吧,在路上总比一直观望的要好,未来的你肯定会感谢现在拼搏的自己!如果想学习提升找不到资料,没人答疑解惑时,请及时加入群:1150305204,里面有各种测试开发资料和技术可以一起交流哦。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/350160.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

python使用PaddleOCR实现《命名实体识别项目》OCR(已实现)(ai领域必看,简单易用)

1.简介: PaddleOCR是飞桨(PaddlePaddle)推出的一个端到端的光学字符识别开源工具集,支持中文、英文、数字以及特殊符号等各种类型的文字检测、识别和词语整体识别。该工具集使用PaddlePaddle深度学习框架技术,提供了多…

【斯坦福计网CS144项目】Lab2 实现一个简单的 TCP 接收类

🕺作者: 主页 我的专栏C语言从0到1探秘C数据结构从0到1探秘Linux 😘欢迎关注:👍点赞🙌收藏✍️留言 🏇码字不易,你的👍点赞🙌收藏❤️关注对我真的很重要&…

21.Arrays类

Arrays类 1. 概述2. 常见方法3. sort 方法的自定义排序4. 代码示例5. 输出结果6. 注意事项 1. 概述 Arrays类是Java中的一个工具类,位于java.util包中。 它提供了一组静态方法,用于操作数组。通过Arrays类,我们可以对数组进行复制、填充、排…

【第四天】蓝桥杯备战

题 1、求和2、天数3、最大缝隙 1、求和 https://www.lanqiao.cn/problems/1442/learning/ 解法:字符串方法的应用 import java.util.Scanner; // 1:无需package // 2: 类名必须Main, 不可修改public class Main {public static void main(String[] args) {Scann…

MSG3D论文解读

论文在stgcn与sta-lstm基础上做的。下面讲一下里面的方法: 1.准备工作 符号。这里是对符号进行解释。 一个人体骨骼图被记为G(v,E) 图卷积: 图卷积定义 考虑一种常用于处理图像的标准卷积神经网络 (CNN)。输入是像素网格。每个像素都有一个数据值向…

kubeSphere DevOps自定义容器 指定nodejs版本

✨✨✨✨✨✨ 🎀前言🎁基于内置镜像构建🎁把镜像添加基础容器中🎁检查容器是否配置成功🎁不生效的原因排查🎁按步骤执行如下命令 🎀前言 由于我本地的开发环境node是16.18.1,而自带容器node的版…

项目中遇到通过域名访问服务提示 Service name unknow

目录 项目中遇到通过域名访问服务提示 Service name unknow 1.问题描述2.问题原因3.解决思路4.解决方案文章所属专区 项目问题解决 1.问题描述 在CentOS 系统环境下 项目中遇到通过域名访问服务提示 Service name unknow,但是 网络是连通的 通过ping 和telnet都能够验证。 …

win10+elasticsearch8.12 安装教程

Elasticsearch是一种搜索引擎,本地安装完成之后,可使用其他编程语言(例如python)与elasticsearch建立连接,然后使用python脚本搜索elasticsearch中的数据 1下载 elasticsearch elasticsearch最新版官网下载链接 点击…

Pandas.DataFrame.product() 乘积(累乘积) 详解 含代码 含测试数据集 随Pandas版本持续更新

关于Pandas版本: 本文基于 pandas2.2.0 编写。 关于本文内容更新: 随着pandas的stable版本更迭,本文持续更新,不断完善补充。 传送门: Pandas API参考目录 传送门: Pandas 版本更新及新特性 传送门&…

让B端管理软件既美观又实用的解决方案来了

hello宝子们...我们是艾斯视觉擅长ui设计和前端开发10年经验!希望我的分享能帮助到您!如需帮助可以评论关注私信我们一起探讨!致敬感谢感恩! 让B端管理软件既美观又实用的解决方案来了 在当今数字化时代,B端管理软件已…

Docker容器部署OpenCV,打造高效可移植的计算机视觉开发环境

推荐 海鲸AI-ChatGPT4.0国内站点:https://www.atalk-ai.com 前言 在计算机视觉领域,快速部署和测试算法是研究和开发的关键。OpenCV作为一个强大的开源计算机视觉库,广泛应用于各种图像处理和视频分析任务。然而,配置OpenCV环境可…

计算机毕业设计 | SpringBoot 求职招聘管理系统(附源码)

1,绪论 1.1 开发背景 高学历人群是网络求职者的主体,且结构趋向固定。而在疫情肆虐的今日,线上招聘成了越来越多企业和个人选择的方式。在疫情期间线下招聘转为线上招聘,是疫情防控的需要。不能否定的是新的招聘模式的出现一定会…

智慧应急消防柜的作用

在现代社会,科技的不断进步带来了许多便利与改变。智能化的产品不仅给我们的生活带来了便捷,也让我们对各个领域的发展有了更高的期待。而在这种场景下,智慧应急消防柜作为智慧城市新型基础设施的必备品,正逐渐受到更多关注。 智能…

《游戏-03_3D-开发》之—新输入系统人物移动攻击连击

本次修改unity的新输入输出系统。本次修改unity需要重启,请先保存项目, 点击加号起名为MyCtrl, 点击加号设置为一轴的, 继续设置W键, 保存 生成自动脚本, 修改MyPlayer代码: using UnityEngine;…

设计模式二(工厂模式)

本质:实例化对象不用new,用工厂代替,实现了创建者和调用者分离 满足: 开闭原则:对拓展开放,对修改关闭 依赖倒置原则:要针对接口编程 迪米特原则:最少了解原则,只与自己直…

DDPM的一点笔记

1 Title Denoising Diffusion Probabilistic Models(Jonathan Ho、Ajay Jain、Pieter Abbeel) 2 Conclusion This paper present high quality image synthesis results using diffusion probabilistic models, a class of latent variable models insp…

【Qt】—— Qt开发环境的搭建

目录 (一)Qt的开发⼯具概述 1.1 Qt Creator 1.2 Visual Studio 1.3 Eclipse (二)Qt SDK的下载和安装 2.1 QtSDK的下载 2.2 QtSDK的安装 2.3 验证QtSDK安装是否成功 2.4 Qt环境变量配置 (一)Qt的…

yolov8 opencv dnn部署 github代码

源码地址 本人使用的opencv c github代码,代码作者非本人 实现推理源码中作者的yolov8s.onnx 推理条件 windows 10 Visual Studio 2019 Nvidia GeForce GTX 1070 opencv4.7.0 (opencv4.5.5在别的地方看到不支持yolov8的推理,所以只使用opencv4.7.0) c部署 先将…

一、防御保护---信息安全概述

一、网络安全防御---信息安全概述 1.信息安全现状及挑战1.1 网络空间安全市场在中国,潜力无穷1.2 数字化时代威胁升级1.3 传统安全防护逐步失效1.4 安全风险能见度不足1.5 缺乏自动化防御手段1.6 网络安全监管标准愈发严苛 2.信息安全概述2.1 简介2.2 常见的网络安全…

分币不花,K哥带你白嫖海外代理 ip!

前言 近来,国内的数据采集环境越来越严峻,不是“非法入侵计算机信息系统”,就是“侵犯公民个人隐私信息”,一个帽子砸下来,直接就“包吃包住”,推荐阅读一下 【K哥爬虫普法专栏】。虽然大伙常说“搏一搏单…