Files
张翔 be5d5ede90 feat: 添加异常日志功能并优化UI样式
refactor: 重构后端查询逻辑和API响应处理

fix: 修复用户角色更新和文件上传问题

test: 添加前端性能测试脚本和E2E测试用例

chore: 更新依赖版本和配置文件

docs: 添加环境检查脚本和测试文档

style: 统一表格标签样式和路由命名

perf: 优化前端页面加载速度和响应时间
2026-03-24 13:32:20 +08:00

52 lines
1.3 KiB
JavaScript

import http from 'k6/http';
import { check, sleep } from 'k6';
import { Rate } from 'k6/metrics';
export let options = {
stages: [
{ duration: '30s', target: 10 },
{ duration: '1m', target: 20 },
{ duration: '30s', target: 0 },
],
thresholds: {
http_req_duration: ['p(95)<500'],
http_req_failed: ['rate<0.01'],
},
};
const BASE_URL = __ENV.BASE_URL || 'http://localhost:8084';
export function setup() {
console.log('Starting API performance test...');
console.log(`Base URL: ${BASE_URL}`);
}
export default function () {
const endpoints = [
{ method: 'GET', url: `${BASE_URL}/api/health` },
{ method: 'GET', url: `${BASE_URL}/api/users` },
{ method: 'GET', url: `${BASE_URL}/api/roles` },
{ method: 'GET', url: `${BASE_URL}/api/config` },
];
const endpoint = endpoints[Math.floor(Math.random() * endpoints.length)];
let response;
if (endpoint.method === 'GET') {
response = http.get(endpoint.url, {
tags: { name: endpoint.url },
});
}
check(response, {
'status is 200': (r) => r.status === 200,
'response time < 500ms': (r) => r.timings.duration < 500,
'response body is not empty': (r) => r.body.length > 0,
});
sleep(1);
}
export function teardown(data) {
console.log('API performance test completed');
}