不会代码的时候,如何使用Jmeter完成接口测试

1.接口测试简介

接口测试是测试系统组件间接口的一种测试。接口测试主要用于检测外部系统与系统之间以及内部各个子系统之间的交互点。测试的重点是要检查数据的交换,传递和控制管理过程,以及系统间的相互逻辑依赖关系等。

2.接口测试流程

接口测试的流程和功能测试流程类似,依据的对象是需求说明书和接口需求,接口测试流程如下:

图片

3.接口测试范围

业务功能(包括正常、异常场景是否实现)

业务规则(覆盖度是否全面)

参数验证(边界、业务规则是否达到要求)

异常场景(重复提交、并发提交、事务中断、多机环境、大数据量测试

性能测试(响应时间、吞吐量、并发数、资源要求)

安全测试(权限验证、SQL注入等)

4.接口测试重点

● 检查接口的功能:检查接口的功能有没有实现,也就是请求会不会成功,如果不成功会不会返回错误代号(或错误信息);

● 检查接口返回的数据:检查接口返回的数据、数据格式、数据类型是否与预期一致(正向且传递的参数正常);

● 检查接口的容错性:接口是否可以正常处理(假如传递的参数足够大或者为负、空值时);

● 检查接口的性能:http请求接口大多与后端执行的SQL语句性能、算法等比较相关;

● 检查接口的安全性:外部调用的接口尤为重要。

5.接口测试需求分析

● 首先根据接口设计的技术架构方案,了解清楚被测接口对应的公共入参、入参、出参及返回数据的Json结构规范,根据测试场景进行测试。

● 理解接口参数,熟悉接口参数的输入要求、输入值范围、必填项等。

● 理解接口输出,熟悉返回json的结构构成、返回值类别、返回值范围、返回data的不同类型等。

● 理解接口的逻辑、接口的业务关联,熟悉技术方案中的接口相互关联、依赖的关系,接口与接口之间的数据传递等。

● 寻找测试点,根据输入 (参数名、取值范围)、输出 (参数名、返回值范围)、关联关系,进行测试点分析。

6.接口测试用例设计

接口测试的主要测试对象是接口,但是随着系统复杂度越来越高,接口越来越多,完全覆盖所有接口是很难的一件事情,并且实际过程中任意内部接口的变动都可能导致我们的测试用例的不可用。

接口用例设计优先级

优先级–>针对所有接口

暴露在外面的接口,因为通常该接口会给第三方调用;

供系统内部调用的核心功能接口;

供系统内部调用非核心功能接口。

优先级–>针对单个接口

正向用例优先测试,逆向(异常)用例次之 (通常情况,非绝对);

是否满足前提条件 > 是否携带默认参值参数 > 参数是否必填 > 参数之间是否存在关联 > 参数数据类型限制 > 参数数据类型自身的数据范围值限制。

接口用例设计方法

图片

测试用例编写注意事项

图片

进行测试执行编写时,有如下的原则:

1.不同的接口参数覆盖不同的业务场景;

2.在后台构造合适的数据来满足接口的测试用例;

3.根据接口的返回值,断言其是否返回期望结果,并查看数据库验证;

4.测试用例涉及多个步骤的,应对涉及的步骤都验证;

5.删除测试过程中产生的结果,确保每个用例执行前都是一个清洁的环境。

7.接口测试用例模板

图片

8.接口数据准备

图片

9.接口测试工具

接口测试工具选择

接口工具:Postman/Jmeter/SouapUI/python,单个接口测试时使用 Postman,多个接口测试时可以使用Jmeter,或者使用python脚本;

Jmeter:可以测试各种类型的接口,不支持的也可以通过网上或自己编写的插件进行扩展。

postman:功能上更简单,组织方式也更轻量级,它主要针对的就是单个的 HTTP 请求。

接口测试工具根据对比

图片

抓包工具

个人比较喜欢Charles嘛,但是也可以使用fiddler或者其他的抓包工具。

jmeter使用dome

图片

10.接口测试原则

基础配置,如域名、环境配置等,单出文件配置,方便不同环境测试、脚本维护;

明确接口实现什么样的功能,实际需要什么样的功能,是否一致;

接口测试数据太多,用该数据驱动模式更有层次,且易于维护;

要在众多测试用例中选出冒烟测试用例及可用于性能测试的用例;

先单接口测试,再多接口业务测试;

测试完成以后,需要清洗脏数据。

11.接口测试执行实例

11.1 使用Jmeter测试接口实例

接口测试环境准备

Jdk1.8 或以上:

http://www.oracle.com/technetwork/java/javase/downloads/index.html

Jmeter 下载址址:http://jmeter.apache.org/download_jmeter.cgi

插件的下载安装地址:http://www.jmeter-plugins.org/

12. 如何快速生产脚本生成

既然使用到了jmeter团队又是多人的情况下,那么 jmeter 脚本的生产力是一个很大的问题,再加上团队不是每个人对 jmeter 的熟悉程度都是不一样的,所以脚本的编写和快速生产就是个问题,针对这个个人建议脚本的生产建议从以下几个方面考虑;

使用jemter原生的录制器;

手写jmeter脚本,但是需要对jmeter相对熟悉;

使用fiddles抓包工具导出生产;

针对web页面个人推荐BlazeMeter的谷歌插件。

针对以上五种生产jmeter脚本快速生产的方案,都可以很好的辅助编写jmeter 的脚本,在这里很多同学肯定会问为什么不使用metersphere,这个项目本身很优秀了,但是由于公司的原因,所以最后放弃,很多同学肯定想,录制生成,直接回访就完事,我只能说太简单,这样你的脚本使用一次基本就报废, 会造成脚本的重复编写费时费力,这个时候,需要测试强硬一点了大家采用统一的录制控制方式去录制,同意脚本编写的方案,毕竟在怎么录制都是不行的,所以最好的实践方式就是采用录制为主,修改为辅的解决方式,去编写复用率高的脚本。

13.团队协作落地

相信jmeter很多测试小伙伴都很熟悉,肯定也都熟悉他有一个最大通病,就是case太多的时候,一点都不方便管理。

其实这个问题,我也遇见了,因为现在的团队不只是我一个人单打独斗,我还有队友,所以对jmx脚本的管理,我在团队里面采用的是git管理我们的脚本,我们在团队内部和开发约束,测试环境的时候,所有的部署都走test的一个代码分支,这样做的好处,就是为了减轻jmx脚本的复杂性,同时也避免了在发布生产环境的时候,将脚本发布到生产环境,因为最初的初衷使用jmeter做接口测试的情况下,就是因为团队开发的同学不写单元测试,测试同学会Java的只有一两个,服务又多,公司的迭代速度又快,开发提测的功能一直没有很好的健壮性,所以,我在想能不能在开发部署成功的时候或者定时轮询执行一下每个服务的接口,以达到提测的质量。

在团队实践中也遇到了一些问题如下:

token的时效性原因,导致脚本老是执行失败;

数据的唯一性,例如我每次请求的时间都是不一样的等;

数据库的连接数老是超标,因为团队存在多个项目组,他们之间又是使用相同的数据库,只是不同表;

Jenkins的并发限制,因为大家都是使用同一个Jenkins,不可能你一个老是占用Jenkins的执行。

针对以上的问题,我个人是如下解决的,首先token校验的问题,存在这个问题的根本原因,是因为我们每次登录都是图片验证码的登录,但是我又不能识别,只能求助开发经理,让他在测试环境给我们测试写了一个万能验证码,再拿这个这个验证码去刷新token和或获取对应的op(op参数是内部特有的验证)

数据的唯一性,这个当时头疼了好久,最后只能去百度,最后发现jmeter还有很强大的功能,就是函数助手,里面有各种函数,例如获取时间戳,随机数,生成uuid等,直接开箱即用。

熟悉mysql的小伙伴都知道MySQL的默认最大连接数是200数据库连接池老是超标,最后查看了mysql日志发现连接数占用最大的是开发的代码里面写了很多多表联查的大SQL,尤其是公司大数据那帮人的sql一个SQL语句执行半个小时…因为去年(2020年)MTSC深圳站的时候,听了唯品会的同学分享接触到了,sql扫描检查,当时在sonar扫描代码的时候,加入了sql的扫描,和开发老大商量,去除了项目中大部分的长sql语句,最后去请教了运维的同学和公司dba的大佬,当时运维同学有点不配合的,最后买了一包好烟,在加各种舔,最终终于同意扩大数据库的连接数,最终勉强解决了这个问题。

jenkins并发机制的问题,这个是jenkisn本身就存在的瓶颈,当时给公司运维提了个需求,让他多起几个jenlkins的的节点,测试专门使用一个节点。

14.接口测试结果报告

由于使用了jmeter为了测试的时候,可以实时查看,个人建议使用 influxdb+cadvisor+grafana 搭建一套配合 jmeter 的报告可视化的监控系统。

搭建步骤如下

创建容器挂载目录

mkdir -p /dockerdata/influxdb
mkdir -p /dockerdata/grafana

安装 influxdb 数据库

docker run -d \-p 8083:8083 \-p 8086:8086 \--expose 8090 \--expose 8099 \--name influxsrv \-v $PWD:/var/lib/influxdb \influxdb;

安装 cadvisor 容器监控

docker run \
--volume=/:/rootfs:ro \
--volume=/var/run:/var/run:rw \
--volume=/sys:/sys:ro \
--volume=/var/lib/docker/:/var/lib/docker:ro \
-p 8081:8080 \
--detach=true --link influxsrv:influxsrv \
--name=cadvisor \
google/cadvisor:latest \
-storage_driver=influxdb \
-storage_driver_db=cadvisor \
-storage_driver_host=influxsrv:8086;

安装 grafana

docker run \
-d \
-p 3000:3000 \
-e INFLUXDB_HOST=localhost \
-e INFLUXDB_PORT=8086 \
-e INFLUXDB_NAME=cadvisor  \
-e INFLUXDB_USER=root \
-e INFLUXDB_PASS=root  \
--link influxsrv:influxsrv \
-v $PWD:/var/lib/grafana \
--name grafana \
grafana/grafana;

最终结果如下

图片

需要注意的点

既然使用influxdb存储jmeter的数据,那么就不得不提jmeter的Backend Listener后端控制器,的配置,这个超简单,但是我没有使用默认的,因为默认的只能查看 压测的tps这些,再加上脚本的每个场景接口我加入事务控制器,所以我采集的是事务控制器,一个事务代表一个接口或者代表多个接口;

启动了influxdb之后需要进入容器创建对应的数据库,要不数据没办法存储;

为了方便在grafana上面看到了每个接口的请求参数和返回值,这个是因为之前公司每个项目已经接入普罗米修斯的监控,在配置普罗米修斯监控的时候,我们加入了自定义监控,所以这款我直接使用普罗米修斯原有的配置的面板;

还有因为插件的原因当时遇见了influxdb里面没办法失败 “/” 所以控制器的命令 “/” 可以使用下划线代替。

13.接口测试中常见问题

接口测试经常遇到如下的bug和问题:

传入参数处理不当,导致程序 crash;

类型溢出,导致数据读出和写入不一致;

因对象权限为进行校验,可以访问其他用户敏感信息;

状态处理不当,导致逻辑出现错乱;

逻辑校验不完善,可利用漏洞获取非正当利益等。

15.接口自动化适用场景及持续集成

接口自动化框架:Jmeter+maven+Jenkins+git

Jmeter作为执行者的角色,每次负责执行具体的接口/性能测试脚本,并得到结果,生成报表。

Maven和Git是作为管理者角色,前者主要负责项目的依赖管理,而后者主要负责项目的代码管理。

Jenkins作为调度者,主要根据我们设置的build触发条件和事件调用jmeter进行测试 ## maven集成jmeter插件。

<dependency><groupId>org.apache.jmeter</groupId><artifactId>ApacheJMeter_components</artifactId><version>5.4.1</version>
</dependency>

jmeter 镜像的制作

因为在上面我们说了我们使用了自己的Backend Listener插件,由于网络原因,所以在运行docker容器的时候,我们需要将jmeter容器使用-v参数挂在到本地。

再加上网络的原因,我们只能自己制作镜像了,制作镜像的dockerfile如下:

FROM java:8
ENV http_proxy ""
ENV https_proxy ""RUN mkdir /jmeterdocker
RUN mkdir -p /jmeterdocker/test
RUN mkdir -p /jmeterdocker/test/input/jmx
RUN mkdir -p /jmeterdocker/test/input/testdata
RUN mkdir -p /jmeterdocker/test/report/html
RUN mkdir -p /jmeterdocker/test/report/jtl
RUN mkdir -p /jmeterdocker/test/report/outputdata
RUN chmod -R 777 /jmeterdockerRUN cd /jmeterdockerENV JMETER_VERSION=5.4.1
ENV JMETER_HOME=/jmeterdocker/apache-jmeter-${JMETER_VERSION}
ENV JMETER_PATH=${JMETER_HOME}/bin:${PATH}RUN wget https://archive.apache.org/dist/jmeter/binaries/apache-jmeter-${JMETER_VERSION}.tgz
RUN tar -zxvf apache-jmeter-${JMETER_VERSION}.tgz
RUN rm apache-jmeter-${JMETER_VERSION}.tgz

需要注意的点

因为使用了docker启动运行容器,那么在运行完成之后,需要在对应的shell脚本中接入如下命令在每次运行构建之前删除对应的容器。

docker rm - f [容器name]

16.目前设计的自动化接口测试案例有两个运行场景:

测试前置、开发自测

一个新的自动化接口测试案例开发完成后,直接发给接口对应的开发,安排在开发本地环境执行,一旦开发确认完成接口开发,就开始执行接口测试案例,基本上可以实时拿到测试结果,方便开发快速做出判断。【开发本地运行的方式就是打开JMeter工具,导入JMX文件,开始执行可。

回归测试:开发本地测试通过后,或整个需求手工测试通过后,把自动化的接口测试案例做分类整理,挑选出需要纳入到回归测试中的案例,在持续集成环境重新准备测试数据,并把案例纳入到持续集成的job中来,这些用于回归的接口测试案例需要配置到持续集成平台自动运行。对接口测试而言,持续集成自动化是核心内容,通过自动化的手段才能有效降低成本,提高接口测试的价值。如果使用LR、JMeter、SoapUI工具做自动化测试,工具本身支持命令行模式运行,可以结合Jenkins等自动化平台,实现项目版本更新后的自动化回归测试。

关于持续自动化回归测试的建议:

接口脚本开发时要注意参数的取值的可用性,不因为时间或数据状态的变化引起脚本不能正常运行,降低脚本维护成本。

接口回归功能的覆盖度控制,需要根据脚本的实际功能和重要性判断自动化回归覆盖度,回归内容越多脚本维护成本越高,一般应用接口不建议全功能覆盖(毕竟接口有变化会做详细测试,如果没修改其它变更可能对其产生的影响一般不会影响其逻辑判断)。

接口脚本需要一定的自动化校验能力,除请求http状态的判断外,还需要对核心内容的正常性做判断(判断内容可与数据库内容匹配等方式,不建议用写死的内容)。

持续性能测试,还需要做好相关的监控、性能指标的分析自动化,减少人工操作。

最后: 为了回馈铁杆粉丝们,我给大家整理了完整的软件测试视频学习教程,朋友们 如果需要可以自行免费领取 【保证100%免费】
在这里插 入图片描述

软件测试面试文档

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

在这里插入图片描述
在这里插入图片描述

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

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

相关文章

2024.3.1 小项目

1、机械臂 #include <myhead.h> #define SER_IP "192.168.125.32" //服务器端IP #define SER_PORT 8888 //服务器端端口号#define CLI_IP "192.168.68.148" //客户端IP #define CLI_PORT 9999 /…

Python matplotlib

目录 1、安装 matplotlib 2、绘制折线图 修改标签文字和线条粗细 校正图形 3、绘制散点图 绘制单点 绘制一系列点 自动计算数据 删除数据点的轮廓 自定义颜色 使用颜色映射 自动保存图表 4、随机漫步 创建 RandomWalk() 类 选择方向 绘制随机漫步图 给点着色 …

最简单的ubuntu远程桌面方法

最简单的ubuntu远程桌面方法 部署环境&#xff1a;Ubuntu 20.04 LTS 现在最常用的远程控制Linux系统的方法是通过XRDP、VNC等&#xff0c;但是安装配置过程繁琐复杂&#xff0c;经常出现各种问题导致连接失败&#xff0c;另外一方面延迟较高&#xff0c;操作卡顿。 经过我坚…

【Java项目介绍和界面搭建】拼图小游戏——键盘、鼠标事件

&#x1f36c; 博主介绍&#x1f468;‍&#x1f393; 博主介绍&#xff1a;大家好&#xff0c;我是 hacker-routing &#xff0c;很高兴认识大家~ ✨主攻领域&#xff1a;【渗透领域】【应急响应】 【Java】 【VulnHub靶场复现】【面试分析】 &#x1f389;点赞➕评论➕收藏 …

DDS数据分发服务——提升汽车领域数据传输效率

1.引言 随着智能化技术的快速发展&#xff0c;汽车行业正经历着一场革命性的变革。如今的分布式系统变得越来越复杂且庞大&#xff0c;对网络通信基数要求在功能和性能层面越来越高。数据分发服务&#xff08;DDS&#xff09;作为一项先进的数据传输解决方案&#xff0c;在汽车…

2369. 检查数组是否存在有效划分(动态规划)

2024-3-1 文章目录 [2369. 检查数组是否存在有效划分](https://leetcode.cn/problems/check-if-there-is-a-valid-partition-for-the-array/)思路&#xff1a;代码&#xff1a; 2369. 检查数组是否存在有效划分 思路&#xff1a; 1.状态定义:f[i]代表考虑将[0,i]是否能被有效划…

电脑要用多少V的电源?电脑电源输入电压是市电

台式电源的输出电压是多少&#xff1f; 电脑电源输出一般有三种不同的电压&#xff0c;分别是&#xff1a; 12V、5V、3.3V。 电脑电源负责给电脑配件供电&#xff0c;如CPU、主板、内存条、硬盘、显卡等&#xff0c;是电脑的重要组成部分。 工作电流根据不同的硬件及其使用状…

Python算法100例-3.3 阿姆斯特朗数

完整源代码项目地址&#xff0c;关注博主私信源代码后可获取 1.问题描述2.问题分析3.算法设计4.确定程序框架5.完整的程序6.问题拓展 1&#xff0e;问题描述 如果一个整数等于其各个数字的立方和&#xff0c;则该数称为“阿姆斯特朗数”&#xff08;亦称为自恋性数&#xff…

nacos开启鉴权+springboot配置用户名密码

nacos默认没有开启鉴权&#xff0c;springboot无需用户名密码即可连接nacos。从2.2.2版本开始&#xff0c;默认控制台也无需登录直接可进行操作。 因此本文记录一下如何开启鉴权&#xff0c;基于nacos2.3.0版本。 编辑nacos服务端的application.properties&#xff1a; # 开…

Linux/Docker 修改系统时区

目录 1. Linux 系统1.1 通过 timedatectl 命令操作1.2 直接修改 /etc/localtime 文件 2. Docker 容器中的 Linux 操作环境&#xff1a; CentOS / AlmaOSMySQL Docker 镜像 1. Linux 系统 1.1 通过 timedatectl 命令操作 使用 timedatectl list-timezones 命令列出可用的时区…

32单片机基础:旋转编码器计次

接线图如上图所示。 我们初始化一下PB0和PB1两个GPIO口外设中断&#xff0c;当然&#xff0c;这里只初始化一个外部中断也能完成功能的对于编码器而言&#xff0c;下图所示为正转的波形。如果把一相的下降沿用作触发中断&#xff0c;在中断时刻读取另一相的电平&#xff0c;正…

【算法科目】2024年第二届全国大学生信息技术认证挑战赛 题解

图像压缩 曾经看到过&#xff0c;这是一道洛谷原题&#xff0c;很可惜我没做过&#xff0c;有点看不懂就没尝试。 原题链接&#xff1a;B3851 [GESP202306 四级] 图像压缩 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 因数分解 直接枚举就行了&#xff0c;从2开始找因子&a…

Spring:EnclosingClass工具类分辨

Spring&#xff1a;EnclosingClass工具类分辨 1 前言 通过Spring的工具分辨EnclosingClass类。 测试类如下&#xff1a; package com.xiaoxu.test.enclosingClass;/*** author xiaoxu* date 2024-01-18* java_demo2:com.xiaoxu.test.enclosingClass.Outter*/ public class …

微信小程序(四十六)登入界面-进阶版

注释很详细&#xff0c;直接上代码 上一篇 此文使用了vant组件库&#xff0c;没有安装配置的可以参考此篇vant组件的安装与配置 新增内容&#xff1a; 1.手机号与验证码格式验证 2.验证码的网络申请和校验 wechat-http模块在好几篇以前已经讲了咋安装的&#xff0c;不记得的友…

最新版阿里云Linux CentOS7 ecs-user用户安装Mysql8详细教程(超简单)

经过两天的踩坑后&#xff0c;终于成功安装&#xff0c;并找到了最快捷的安装方式。接下来就由我来给大家介绍不踩坑安装大法&#xff01; 一、下载Mysql 首先前往Mysql官网下载 MySQL官方下载地址 第一步&#xff0c;选择安装包&#xff0c;这是最关键的一步&#xff0c;选错安…

使用query请求数据出现500的报错

我在写项目的时候遇到了一个问题&#xff0c;就是在存商品id的时候我将它使用了JSON.stringify的格式转换了&#xff01;&#xff01;&#xff01;于是便爆出了500这个错误&#xff01;&#xff01;&#xff01; 我将JSON.stringify的格式去除之后&#xff0c;它就正常显示了&…

昇腾ACL应用开发之硬件编解码dvpp

1.前言 在我们进行实际的应用开发时&#xff0c;都会随着对一款产品或者AI芯片的了解加深&#xff0c;大家都会想到有什么可以加速预处理啊或者后处理的手段&#xff1f;常见的不同厂家对于应用开发的时候&#xff0c;都会提供一个硬件解码和硬件编码的能力&#xff0c;这也是抛…

sql注入之sqli-labs/less-3 单引号加括号闭合

输入单引号试探&#xff1a; id1 报错信息里面出现 ) 说明闭合符合里面还有个 ) 再次试探&#xff1a;id1 ) order by 3 -- 查看回显位置&#xff1a; id-1%20%27)%20union%20select%201,2,3%20-- 查看数据库&#xff1a; id-1%20%27)%20union%20select%201,2,database()%2…

Kerberos协议攻防之黄金票据控制整个公司电脑

&#x1f449;重点内容&#xff1a; 1、网络认证、本地认证、域认证的优略势 2、域认证之Kerberos协议的认证流程详解 3、TGT、Krbtgt、KDC、TGS搞懂这些绕口的概念 4、深入理解黄金票据攻击Golden Ticket Attack 5、实战&#xff01;通过黄金票据控制内网中所有的电脑

DC-2靶机详解

写写自己打DC-2的过程 使用工具 kali DC-2的靶机下载地址为&#xff1a;https://www.vulnhub.com/entry/dc-2,311/ 环境配置。 Kali和DC-2都设置为NAT模式&#xff0c;都为仅主机模式也可以。 信息收集 arp-scan -l nmap -sn 192.168.236.0/24 获取靶机ip&#xff1a;192.16…