大家好,我是狂师!
今天给大家推荐一款开源的HTTP测试工具:Hurl
,相比curl
、wget
功能更强大,且更容易上手、很适用新手使用。
1、项目介绍
Hurl
是一个使用Rust
语言开发的命令行工具,它允许用户运行以简单纯文本格式定义的HTTP请求。这个工具不仅适用于获取数据,还非常适合用于测试HTTP会话和API。
项目地址:
https://github.com/Orange-OpenSource/hurl
Hurl的主要特性和用途包括但不限:
- 请求发送与捕获:Hurl可以发送HTTP请求,并捕获响应中的值。这使得用户可以方便地执行各种HTTP操作,并收集所需的响应数据。
- 查询与评估:Hurl支持对标头和正文响应进行查询和评估。用户可以使用XPath和JSONPath等多种查询方式,以满足不同的测试需求。
- 链式调用:Hurl支持多个请求的链式调用,这使得用户可以方便地构建复杂的测试用例,从而更全面地测试HTTP会话或API。
- 集成与报告:Hurl易于集成到CI/CD(持续集成/持续部署)流程中,支持生成多种格式的报告,如文本报告、JUnit报告和HTML报告,这有助于用户分析和理解测试结果。
- 适用于多种场景:Hurl不仅适用于REST/JSON API的测试,还适用于HTML内容、GraphQL以及SOAP API等多种场景。
总的来说,Hurl是一个非常灵活且功能丰富的命令行工具,它不仅可以发送HTTP请求,还可以将这些请求链接在一起,形成请求链。这个特性使得Hurl在模拟复杂的用户交互场景时特别有用。此外,Hurl还能够捕获请求中的特定值,并对响应头部和响应正文中的信息进行查询和评估。
无论是对于初学者还是经验丰富的测试人员,Hurl都是一个值得考虑的选择。
2、不同平台安装下载
Hurl作为一个功能强大的命令行HTTP请求工具,其安装步骤在不同的操作系统上会有所不同。以下是针对各个平台的安装操作步骤:
- Mac用户:可以通过Homebrew来安装Hurl。在终端中输入命令,按照提示完成安装过程。
brew install hurl
- Windows用户:可以访问Hurl的GitHub发布页面,下载最新版本的安装包,然后按照提示进行安装。
https://github.com/Orange-OpenSource/hurl/releases
- Linux用户:可以使用包管理器来安装Hurl。例如,在基于Debian的系统上,可以使用
apt-get install hurl
命令来安装。
3、Hurl使用
1、GET请求
# Get home:
GET https://example.org
HTTP 200
[Captures]
csrf_token: xpath "string(//meta[@name='_csrf_token']/@content)"
# Do login!
POST https://example.org/login?user=toto&password=1234
X-CSRF-TOKEN: {{csrf_token}}
HTTP 302
2、POST请求
POST https://example.org/api/tests
{
"id": "4568",
"evaluate": true
}
HTTP 200
[Asserts]
header "X-Frame-Options" == "SAMEORIGIN"
jsonpath "$.status" == "RUNNING" # Check the status code
jsonpath "$.tests" count == 25 # Check the number of items
jsonpath "$.id" matches /\d{4}/ # Check the format of the id
Hurl虽是一个命令行工具,但Hurl的主要使用方式是通过编写Hurl文件,这些文件包含了要发送的HTTP请求的定义。然后,用户可以通过Hurl命令行工具来运行这些文件,发送请求并获取响应。
示例一:发送GET请求并输出响应
1、创建Hurl文件内容 (example1.hurl)
GET https://api.example.com/data
2、执行命令行
hurl example1.hurl
example1.hurl 是包含HTTP请求的Hurl文件。
执行此命令后,Hurl会发送一个GET请求到https://api.example.com/data
,并在终端输出服务器的响应。
示例二:发送POST请求并携带JSON数据
1、创建Hurl文件内容 (example2.hurl)
POST https://api.example.com/create
Content-Type: application/json
{
"name": "John Doe",
"age": 30
}
2、执行命令行
hurl example2.hurl
执行命令后,Hurl会发送POST请求到https://api.example.com/create
,并在请求体中携带JSON数据。
示例三:使用变量和链式请求
1、创建Hurl文件内容 (example3.hurl)
GET https://api.example.com/user/123
# 捕获响应中的token
{{token}} = response.headers.get("X-Auth-Token")
GET https://api.example.com/data
Authorization: Bearer {{token}}
2、执行命令行
hurl example3.hurl
3、执行解释:
- 第一个GET请求用于获取用户的认证token。
{{token}} = response.headers.get(“X-Auth-Token”) 这行代码捕获响应头中的X-Auth-Token值,并将其存储在token变量中。 - 第二个GET请求使用了前面捕获的token变量作为Authorization头的值,用于后续的认证。
- 执行命令后,Hurl会按照顺序执行两个请求,并在第二个请求中使用第一个请求的响应数据。
示例四:包含断言和隐式验证
1、创建Hurl文件内容 (example4.hurl)
GET https://api.example.com/status
# 隐式验证:检查状态码是否为200
HTTP/1.1 200
# 显式断言:检查响应体是否包含特定文本
assert contains(response.body, "OK")
2、执行命令行:hurl example4.hurl
3、执行解释
- 发送GET请求到https://api.example.com/status。
- 隐式验证是通过在Hurl文件中直接指定期望的HTTP状态码(这里是200)来完成的。如果服务器的响应状态码与指定的不同,Hurl会报错。
- 显式断言使用assert关键字来检查响应体是否包含"OK"文本。如果不包含,测试将失败。
这些示例展示了Hurl的基本用法和一些高级特性,如变量捕获、链式请求和断言验证。
你可以根据自己的需求,结合Hurl的文档和这些示例,构建更复杂的HTTP测试场景。