50 lines
1.4 KiB
Bash
50 lines
1.4 KiB
Bash
#!/bin/bash
|
||
|
||
# 用户管理系统 API 测试脚本
|
||
|
||
TEST_ADMIN_ACCOUNT="${TEST_ADMIN_ACCOUNT:-admin}"
|
||
if [ -z "${TEST_ADMIN_PASSWORD:-}" ]; then
|
||
echo "请先设置 TEST_ADMIN_PASSWORD"
|
||
exit 1
|
||
fi
|
||
|
||
echo "=== 1. 健康检查 ==="
|
||
curl http://localhost:8080/health
|
||
echo -e "\n"
|
||
|
||
echo "=== 2. 用户注册 ==="
|
||
curl -X POST http://localhost:8080/api/v1/auth/register \
|
||
-H "Content-Type: application/json" \
|
||
-d '{"username":"testuser","password":"Test123456","email":"test@example.com"}'
|
||
echo -e "\n"
|
||
|
||
echo "=== 3. 用户登录(admin) ==="
|
||
LOGIN_RESPONSE=$(curl -s -X POST http://localhost:8080/api/v1/auth/login \
|
||
-H "Content-Type: application/json" \
|
||
-d "{\"account\":\"${TEST_ADMIN_ACCOUNT}\",\"password\":\"${TEST_ADMIN_PASSWORD}\"}")
|
||
|
||
echo "$LOGIN_RESPONSE"
|
||
|
||
# 提取token
|
||
TOKEN=$(echo $LOGIN_RESPONSE | grep -o '"access_token":"[^"]*' | cut -d'"' -f4)
|
||
|
||
echo -e "\n=== 4. 获取用户信息 ==="
|
||
if [ -n "$TOKEN" ]; then
|
||
curl -X GET http://localhost:8080/api/v1/auth/userinfo \
|
||
-H "Authorization: Bearer $TOKEN"
|
||
echo -e "\n"
|
||
else
|
||
echo "无法获取token,跳过此测试"
|
||
fi
|
||
|
||
echo -e "\n=== 5. 测试限流(连续快速请求) ==="
|
||
for i in {1..6}; do
|
||
echo "第 $i 次登录请求:"
|
||
curl -s -X POST http://localhost:8080/api/v1/auth/login \
|
||
-H "Content-Type: application/json" \
|
||
-d '{"account":"wrong","password":"wrong"}'
|
||
echo ""
|
||
done
|
||
|
||
echo -e "\n测试完成!"
|