初识HttpRunner
一.背景
前段时间接触到HttpRunner自动化测试框架,发现对测试人员代码能力要求极低,用户只需准备好用例脚本即可发起测试,非常方便,故记录一下。
二.安装
运行环境
HttpRunner框架基于Python开发语言,可以运行在macOS、Linux、Windows系统平台。
本文实例均运行于Windows操作系统。
安装方式
pip install httprunner安装校验
运行如下命令,若正常显示版本号,则说明 HttpRunner 安装成功。
hrun -V
三.原理
基本概念
测试用例
测试用例必须完整独立,每条用例可独立运行
一条用例需要用一个YAML/JSON文件管理
测试步骤
测试用例是测试步骤的有序集合
针对接口测试时,一个测试步骤对应一个API
测试用例集
测试用例集是测试用例的无序集合
集合中的测试用例相互独立,不存在先后依赖关系
测试场景
测试场景和 测试用例集是同一概念,都是 测试用例 的无序集合。
测试用例组织
测试用例结构

Testcase编写
YAML/JSON文件的数据存储结构为list of dict形式,其中可能包含一个全局配置项(config)和若干个测试步骤(test)config:作为整个测试用例的全局配置项
test:对应单个测试步骤(teststep),测试用例存在顺序关系,运行时将从前往后依次运行各个测试步骤
config详细说明
作用域为整个测试用例
- config:
name: demoTestCase
base_url: http://morse.qa-sh.56qq.com
variables:
bd-token: XXXXXXXXXXXXXXX==
bd-app-uid: XXXXXXXXXXXXXXXXXXXa6c2-1c5119c570e3
test详细说明
作用域仅限本身
- test:
name: test_three_elec
request:
headers:
bd-app-uid: a365474c-a7e6-4b3d-a6c2-1c5119c570e3
bd-token: 6fEkwIF8NwKgnpEG1JTTg==
method: POST
url: /three_elec/do-check.do
params:
name: 蒋xx
idcard: 511323xxxxxx33092
mobile: 1818095xxxx
运行测试
运行单个测试用例文件,并生成一个测试报告文件
cmd命令框执行:
hrun filepath/testcase.yml运行测试用例集(文件夹内包含多个测试用例文件),并生成一个测试报告文件
cmd命令框执行:
hrun testcases_folder_path高级功能
可设置用例运行过程中遇到失败时不再继续运行后续用例;
可设置日志打印级别
保存详细运行过程数据
输出报告
默认运行完测试用例会在当前路径下自动创建reports目录,里面会生成一份html格式的测试报告
高级功能
可自定义测试报告模板样式
可指定报告生成路径
四 实践
编写YAML格式测试用例

运行测试用例

查看测试报告

点击绿色的log按钮

五 后记
体验了一把下来会发现操作十分简单,只要学会组织测试用例,就能完成API自动化测试。
本文只是介绍演示了最基本的流程,还有很多功能,例如通过抓包文件转换测试用例,为用例添加校验,参数关联,自定义函数传参等,待后续继续学习。
参考资料:https://cn.httprunner.org/
https://debugtalk.com/tags/HttpRunner/
初识HttpRunner的更多相关文章
- Android动画效果之初识Property Animation(属性动画)
前言: 前面两篇介绍了Android的Tween Animation(补间动画) Android动画效果之Tween Animation(补间动画).Frame Animation(逐帧动画)Andr ...
- 初识Hadoop
第一部分: 初识Hadoop 一. 谁说大象不能跳舞 业务数据越来越多,用关系型数据库来存储和处理数据越来越感觉吃力,一个查询或者一个导出,要执行很长 ...
- python学习笔记(基础四:模块初识、pyc和PyCodeObject是什么)
一.模块初识(一) 模块,也叫库.库有标准库第三方库. 注意事项:文件名不能和导入的模块名相同 1. sys模块 import sys print(sys.path) #打印环境变量 print(sy ...
- 初识IOS,Label控件的应用。
初识IOS,Label控件的应用. // // ViewController.m // Gua.test // // Created by 郭美男 on 16/5/31. // Copyright © ...
- UI篇(初识君面)
我们的APP要想吸引用户,就要把UI(脸蛋)搞漂亮一点.毕竟好的外貌是增进人际关系的第一步,我们程序员看到一个APP时,第一眼就是看这个软件的功能,不去关心界面是否漂亮,看到好的程序会说"我 ...
- Python导出Excel为Lua/Json/Xml实例教程(一):初识Python
Python导出Excel为Lua/Json/Xml实例教程(一):初识Python 相关链接: Python导出Excel为Lua/Json/Xml实例教程(一):初识Python Python导出 ...
- 初识SpringMvc
初识SpringMvc springMvc简介:SpringMVC也叫Spring Web mvc,属于表现层的框架.Spring MVC是Spring框架的一部分,是在Spring3.0后发布的 s ...
- 初识redis数据类型
初识redis数据类型 1.String(字符串) string是redis最基本的类型,一个key对应一个value. string类型是二进制安全的.意思是redis的string可以包含任何数据 ...
- Redis初识、设计思想与一些学习资源推荐
一.Redis简介 1.什么是Redis Redis 是一个开源的使用ANSI C 语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value 数据库,并提供多种语言的API.从2010 年 ...
随机推荐
- Android开发之JDK配置,及ADT下载
第一步: 到官网上下载jdk,记住关键的一点,首先要查看自己的windows电脑是32位的还是64位的,这里想下载相应的位数的jdk 第二步: 安装JDK,一般默认安装路径,不做自己修改安装路径,如: ...
- Vue.js ---Hello---1
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- Cannot find module 'less-bundle-promise'
Error: Cannot find module 'less-bundle-promise' 解决办法 :npm install less-bundle-promise --save
- Linux - Shell - 免密码登录
概述 简述 linux ssh 无密码登录 无能狂怒 最近真是不知道写啥了 环境 os centos7 1. 场景 场景 主机A 需要经常访问 主机B 每次访问, 都要输入一次 密码 问题 每次都输密 ...
- eclipse的安装和环境配置
一,eclipse下载 地址:https://www.eclipse.org/downloads/ 一般浏览器都有翻译功能 二.有32位和64位的版本根据自己的需求下载,选下载的选下载量最多的下载. ...
- orcad常用库文件
ORCAD CAPTURE元件库介绍 AMPLIFIER.OLB amplifier 共182个零件,存放模拟放大器IC,如CA3280,TL027C,EL4093等. ARITHMETIC.OLB ...
- 结合Thread Ninja明确与处理异步协程中的异常
Thread Ninja说明: Thread Ninja - Multithread Coroutine Requires Unity 3.4.0 or higher. A simple script ...
- 虚拟机linux系统网络连接配置问题总结
1.虚拟机与CentOS的安装与配置参考本人博客:https://www.cnblogs.com/ClikeL/p/11743520.html 2.测试网络连接 ping www.baidu.com ...
- 记manjaro图形驱动删除后的一次补救
#一.前言 众所周知,NVIDIA的闭源驱动在Linux上的兼容性不是很好,再加上我不玩游戏,于是我就想卸载独显只留核显.我以为我装了独显和核显两种驱动,原本想直接删除独显驱动,没想到删除的是bumb ...
- input标签中的id和name的区别
做网站很久了,但到现在还没有搞明白input中name和id的区别,最近学习jquery,又遇到这个问题,就在网上搜集资料.看到这篇,就整理出来,以备后用. 可 以说几乎每个做过Web开发的人都问过, ...