一.背景

   前段时间接触到HttpRunner自动化测试框架,发现对测试人员代码能力要求极低,用户只需准备好用例脚本即可发起测试,非常方便,故记录一下。

二.安装

  1. 运行环境

    HttpRunner框架基于Python开发语言,可以运行在macOS、Linux、Windows系统平台。

    本文实例均运行于Windows操作系统。

  2. 安装方式

    pip install httprunner

  3. 安装校验

    运行如下命令,若正常显示版本号,则说明 HttpRunner 安装成功。

    hrun -V

三.原理

  1. 基本概念

    • 测试用例

      • 测试用例必须完整独立,每条用例可独立运行

      • 一条用例需要用一个YAML/JSON文件管理

    • 测试步骤

      • 测试用例是测试步骤的有序集合

      • 针对接口测试时,一个测试步骤对应一个API

    • 测试用例集

      • 测试用例集是测试用例的无序集合

      • 集合中的测试用例相互独立,不存在先后依赖关系

    • 测试场景

      • 测试场景和 测试用例集是同一概念,都是 测试用例 的无序集合。

  2. 测试用例组织

    • 测试用例结构

    • 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

  3. 运行测试

    • 运行单个测试用例文件,并生成一个测试报告文件

      cmd命令框执行:hrun filepath/testcase.yml

    • 运行测试用例集(文件夹内包含多个测试用例文件),并生成一个测试报告文件

      cmd命令框执行:hrun testcases_folder_path

    • 高级功能

      • 可设置用例运行过程中遇到失败时不再继续运行后续用例;

      • 可设置日志打印级别

      • 保存详细运行过程数据

  4. 输出报告

    • 默认运行完测试用例会在当前路径下自动创建reports目录,里面会生成一份html格式的测试报告

    • 高级功能

      • 可自定义测试报告模板样式

      • 可指定报告生成路径

四 实践

  1. 编写YAML格式测试用例

  2. 运行测试用例

  3. 查看测试报告

    点击绿色的log按钮

五 后记

体验了一把下来会发现操作十分简单,只要学会组织测试用例,就能完成API自动化测试。

  本文只是介绍演示了最基本的流程,还有很多功能,例如通过抓包文件转换测试用例,为用例添加校验,参数关联,自定义函数传参等,待后续继续学习。

参考资料:https://cn.httprunner.org/

     https://debugtalk.com/tags/HttpRunner/

初识HttpRunner的更多相关文章

  1. Android动画效果之初识Property Animation(属性动画)

    前言: 前面两篇介绍了Android的Tween Animation(补间动画) Android动画效果之Tween Animation(补间动画).Frame Animation(逐帧动画)Andr ...

  2. 初识Hadoop

    第一部分:              初识Hadoop 一.             谁说大象不能跳舞 业务数据越来越多,用关系型数据库来存储和处理数据越来越感觉吃力,一个查询或者一个导出,要执行很长 ...

  3. python学习笔记(基础四:模块初识、pyc和PyCodeObject是什么)

    一.模块初识(一) 模块,也叫库.库有标准库第三方库. 注意事项:文件名不能和导入的模块名相同 1. sys模块 import sys print(sys.path) #打印环境变量 print(sy ...

  4. 初识IOS,Label控件的应用。

    初识IOS,Label控件的应用. // // ViewController.m // Gua.test // // Created by 郭美男 on 16/5/31. // Copyright © ...

  5. UI篇(初识君面)

    我们的APP要想吸引用户,就要把UI(脸蛋)搞漂亮一点.毕竟好的外貌是增进人际关系的第一步,我们程序员看到一个APP时,第一眼就是看这个软件的功能,不去关心界面是否漂亮,看到好的程序会说"我 ...

  6. Python导出Excel为Lua/Json/Xml实例教程(一):初识Python

    Python导出Excel为Lua/Json/Xml实例教程(一):初识Python 相关链接: Python导出Excel为Lua/Json/Xml实例教程(一):初识Python Python导出 ...

  7. 初识SpringMvc

    初识SpringMvc springMvc简介:SpringMVC也叫Spring Web mvc,属于表现层的框架.Spring MVC是Spring框架的一部分,是在Spring3.0后发布的 s ...

  8. 初识redis数据类型

    初识redis数据类型 1.String(字符串) string是redis最基本的类型,一个key对应一个value. string类型是二进制安全的.意思是redis的string可以包含任何数据 ...

  9. Redis初识、设计思想与一些学习资源推荐

    一.Redis简介 1.什么是Redis Redis 是一个开源的使用ANSI C 语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value 数据库,并提供多种语言的API.从2010 年 ...

随机推荐

  1. Codeforces Round #600 (Div. 2) C - Sweets Eating

    #include<iostream> #include<algorithm> #include<cstring> using namespace std ; typ ...

  2. opencv-python常用接口

    最直接的是参考官网:https://docs.opencv.org/4.2.0/d6/d00/tutorial_py_root.html

  3. linux 中对 mysql 数据表的基本命令

    显示数据表的结构 describe 表名; 建表 use 库名: create table 表名(字段设定列表): 将表中记录清空 delete from 表名; 删表 drop table 表名:

  4. Leetcode 74. 搜索二维矩阵 C+

    二分法,先对行二分找出结果可能存在的行,再对这一行二分查找.O(Log m+Log n),m.n分别为矩阵的高和宽. class Solution { public: bool searchMatri ...

  5. 实用sql语句合集

    1. 将选取A表的name字段  然后选择A表和B表,最后进行id相等比较 最终得到的是合集 $res = \DB::select("SELECT name FROM users,car_a ...

  6. 记manjaro图形驱动删除后的一次补救

    #一.前言 众所周知,NVIDIA的闭源驱动在Linux上的兼容性不是很好,再加上我不玩游戏,于是我就想卸载独显只留核显.我以为我装了独显和核显两种驱动,原本想直接删除独显驱动,没想到删除的是bumb ...

  7. Myeclipse的一些快捷键整理(转)

    1. [ALT+/]    此快捷键为用户编辑的好帮手,能为用户提供内容的辅助,不要为记不全方法和属性名称犯愁,当记不全类.方法和属性的名字时,多体验一下[ALT+/]快捷键带来的好处吧.    2. ...

  8. 交叉连接(CROSS JOIN)

    除了在FROM子句中使用逗号间隔连接的表外,SQL还支持另一种被称为交叉连接的操作,它们都返回被连接的两个表所有数据行的笛卡尔积,返回到的数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合 ...

  9. 开发笔记-记一个基础logback配置

    <?xml version="1.0" encoding="UTF-8"?> <configuration scan="true&q ...

  10. Apache Kafka(十二)Log Cleanup 策略

    Log Cleanup 策略 在Kafka中,存在数据过期的机制,称为data expire.如何处理过期数据是根据指定的policy(策略)决定的,而处理过期数据的行为,即为log cleanup. ...