Files
novalon-website/performance/load-test-summary.json
T
张翔 3e79a8a3bd feat: complete phase 4-6 - monitoring and quality gate improvements
- Add comprehensive monitoring alert rules (8 alerts)
  - Service availability, error rate, response time
  - CPU and memory usage alerts
  - Request rate and 4xx error rate monitoring

- Enhance Woodpecker quality gate
  - Split into separate steps for better visibility
  - Add E2E tests, security check, performance check
  - Update coverage threshold to 30% (previously 70%)
  - Add quality summary with clear pass/fail indicators

- Performance test results
  - 123 requests in 30s with 10 VUs
  - P95 response time: 345.55ms (target < 500ms) 
  - P99 response time: < 1000ms 
  - Error rate: 0% (target < 1%) 
  - All performance metrics meet targets
2026-03-10 13:25:17 +08:00

258 lines
5.3 KiB
JSON

{
"root_group": {
"path": "",
"id": "d41d8cd98f00b204e9800998ecf8427e",
"groups": [],
"checks": [
{
"passes": 123,
"fails": 0,
"name": "status is 200",
"path": "::status is 200",
"id": "6210a8cd14cd70477eba5c5e4cb3fb5f"
},
{
"id": "3e02485a995423a591645f4eee6c60eb",
"passes": 123,
"fails": 0,
"name": "response time < 500ms",
"path": "::response time < 500ms"
}
],
"name": ""
},
"options": {
"summaryTrendStats": [
"avg",
"min",
"med",
"max",
"p(90)",
"p(95)"
],
"summaryTimeUnit": "",
"noColor": false
},
"state": {
"isStdOutTTY": false,
"isStdErrTTY": false,
"testRunDurationMs": 32879.819
},
"metrics": {
"http_req_connecting": {
"type": "trend",
"contains": "time",
"values": {
"avg": 0.01948780487804878,
"min": 0,
"med": 0,
"max": 0.283,
"p(90)": 0,
"p(95)": 0.23639999999999997
}
},
"http_req_duration{expected_response:true}": {
"type": "trend",
"contains": "time",
"values": {
"p(90)": 91.53640000000001,
"p(95)": 345.5532999999997,
"avg": 75.34022764227645,
"min": 29.05,
"med": 46.754,
"max": 488.697
}
},
"http_req_blocked": {
"type": "trend",
"contains": "time",
"values": {
"max": 1.955,
"p(90)": 0.0188,
"p(95)": 1.5856,
"avg": 0.13820325203252054,
"min": 0.002,
"med": 0.004
}
},
"http_req_waiting": {
"type": "trend",
"contains": "time",
"values": {
"avg": 70.28063414634148,
"min": 27.337,
"med": 43.435,
"max": 485.976,
"p(90)": 88.70960000000001,
"p(95)": 292.4193999999997
}
},
"iterations": {
"contains": "default",
"values": {
"count": 123,
"rate": 3.740896505543416
},
"type": "counter"
},
"http_req_tls_handshaking": {
"contains": "time",
"values": {
"p(90)": 0,
"p(95)": 0,
"avg": 0,
"min": 0,
"med": 0,
"max": 0
},
"type": "trend"
},
"response_time": {
"contains": "default",
"values": {
"min": 29.05,
"med": 46.754,
"max": 488.697,
"p(90)": 91.53640000000001,
"p(95)": 345.5532999999997,
"avg": 75.34022764227645
},
"type": "trend"
},
"http_req_failed": {
"type": "rate",
"contains": "default",
"values": {
"rate": 0,
"passes": 0,
"fails": 123
},
"thresholds": {
"rate<0.01": {
"ok": true
}
}
},
"http_req_sending": {
"type": "trend",
"contains": "time",
"values": {
"p(95)": 0.11769999999999987,
"avg": 0.026504065040650365,
"min": 0.007,
"med": 0.014,
"max": 0.187,
"p(90)": 0.05540000000000001
}
},
"data_received": {
"contains": "data",
"values": {
"count": 15561945,
"rate": 473297.76967446203
},
"type": "counter"
},
"errors": {
"contains": "default",
"values": {
"rate": 0,
"passes": 0,
"fails": 123
},
"thresholds": {
"rate<0.01": {
"ok": true
}
},
"type": "rate"
},
"checks": {
"contains": "default",
"values": {
"rate": 1,
"passes": 246,
"fails": 0
},
"type": "rate"
},
"iteration_duration": {
"type": "trend",
"contains": "time",
"values": {
"max": 4164.717958,
"p(90)": 3715.5804494,
"p(95)": 3916.4994827,
"avg": 2532.0006926991864,
"min": 1129.295583,
"med": 2566.626708
}
},
"data_sent": {
"values": {
"rate": 283.0915827121798,
"count": 9308
},
"type": "counter",
"contains": "data"
},
"http_req_duration": {
"values": {
"avg": 75.34022764227645,
"min": 29.05,
"med": 46.754,
"max": 488.697,
"p(90)": 91.53640000000001,
"p(95)": 345.5532999999997
},
"thresholds": {
"p(95)<500": {
"ok": true
},
"p(99)<1000": {
"ok": true
}
},
"type": "trend",
"contains": "time"
},
"vus": {
"type": "gauge",
"contains": "default",
"values": {
"value": 3,
"min": 3,
"max": 10
}
},
"vus_max": {
"values": {
"value": 10,
"min": 10,
"max": 10
},
"type": "gauge",
"contains": "default"
},
"http_reqs": {
"type": "counter",
"contains": "default",
"values": {
"count": 123,
"rate": 3.740896505543416
}
},
"http_req_receiving": {
"values": {
"p(90)": 6.1480000000000015,
"p(95)": 32.66159999999997,
"avg": 5.0330894308943135,
"min": 1.583,
"med": 2.09,
"max": 54.188
},
"type": "trend",
"contains": "time"
}
}
}