目录:导读
- 前言
- 一、Python编程入门到精通
- 二、接口自动化项目实战
- 三、Web自动化项目实战
- 四、App自动化项目实战
- 五、一线大厂简历
- 六、测试开发DevOps体系
- 七、常用自动化测试工具
- 八、JMeter性能测试
- 九、总结(尾部小惊喜)
前言
1、线程组
线程组分类:
Jmeter线程组主要分为3类分别为线程组、setUp线程组、tearDown线程组
①线程组
这个就是我们通常添加运行的线程。通俗的讲一个线程组,可以看做一个虚拟用户组,线程组中的每个线程都可以理解为一个虚拟用户。
②setUp线程组
一种特殊类型的ThreadGroup的,可用于执行预测试操作。这些线程的行为完全像一个正常的线程组元件。不同的是,这些类型的线程执行测试前进行定期线程组的执行;类似LoadRunner的init,测试开始时进行初始化的工作。
③tearDown线程组
一种特殊类型的ThreadGroup的,可用于执行测试后动作。这些线程的行为完全像一个正常的线程组元件。不同的是,这些类型的线程执行测试结束后执行定期的线程组;类似LoadRunnner的end,测试结束时进行回收工作。
线程组参数:
三种不同线程组的参数设置页面都一致
①在取样器错误后执行的操作
继续:继续执行接下来的操作。
启动下一次循环:开始下一次循环。
停止线程:退出该线程(不再执行此线程的操作)。
停止测试:等待当前执行的采样器结束后,结束整个测试。
立即停止测试:马上停止测试。
②线程属性
线程数:相当于模拟的用户数量。
Ramp-up 时间(秒):达到指定线程需要的时间,例如线程数为100,时间设定为10s,那么就是10s加载100个线程,每秒启动的线程数=100/10=10。
循环次数:如果填具体的数值,就是循环对应的次数;如果选择“Forever”,则一直执行下去,直到手动停止。
same user on each iteration:每次迭代都有相同的用户,此功勾选为默认勾选。如果只是做接口测试则无需管这个参数,如果是要做模拟多线程的情况则需要取消勾选。
延迟创建线程直到需要:延迟线程创建,直到需要才创建。
调度器:
持续时间(秒):测试计划持续多长时间
启动延迟(秒):测试计划延迟多长时间启动
2、Http请求
可在线程组-取样器中添加HTTP请求
协议:向目标服务器发送http请求时的协议,http/https,大小写不敏感,默认http
服务器名称或IP:需要调用的服务器或IP
端口号:目标服务器的端口号,默认值为80,可为空
HTTP请求:可以根据实际需要请求的接口,选择请求的类型get/post…
路径:目标的URL路径(不包括服务器地址和端口)
内容编码:请求内容的编码,一般使用UTF-8
自动重定向:如果选中该选项,当发送HTTP请求后得到的响应是302/301时,JMeter 自动重定向到新的页面。
跟随重定向:Http Request取样器的默认选项,当响应Code是3XX时,自动跳转到目标地址。与自动重定向不同,jmeter会记录重定向过程中的所有请求,在查看结果树可以查看服务器返回的内容,可以对响应的内容进行关联。
使用keepalive:该选项被选中时,jmeter 和目标服务器之间使用 Keep-Alive方式进行HTTP通信,默认选中。
对POST使用multipart/form-data:当发送HTTP POST 请求时,使用Use multipart/from-data方法发送,默认不选中。
参数:可手动添加请求参数,会放到请求数据中,格式为参数名=参数。无法与消息体数据共同使用。
消息体数据:此数据会与请求一起发出,发出的格式为手动设置的格式。无法与参数选项共同使用。
文件上传:文件上传的接口在进行测试的时候需要在文件上传页面设置上传文件的属性。由文件名称、参数名称、MIME类型构成。
3、Jar包导入
Jar包导入分为三种方法:
①在测试计划直接导入jar包
②lib目录导入
可以把需要的jar包放入lib目录下,重启后此jar包即可在Jmeter模块中使用
③其余目录导入
通过修改bin目录下的jmeter.properties文件中的plugin_dependency_paths,可以引用其余目录下的jar包。
4、正则表达式提取器
在一个线程组中,B请求如果需要使用A请求返回的数据,将上一个请求的响应数据作为下一个请求的参数,则需要对A请求的响应报文使用后置处理器,其中最方便常用的就是正则表达式提取器
引用名称:Jmeter变量的名称,存储提前出的结果;
模板:表示使用提取到的第几个值,
N
N
N使用提取到的第N个值;
匹配数字:正则表达式匹配数据的结果可以看成一个数值,0表示随机取,正数N表示取第N个值;
缺省值:匹配失败时候的默认值;
正则表达式:
():表示提取字符串的部分值,前后是提取的边界内容
?:出现在该符号之前的项目是可选的,最多匹配一次
*:匹配出现0次或多次的项目
+:匹配一次或多次之前的项目
$:匹配行末的空字符串
{N}:精确匹配N次的先前项目
5、查看结果树
用来监控请求执行的结果,主要分为查看结果树、汇总报告、聚合报告等。
也可以下载第三方监听器。
下面是我整理的2023年最全的软件测试工程师学习知识架构体系图 |
一、Python编程入门到精通
二、接口自动化项目实战
三、Web自动化项目实战
四、App自动化项目实战
五、一线大厂简历
六、测试开发DevOps体系
七、常用自动化测试工具
八、JMeter性能测试
九、总结(尾部小惊喜)
在追逐梦想的路上,别停下脚步;在面对困难的时刻,别放弃希望;因为奋斗不仅是目标的实现,更是自我成长的旅程。坚信自己的力量,勇往直前,点亮人生的星辰!
初心如磐,奋斗不止;困境无阻,信念不移;梦想的火焰在胸中燃起,勇敢追逐,勇敢闯荡;每一次努力都是铺就成功之路的砖石,坚持不懈,终将书写属于自己的辉煌篇章!
奋斗是奇迹的种子,努力是它的呵护者。用汗水浇灌梦想的花朵,用坚持浇筑成功的基石。不论风雨多么狂暴,心中的勇气与热情,将引领我们驰骋向前,创造属于自己的辉煌人生!