接口测试框架Python:Requests、HttpRunner

文章目录

以前不了解httpRunner实现机制很不喜欢它,认为就是简单的接口录制与回放,只适合处理简单的接口逻辑。随着最近对httpRunner再次解读,发现它也能实现复杂接口的自动化用例,而且对于场景类的实现很快(不涉及特殊处理的,只要做好参数管理)。对于特殊处理的接口,针对特殊部分可以通过封装方法实现调用,如接口的加密,cookie失效等等。

httprunner源码:https://github.com/httprunner/httprunner

环境准备

涉及多个项目且项目接口实现的机制差距大,建议创建多个自动化项目且环境配置虚拟化以便解决包之间的冲突问题。

创建虚拟化环境步骤

1 创建虚拟环境:C:\py_workspace>python -m venv /venv
2 进入\venv\Scripts目录,激活虚拟环境:activate
3 返回上2级目录
4 安装虚拟安装包:pip install httprunner==3.1.6 (hrun3 低版本支持创建项目,高版本不支持)
5 查看httprunner版本:httprunner -V
6 查看帮助文档: httprunner -h
7 创建项目:httprunner startproject baseProduct

录制接口

Charles或fiddler或浏览器抓包,过滤需要使用的host接口,另存为.har文件,把录制的接口放置在创建的项目的har目录下。

生成用例

 查看用例生成命令:har2case -h

   用例生成命令:har2case  xxx.har 默认生成py文件,也可以指定生成yml文件-->har2case  xxx.har  -2y

转换用例格式

  查看用例格式生成命令:hmake -h

    把默认用例格式转换为pytest默认格式:hmake testcases

备注:转换过程中可能出现click包依赖异常(black是python中用来格式化代码等库,但是本地安装完成后,遇到了这个报错,需要重新安装低版本),具体见截图

解决:pip install click==8.0.2

 

运行用例

hrun testcases
hrun -s testcases  打印运行日志

设置变量

全局变量:定义在类变量config

1 config = Config("testcase description").verify(False).variables(
2 **{
3 "uuid": "VJ7N5NBw",
4 'cookies': "${get_online_cookie()}"
5 }
6 )

base_url 特殊的全局变量:

  主域名设置,一个文件设置一个,引用方式:请求方法对应的URL参数,只要写路径即可

局部变量:

 1、定义在每个step里 .with_variables({'courseId':'1000'})

    2、引用: 每个请求对应的请求参数 .with_params(**{"time": "1670292083257",'course': '$courseId'}

提取响应字段

  提取字段语法:数据来源父级,如body、headers、cookies

.extract().with_jmespath('body.result.uuid', 'uid')
.extract().with_jmespath('headers.origin', 'origin')
.extract().with_jmespath('cookies.“set-cookie“', 'cookie')

  引用变量:

  1、不涉及边界的变量引用

Step(
RunRequest("/gateway/xxx/userInfo")
.get(
"/gateway/xxx/userInfo"
)
.with_params(**{"time": "1670292083257"})
.with_headers(
**{
"Cookie": "$cookies"
}
)

  2、涉及边界变量引用:

Step(
RunRequest("/gateway/xxx/userInfo")
.get(
"/gateway/xxx/userInfo"
)
.with_params(**{"time": "1670292083257"})
.with_headers(
**{
"Cookie": "${cookies}testor"
}
)

  3、动态引入函数变量

config = Config("testcase description")\
.verify(False)\
.variables(
**{
"uuid": "V...w",
'cookies': "${get_online_cookie()}"
}
)

hook机制

HttpRunner中,我们可以通过hook机制来实现 setUp() 和 tearDown(),其对应的实现函数可以封装在其他模块

setup_hook:主要用于处理接口的前置的准备工作
teardown_hook:主要用于后置清理工作

用例分层

用例分层需要考虑用例的调用与参数调用。用例调用通过RunTestCase类的call方法实现,模块间的参数可以通过export实现传递。特别需关注call调用的用例文件名不要含有test,不然会被当作测试文件执。

用例分层demo截图

导出变量:Config()配置 .export("",)

引用上面导出的变量

用例的参数化

先在需要参数化测试类名下定义参数化字段,这样整个文件都可使用定义的参数。HttpRunner3.x支持3种参数化规则:

  1、自己定义的变量数组

  2、debugtalk.py函数返回值中

  3、外部文件中

参数化是固定格式,不能修改否则报错。一般自动化用例涉及参数化的使用很少,如果需要参数化会把整个信息配置化便于遍历和断言。

 1 @pytest.mark.parametrize(
2 "param",
3 Parameters(
4 {
5 "user_agent": ["iOS/10.1", "iOS/10.2"], ##自定义参数
6 "username-password": "${parameterize(request_methods/account.csv)}",##外部文件
7 "app_version": "${get_app_version()}",##debugtalk.py 定义函数
8 }
9 ),
10 )
11 def test_start(self, param):
12 super().test_start(param)

报告

  pytest自带报告:hrun testcases/origin_test.py -s --html=origin.html

  allure报告:hrun testcases/origin_test.py  --alluredir=allurereports/

  打开报告:open report文件名

性能

  locust是python语言开发的一款的开源的的性能测试框架,他比jmeter更加的轻量级,主要是通过协程(gevent)的方式去实现并发,通过协程的方式可以大幅提高单机的并发能力,同时避免系统级的资源调度。locust具有开源性、分布式、支持高并发,支持webUI的操作方式。我推荐locus主要是集成好的压测工具,不需要额外在写压测脚本可实现用例的高复用。而且配合用例管理平台,不论功能测试还是开发都可以根据自己的需要执行对应的接口要求。

命令:locusts -f testcases/online_origin_test.py,执行命令会唤起locusts服务,通过web访问地址:http://localhost:8089/(请用Chrome浏览器)

locusts 参考链接:https://www.jb51.net/article/207182.htm

httpRunner使用汇总的更多相关文章

  1. 一、HttpRunner学习汇总

    HttpRunner是一款面向Http和HTTPS协议的通用测试框架,只需编写维护一份YAML/JSON脚本即可实现自动化测试.性能测试.线上监控.持续集成等多种测试需求,是基于关键字驱动的框架,基于 ...

  2. 【HttpRunner v3.x】笔记—8.运行testcase的几种方式

    在之前的demo过程中,已经运行过testcase了,那这篇就也来汇总一下,运行case相关的知识点. 一.运行testcase的几种场景 1. 运行单个case 通常单个case的话我会在编辑器里用 ...

  3. 常用 Gulp 插件汇总 —— 基于 Gulp 的前端集成解决方案(三)

    前两篇文章讨论了 Gulp 的安装部署及基本概念,借助于 Gulp 强大的 插件生态 可以完成很多常见的和不常见的任务.本文主要汇总常用的 Gulp 插件及其基本使用,需要读者对 Gulp 有一个基本 ...

  4. 异常处理汇总 ~ 修正果带着你的Net飞奔吧!

    经验库开源地址:https://github.com/dunitian/LoTDotNet 异常处理汇总-服 务 器 http://www.cnblogs.com/dunitian/p/4522983 ...

  5. UWP开发必备:常用数据列表控件汇总比较

    今天是想通过实例将UWP开发常用的数据列表做汇总比较,作为以后项目开发参考.UWP开发必备知识点总结请参照[UWP开发必备以及常用知识点总结]. 本次主要讨论以下控件: GridView:用于显示数据 ...

  6. Oracle手边常用70则脚本知识汇总

    Oracle手边常用70则脚本知识汇总 作者:白宁超 时间:2016年3月4日13:58:36 摘要: 日常使用oracle数据库过程中,常用脚本命令莫不是用户和密码.表空间.多表联合.执行语句等常规 ...

  7. Oracle 数据库知识汇总篇

    Oracle 数据库知识汇总篇(更新中..) 1.安装部署篇 2.管理维护篇 3.数据迁移篇 4.故障处理篇 5.性能调优篇 6.SQL PL/SQL篇 7.考试认证篇 8.原理体系篇 9.架构设计篇 ...

  8. Vertica 数据库知识汇总篇

    Vertica 数据库知识汇总篇(更新中..) 1.Vertica 集群软件部署,各节点硬件性能测试 2.Vertica 创建数据库,创建业务用户测试 3.Vertica 数据库参数调整,资源池分配 ...

  9. 读书笔记汇总 - SQL必知必会(第4版)

    本系列记录并分享学习SQL的过程,主要内容为SQL的基础概念及练习过程. 书目信息 中文名:<SQL必知必会(第4版)> 英文名:<Sams Teach Yourself SQL i ...

  10. 关于DDD的学习资料汇总

    DDD(Domain-Driven Design)领域驱动设计,第一次看到DDD是在学习ABP时,在其中的介绍中看到的.what,DDD是个什么鬼,我不是小白,是大白,没听过.于是乎,度娘查查查,找到 ...

随机推荐

  1. [论文总结] kmeans聚类和WGCNA

    kmeans聚类和WGCNA 文章目录 kmeans聚类和WGCNA 论文1 论文2 论文3 总结 总结了3篇论文中kmeans聚类和WGCNA的运用. 论文1 Comprehensive disse ...

  2. [LeetCode]对角线遍历

    题目 代码 class Solution { public: vector<int> findDiagonalOrder(vector<vector<int>>&a ...

  3. 安装pytorch-gpu的经验与教训

    首先说明 本文并不是安装教程,网上有很多,这里只是自己遇到的一些问题 我是以前安装的tensorflow-gpu的,但是发现现在的学术论文大部分都是用pytorch复现的,因此才去安装的pytorch ...

  4. CF896E Welcome home, Chtholly

    题面 维护一个\(n(n\leqslant 100000)\)个元素序列\(a_1,a_2,\dots,a_n\),有\(m(m\leqslant 100000)\)次操作,分为如下两种. 给定\(l ...

  5. P1605迷宫——题解

    展开 题目背景 给定一个N*M方格的迷宫,迷宫里有T处障碍,障碍处不可通过.给定起点坐标和终点坐标,问: 每个方格最多经过1次,有多少种从起点坐标到终点坐标的方案.在迷宫中移动有上下左右四种方式,每次 ...

  6. Golang如何实现节假日不打扰用户?

    ​ 1.场景 想象下以下场景,嘿嘿...! 一个iphone用户,闹钟是可以按节假日不响的! 每日新闻机器人,节假日是可以不打扰我的! 我的业务,节假日是可以... 2.思路 要实现识别节假日,大概有 ...

  7. 超简单的图文并茂Linux上使用yum安装Mysql(Aliyun Linux release 2.1903 LTS)

    首先登录进入你的Linux服务器 查看是否已安装mysql rpm -qa|grep mysql 查看自己的服务器版本 cat /etc/redhat-release 打开MySQL Yum存储库下载 ...

  8. 如何用Python实现http客户端和服务器

    功能:客户端可以向服务器发送get,post等请求,而服务器端可以接收这些请求,并返回给客户端消息. 客户端: #coding=utf-8import http.clientfrom urllib i ...

  9. APP测试注意点-安装卸载与运行

    1.安装和卸载 应用在不同系统版本的ios和android是否可以正常安装(适配问题) 安装过程中是否可以取消 手机存储空间不足时安装应用是否有相应提示信息 安装后的应用是否可以正常卸载 卸载后是否会 ...

  10. Vue3源码阅读梳理

    简单代码例子 const { createApp, defineComponent, computed, watch, ref, reactive, effect } = Vue const app ...