遇到这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,里面有各种测试开发资料和技术可以一起交流哦。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

操作系统-进程通信(共享存储 消息传递 管道通信 读写管道的条件)

文章目录 什么是进程通信为什么进程通信需要操作系统支持共享存储消息传递直接通信方式间接通信方式 管道通信小结注意 什么是进程通信 分享吃瓜文涉及到了进程通信 进程通信需要操作系统支持 为什么进程通信需要操作系统支持 进程不能访问非本进程的空间 当进程P和Q需要…

美易平台:芯片生产商Cerebras Systems考虑最快今年IPO

据知情人士透露,硅谷芯片制造初创公司Cerebras Systems Inc.正考虑在今年下半年进行首次公开募股(IPO)。如果成功上市,这家人工智能(AI)超级计算机生产商的估值将超过其2021年融资时的40亿美元估值。目前&a…

【DeepLearning-3】前馈(feed-forward)神经网络层

类定义 class FeedForward(nn.Module): FeedForward 类继承自 nn.Module,nn.Module是PyTorch中所有神经网络模块的基类。nn.Module允许您创建自己的神经网络层。 nn.Module 是构建所有神经网络层和模型的基类。当创建一个类继承自 nn.Module时,意味着你…

JavaScript中有哪些函数类型

JavaScript中的函数类型有很多种,下面列出了一些常见的函数类型及其示例: 一元函数(Unary Functions):只接收一个参数的函数。 一元函数是指函数方程中只包含一个自变量的函数。例如,函数yF(x)是一元函数&…

幻兽帕鲁服务器数据备份

搭建幻兽帕鲁个人服务器,最近不少用户碰到内存不足、游戏坏档之类的问题。做好定时备份,才能轻松快速恢复游戏进度 这里讲一下如何定时将服务器数据备份到腾讯云轻量对象存储服务,以及如何在有需要的时候进行数据恢复。服务器中间的数据迁移…

数据结构(顺序表)

文章目录 一、线性表1、线性表1.1、线性表的定义1.2、线性表的操作 2、顺序表2.1、顺序表的实现--静态分配2.2、顺序表的实现--动态分配2.2、顺序表的特点 3、顺序表的基本操作3.1、插入操作3.2、删除操作3.3、查找操作3.2、按位查找3.2、按值查找 一、线性表 1、线性表 1.1、…

Git 删除已经 Push 到远程多余的文件

例如要删除 data/log 文件 1. 在当前项目下打开终端 2. 查看有哪些文件夹 dir 3. 预览将要删除的文件(如果不清楚该目录下是否存在不应该删除的文件) git rm -r -n --cached 文件/文件夹名称 加上 -n 这个参数,执行命令时,是不会…

Numpy应用-股价分析实战

股价统计分析 数据样本 股价常用指标 极差 越高说明波动越明显 股价近期最高价的最大值和最小值的差价 成交量加权平均价格 英文名VWAP(Volume-Weighted Average Price,成交量加权平均价格)是一个非常重要的经济学量,代表着金融…

考研机试 糖果分享游戏

糖果分享游戏 一些学生围坐一圈,中间站着他们的老师,所有人都面向老师。 他们要玩一个有关糖果分享的游戏。每个学生最开始都有一定数量的糖果(保证一定是偶数)。 每轮游戏的进程为: 老师吹起哨声,所有学…

苹果Find My市场需求火爆,伦茨科技ST17H6x芯片助力客户量产

苹果发布AirTag发布以来,大家都更加注重物品的防丢,苹果的 Find My 就可以查找 iPhone、Mac、AirPods、Apple Watch,如今的Find My已经不单单可以查找苹果的设备,随着第三方设备的加入,将丰富Find My Network的版图。产…

2024年华为OD机试真题-寻找最富裕的小家庭-Java-OD统一考试(C卷)

题目描述: 在一棵树中,每个节点代表一个家庭成员,节点的数字表示其个人的财富值,一个节点及其直接相连的子节点被定义为一个小家庭。 现给你一棵树,请计算出最富裕的小家庭的财富和。 输入描述:第一行为一个数N,表示成员总数,成员编号1-N,1<=N<=1000 第二行为N个…

Unity 中的接口和继承

在Unity的游戏开发中&#xff0c;理解面向对象编程的概念&#xff0c;如类、接口、继承和多态性&#xff0c;是非常重要的。本文旨在帮助理解和掌握Unity中接口和继承的概念&#xff0c;以及如何在实际项目中应用这些知识。 类和继承 在C#和Unity中&#xff0c;类是构建应用程序…

WSL中遇到CondaHTTPError: HTTP 000 CONNECTION FAILED for url解决方法

文章目录 遇到问题解决方法参考 遇到问题 之前用WSL使用conda都是正常的&#xff0c;今天用的时候遇到CondaSSLError: Encountered an SSL error. Most likely a certificate verification issue. (base) lishizhengDESKTOP-8SJ6087:~$ conda update -n base -c defaults con…

Google Chrome RCE漏洞 CVE-2020-6507 和 CVE-2024-0517 流程分析

本文深入研究了两个在 Google Chrome 的 V8 JavaScript 引擎中发现的漏洞&#xff0c;分别是 CVE-2020-6507 和 CVE-2024-0517。这两个漏洞都涉及 V8 引擎的堆损坏问题&#xff0c;允许远程代码执行。通过EXP HTML部分的内存操作、垃圾回收等流程方式实施利用攻击。 CVE-2020-…

操作符详解(上)

目录 操作符的分类 二进制和进制转换 2进制转10进制 10进制转2进制数字 2进制转8进制 2进制转16进制 原码、反码、补码 移位操作符 左移操作符 右移操作符 位操作符&#xff1a;&、|、^、~ 单目操作符 逗号表达式 操作符的分类 • 算术操作符&#xff1a; …

【C++干货铺】 RAII实现智能指针

个人主页点击直达&#xff1a;小白不是程序媛 C系列专栏&#xff1a;C干货铺 代码仓库&#xff1a;Gitee 目录 为什么需要智能指针&#xff1f; 内存泄漏 什么是内存泄漏&#xff0c;内存泄露的危害 内存泄漏的分类 堆内存泄漏&#xff08;Heap leak&#xff09; 系统资…

CMG GPP 0.05°全球区域2000~2019年月数据分享

各位同学们好&#xff0c;今天分享的是CMG GPP 0.05全球区域2000~2019年月数据。您可以私信或评论。 一、数据简介 准确估算陆地植被的初级生产总值&#xff08;GPP&#xff09;对于了解全球碳循环和预测未来气候变化至关重要。目前有多种基于不同方法的 GPP 产品&#xff0c…

ORM-08-EclipseLink 入门介绍

拓展阅读 The jdbc pool for java.(java 手写 jdbc 数据库连接池实现) The simple mybatis.&#xff08;手写简易版 mybatis&#xff09; 1. EclipseLink概述 本章介绍了EclipseLink及其关键特性&#xff1a;包括在EclipseLink中的组件、元数据、应用程序架构、映射和API。 本…

Leetcode—29. 两数相除【中等】

2023每日刷题&#xff08;九十四&#xff09; Leetcode—29. 两数相除 叛逆期实现代码 class Solution { public:int divide(int dividend, int divisor) {if(dividend INT_MIN && divisor -1) {return INT_MAX;} return dividend / divisor;} };运行结果 倍增算法…

java多线程测试websocket demo(使用文件流)

这个demo主要是利用Java多线程来测试WebSocket通信。首先&#xff0c;创建一个WebSocket服务器和客户端&#xff0c;然后使用多线程来模拟多个客户端同时连接服务器进行通信。通过多线程测试&#xff0c;可以验证WebSocket通信的并发性能和稳定性。同时&#xff0c;可以通过多线…