前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >API测试工具-HttpRunner

API测试工具-HttpRunner

作者头像
wangmcn
发布2024-04-03 19:26:27
940
发布2024-04-03 19:26:27
举报
文章被收录于专栏:AllTests软件测试AllTests软件测试

1、前言

目前市场上存在众多 API 测试工具,例如 Postman、SoapUI、JMeter 等,它们各具特色,广泛应用于 API 的开发与测试工作。

本文将介绍一款 API 测试工具 - HttpRunner,以其简单易用,功能强大,具有丰富的插件化机制和高度的可扩展能力脱颖而出。

2、简介

HttpRunner 是一款开源的 API 测试工具,兼容 HTTP(S)、HTTP2、WebSocket、RPC 等多种网络协议,支持接口测试、性能测试、数字体验监测等多种测试类型。它操作简便,功能全面,拥有丰富的插件系统和卓越的扩展性。

功能特点:

1、全面支持网络协议:不仅完整支持 HTTP(S)/1.1 和 HTTP/2,还能灵活扩展至 WebSocket、TCP、RPC 等多种协议。

2、多样化的测试用例格式:支持 YAML、JSON、go test、pytest 等多种格式,且可轻松实现格式之间的转换。

3、双重执行引擎:集成了 golang 和 python 两种执行引擎,既保证了go 的高效性能,也享受了 pytest 丰富的生态系统。

4、便捷的用例生成方式:支持通过 HAR、Postman、Swagger、curl 等工具生成测试用例,同时提供基于链式调用的编写方法,简化测试用例的编写过程。

5、应对复杂测试场景:借助 variables、extract、validate、hooks 等机制,轻松构建复杂的测试场景。

6、插件化扩展:内置了丰富的函数库,并支持使用 go、python、java 等主流编程语言编写自定义函数,轻松扩展更多功能。

7、高效的性能测试:无需额外设置即可进行压力测试,单机轻松支持超过1万 VUM,配合分布式负载能力,可实现大规模压力测试。

8、网络性能监测:在进行场景化接口测试的同时,还能额外监测网络链路的性能指标,如 DNS 解析、TCP 连接、SSL 握手、网络传输等。

9、一键快速部署:通过二进制命令行工具分发,无需依赖特定环境,一条命令即可在 macOS、Linux、Windows 上迅速完成安装部署。

官方网址:

https://httprunner.com/

3、安装

目前 HttpRunner 经过不断迭代,已经进入到 v4.0 版本。

HttpRunner v4 融合了 Golang 和 Python 两种编程语言的优势,底层构建了两套较为独立的执行引擎,旨在实现 Golang 的高效性能与 pytest 丰富生态系统的完美结合。

HttpRunner v4 = v2 + v3 + hrp + ...

v4 版本会与之前的 v2/v3/hrp 做兼容。

一、在MacOS上安装

HttpRunner v4 采用 Golang 开发,只需在系统终端中执行一条命令即可完成安装部署。

打开终端执行:

代码语言:javascript
复制
bash -c "$(curl -ksSL https://httprunner.com/script/install.sh)"

安装完成后,获得一个hrp命令行工具。

二、在Windows上安装

1、使用pip安装

代码语言:javascript
复制
pip install httprunner

2、安装hrp命令

GitHub上下载安装包:

https://github.com/httprunner/httprunner/releases

目前最新版本v4.3.6,选择合适的版本进行下载。

作者选择下载hrp-v4.3.6-windows-amd64.zip包。

下载完成后,进行解压。

例如作者将下载后的包解压到D盘,并对目录重命名为httprunner。

将目录路径添加到系统环境变量中。

打开命令行,输入hrp,如下图,正常打印帮助信息,则说明hrp命令行工具已安装成功。

4、快速上手

一、创建项目

执行 hrp startproject 命令,即可初始化指定名称的项目工程。

例如:在终端执行命令,创建demo项目。

代码语言:javascript
复制
hrp startproject demo

目录结构:

har 录制的文件目录

results 报告目录

testcases 测试用例目录(默认包含了多个示例用例)

.env 环境配置文件

.gitignore 传git仓库时忽略文件

debugtalk.py 辅助函数功能文件

proj.json 记录创建项目的信息

二、编写用例

HttpRunner 的测试用例由两个核心部分构成:

配置(config):这是测试用例的共享配置环节,涵盖了诸如用例名称、基础 URL、参数化数据源以及是否启用 SSL 验证等设置。

测试步骤(teststeps):这部分是一系列有序的操作步骤,其设计理念借鉴了 go interface,能够灵活支持各种协议和测试类型的扩展,甚至包括用户界面(UI)自动化测试。每个 step 都是一个 HTTP 请求,描述信息仅包含了 HTTP 请求和结果校验的核心要素。

变量的定义在 step 或 config 的 variables 中。

函数的定义在项目根目录的 debugtalk.py 中。

创建 test_demo.yml 文件,用例内容(2条测试用例):

代码语言:javascript
复制
config:
    name: "get/post demo"
    variables:
        base_url: https://www.httpbin.org
        foo1: "admin"
        foo2: "123456"
        expect_foo1: "admin"
        expect_foo2: "123456"

teststeps:
-
    name: get demo
    request:
        method: GET
        url: $base_url/get
        params:
            username: $foo1
            password: $foo2
    extract:
        foo3: "body.args.username"
        foo4: "body.args.password"
    validate:
        - eq: ["status_code", 200]
        - eq: [$expect_foo1, $foo3]
        - eq: [$expect_foo2, $foo4]
-
    name: post demo
    variables:
        foo1: "admin2"
        foo3: "567890"
    request:
        method: POST
        url: $base_url/post
        headers:
            Content-Type: "text/plain"
        body: "username: $foo1; password: $foo3."
    validate:
        - eq: ["status_code", 200]
        - eq: ["body.data", "username: admin2; password: 567890."]

三、运行接口测试

使用 hrp run 命令执行指定的测试用例;如生成 HTML 测试报告,需添加 --gen-html-report 参数。

例如:

代码语言:javascript
复制
hrp run testcases/test_demo.yml --gen-html-report

执行完成后,可以看到 results 目录生成 report.html 测试报告。

打开测试报告,可以看到2条测试用例执行成功。

打开日志,可以看到具体的请求、返回、断言等信息。

四、运行性能测试

使用 hrp boom 命令运行性能测试;添加 --spawn-count 参数可指定并发用户数,添加 --spawn-rate 可指定起始发压斜率。

例如:

代码语言:javascript
复制
hrp boom testcases/test_demo.yml --spawn-count 10 --spawn-rate 2

在压测过程中,每隔 3 秒打印一次性能汇总数据;使用 CTRL + C 终止测试后,会打印整个压测过程的汇总数据(Statistics Summary)。

运行日志:

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2024-03-29,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 AllTests软件测试 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
腾讯云服务器利旧
云服务器(Cloud Virtual Machine,CVM)提供安全可靠的弹性计算服务。 您可以实时扩展或缩减计算资源,适应变化的业务需求,并只需按实际使用的资源计费。使用 CVM 可以极大降低您的软硬件采购成本,简化 IT 运维工作。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档