【软件测试】超细HttpRunner接口自动化框架使用案例,一篇策底打通...

本文主要是介绍【软件测试】超细HttpRunner接口自动化框架使用案例,一篇策底打通...,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录:导读

    • 前言
    • 一、Python编程入门到精通
    • 二、接口自动化项目实战
    • 三、Web自动化项目实战
    • 四、App自动化项目实战
    • 五、一线大厂简历
    • 六、测试开发DevOps体系
    • 七、常用自动化测试工具
    • 八、JMeter性能测试
    • 九、总结(尾部小惊喜)


前言

1、HttpRunner框架安装

# 安装httprunner
pip install httprunner# 当然也可以指定版本安装
pip install httprunner==2.3.2# 检验安装是否成功
hrun -V

2、HttpRunner框架demo介绍

#创建HttpRunner项目
hrun --startproject  demo #指定目录创建HttpRunner项目
hrun --startproject  D:\TestSoftware\Pychram\PychramProject\demo 

在这里插入图片描述

#api文件:* 用以保存单个独立的接口,最好是可以单独运行的(例如:保存一个公共方法用于case调用,调用格式:api/XXX.json或者是api/XXX.yaml)
# testcase文件:* 用以保存一个或者多个接口组成的测试用例(也能集合其它case进行顺序执行,调用格式:testcase/xxx.json或者是api/XXX.yaml)# 执行测试用例则在项目控制台下:
hrun testcases/xx.json
# 或
hrun testcases/xx.yaml# testsuites文件:* 多个测试用例的集合(用例集执行顺序是无序的)
# reports文件:* 运行用例后生成测试报告的位置# debugtalk.py文件:* 在文件中定义方法(可以用其它.py文件写方法再进行调用,调用格式:${getdemo())# .env文件:* 自定义变量(调用格式:${.ENV(demo)}

因不同公司要求不一样,JSON与Yaml文件可以在:http://www.json2yaml.com/ 上互传

3、以JSON文件处理不同方式的请求

1)get方式发送请求

# 在testcases下新建 get请求.json
{"config": {"name": "模块名称","base_url": "主机IP地址和端口"},"teststeps": [{"name":"Get方式","request": {"url": "/Api url地址","method": "GET","params": {"username": "abc","password": "123","phone": "12345678901","email": "abc@163.com"}}}]
}

2)post方式发送请求

# 在testcases下新建 post请求.json
{"config": {"name": "模块名称","base_url": "主机IP地址和端口"},"teststeps": [{"name": "Post方式","request": {"url": "API url地址","method": "POST","data": {"username": "zhangsan","password": "123"}},"validate":[{"contains": ["content.msg","登录成功!!"]}]}]
}

3)json方式发送请求

# 在testcases下新建 json请求.json
{"config": {"name": "模块名称","base_url": "主机IP地址和端口"},"teststeps": [{"name": "json报文处理","request": {"url": "/Api url地址","method": "POST","json": {"username": "lisi","password": "123","phone": "123456","email": "lisi@163.com"}},"validate": [{"eq": ["content.msg","注册成功"]}]}]
}

4)上传文件
首先在debugtalk.py文件里添加getFile函数

def getFile():f = open("文件存放地址\\文件名称.png",mode="rb")return f
# 在testcases下新建 Uploadfile.json
# 使用${getFile()} 引用函数
{"config": {"name": "模块名称","base_url": "主机IP地址和端口"},"teststeps": [{"name": "上传文件","request": {"url": "/Api url地址","method": "POST","data": {"username": "lisi"},"files":{"pic": ["woman0.png","${getFile()}","image/png"]}}}]
}

5)参数化

第一种方式-variables设置变量

# 在testcases下新建 parameter.json
{"config": {"name": "模块名称","base_url": "主机IP地址和端口","variables": {"name": "a8","pwd": "123456"}},"teststeps": [{"name": "参数化","request": {"url": "/Api url地址","method": "POST","data": {"username": "$name","password": "$pwd"}},"validate": [{"eq":["content.msg","success"]}]}]
}

第二种方式–p获取函数

首先在项目目录下新建package dada,在data下创建user.csv文件

name,pwd,extra
a1,123,success
a2,456,登录失败
#¥@,123,登录失败

再在testsuites目录下新建 login_param.json

{"config": {"name": "login_参数化处理"},"testcases": [{"name": "loginTest","testcase": "testcases/login.json", "parameters": [{"name-pwd-extra":"${P(data/user.csv)}"}]}]
}

最后在testcases目录下,新建login.json

#  直接引用自定义名称
{"config": {"name": "模块名称","base_url": "主机Ip和端口"},"teststeps": [{"name": "登录","request": {"url": "Api url地址","method": "POST","data": {"username": "$name","password": "$pwd"}},"validate":[{"contains": ["content.msg","$extra"]}]}]
}

6)接口依赖处理

# 在testcases下新建 api依赖.json
{"config": {"name": "模块名称","base_url": "主机IP地址和端口","variables": {"name": "b1","pwd": "123456","email": "b1@163.com"}},"teststeps": [{"name": "获取验证码","request": {"url": "/Api url地址","method": "GET"},"extract": [{"code": "content.data.code"}],"validate": [{"eq": ["content.msg","success"]}]},{"name": "注册","request": {"url": "/Api url地址","method": "POST","data": {"username": "$name","password":"$pwd" ,"email":"$email" ,"verifyCode":"$code"}},"validate": [{"contains": ["content.msg","注册成功"]}]}]
}

4、批量执行case

在testsuites目录下新建 批量执行.json

{"config": {"name": "接口自动化学习案例"},"testcases": [{"name": "测试_get请求","testcase": "testcases/get请求.json"},{"name": "测试_post请求","testcase": "testcases/post请求.json"},{"name": "测试_json请求","testcase": "testcases/json请求.json"},{"name": "测试_json请求","testcase": "testcases/Uploadfile.json"},{"name": "测试_依赖处理","testcase": "testcases/api依赖.json"}]
}

控制台

hrun testsuites/批量执行.json 

5、输出测试报告

1)原生测试报告

通过控制台 hrun testsuites/xx.json 测试通过后,在项目目录下的reports下自动生成报告

在这里插入图片描述

2)测试报告优化

进入在Lib\site-packages\httprunner\static下 ,添加extent_report_template.html,在Lib\site-packages\httprunner下,修改report.py中的默认报告路径

在这里插入图片描述

修改后变更为:

在这里插入图片描述

下面是我整理的2023年最全的软件测试工程师学习知识架构体系图

一、Python编程入门到精通

请添加图片描述

二、接口自动化项目实战

请添加图片描述

三、Web自动化项目实战

请添加图片描述

四、App自动化项目实战

请添加图片描述

五、一线大厂简历

请添加图片描述

六、测试开发DevOps体系

请添加图片描述

七、常用自动化测试工具

请添加图片描述

八、JMeter性能测试

请添加图片描述

九、总结(尾部小惊喜)

只要你有梦想,就要勇敢地去追求它,不要被困难和阻碍所吓倒。相信自己的能力和价值,坚定地走下去,成功就在前方等待着你!

每一次的努力都是一次积累,每一次的奋斗都是一次成长。不要畏惧困难,坚持追逐梦想,因为只有不停前行,才能创造属于自己的辉煌人生!

成功需要的不仅仅是才华和机遇,更需要的是坚持和不懈的努力。只要你保持着热情和毅力,就一定能够实现自己的理想!

这篇关于【软件测试】超细HttpRunner接口自动化框架使用案例,一篇策底打通...的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/286673

相关文章

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]