fail_count is computed from TestResult rows, not from test.failed. test.failed only reflects whether the final progress status is canceled — it does not reflect regression test outcomes. Use this endpoint, not test.failed, to triage a run.
GET
/runs/{run_id}/summary
curl \
--request GET 'https://sampleplatform.ccextractor.org/api/v1/runs/{run_id}/summary' \
--header "Authorization: Bearer $ACCESS_TOKEN"
Response examples (200)
{
"run_id": 42,
"total_samples": 42,
"pass_count": 42,
"fail_count": 42,
"skipped_count": 42,
"missing_output_count": 42,
"error_count": 42,
"duration_ms": 42,
"triggered_by": "string"
}
Response examples (401)
{
"code": "unauthorized",
"message": "Bearer token is missing, expired, or invalid.",
"details": {}
}
Response examples (404)
{
"code": "not_found",
"message": "Run 9317 not found.",
"details": {
"resource": "run",
"id": 9317
}
}
Response examples (429)
{
"code": "rate_limited",
"message": "Rate limit exceeded. Retry after 30 seconds.",
"details": {
"retry_after": 30,
"limit": 120,
"window": "60s"
}
}
Response examples (default)
{
"code": "not_found",
"message": "Run 9317 not found.",
"details": {}
}