Claude-skill-registry httpie-api-test
API 接口测试工作流,使用 HTTPie 作为核心工具。当用户需要测试 API 接口、执行接口调用、生成测试报告、管理接口依赖关系、或在项目中建立标准化的接口测试流程时使用此 skill。适用于 RESTful API 测试、接口联调、回归测试等场景。
install
source · Clone the upstream repo
git clone https://github.com/majiayu000/claude-skill-registry
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/majiayu000/claude-skill-registry "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/data/httpie-api-test" ~/.claude/skills/majiayu000-claude-skill-registry-httpie-api-test && rm -rf "$T"
manifest:
skills/data/httpie-api-test/SKILL.mdsource content
HTTPie API Test
使用 HTTPie 进行 API 测试的标准化工作流。
核心工具
HTTPie 比 curl 更优雅。安装:
# macOS brew install httpie # Ubuntu/Debian apt install httpie # pip pip install httpie
API 注册表
在项目根目录创建
api-registry.md 作为接口测试的神经中枢。完整格式见 references/api-registry.md。
基本结构
# API Registry ## Environment | Name | Value | |------|-------| | BASE_URL | https://api.example.com | | TOKEN | Bearer xxx | ## Endpoints ### [GET] /users - 获取用户列表 - Status: tested - Depends: none - Last tested: 2024-01-15 **Request:** http GET $BASE_URL/users Authorization:$TOKEN **Expected:** 200, 返回用户数组 --- ### [POST] /users - 创建用户 - Status: pending - Depends: none **Request:** http POST $BASE_URL/users Authorization:$TOKEN \ name="张三" email="test@example.com" **Expected:** 201, 返回新用户对象
工作流
1. 初始化
在项目根目录创建
api-registry.md,定义环境变量和接口列表。
2. 执行测试
读取注册表,按依赖顺序执行:
# 设置环境变量 export BASE_URL="https://api.example.com" export TOKEN="Bearer your-token" # GET http GET $BASE_URL/users Authorization:$TOKEN # POST with JSON body http POST $BASE_URL/users Authorization:$TOKEN \ name="测试" email="test@example.com" # 保存响应 http GET $BASE_URL/users Authorization:$TOKEN > response.json
3. 更新状态
测试完成后更新注册表中的
Status 和 Last tested 字段。
4. 生成报告
python scripts/generate_report.py api-registry.md -o test-report.md
HTTPie 速查
# Headers http url Header:Value # 认证 http -a user:pass url # 表单提交 http -f POST url field=value # 仅显示 headers http --headers url # 详细模式 http --verbose url
依赖管理
用
Depends 字段声明依赖关系:
### [DELETE] /users/{id} - 删除用户 - Status: pending - Depends: POST /users
测试时按依赖拓扑排序执行。
状态标记
| Status | 含义 |
|---|---|
| pending | 待测试 |
| tested | 已通过 |
| failed | 测试失败 |
| blocked | 被阻塞 |
| deprecated | 已废弃 |