大家好,我是狂师!

今天给大家推荐一款开源的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测试场景。

标签: none

添加新评论