From 466f732672fae5619ef6f63a7de1b1bd1fe1a9fc Mon Sep 17 00:00:00 2001 From: Francois Kritzinger Date: Tue, 3 Dec 2024 14:51:16 +0200 Subject: Implement handle_check_suite_completed() --- mod/mod-ci-github.cxx | 84 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 84 insertions(+) (limited to 'mod/mod-ci-github.cxx') diff --git a/mod/mod-ci-github.cxx b/mod/mod-ci-github.cxx index 394638a..66ac760 100644 --- a/mod/mod-ci-github.cxx +++ b/mod/mod-ci-github.cxx @@ -674,6 +674,90 @@ namespace brep // // 4. Verify the result matches what GitHub thinks it is (if easy). + HANDLER_DIAG; + + l3 ([&]{trace << "check_suite event { " << cs << " }";}); + + // Service id that uniquely identifies the CI tenant. + // + string sid (cs.repository.node_id + ':' + cs.check_suite.head_sha); + + // The log subject. + // + string sub ("check suite " + cs.check_suite.node_id + '/' + sid); + + // Load the service data. + // + service_data sd; + + if (optional d = find (*build_db_, "ci-github", sid)) + { + try + { + sd = service_data (*d->service.data); + } + catch (const invalid_argument& e) + { + fail << "failed to parse service data: " << e; + } + } + else + { + error << sub << ": tenant_service does not exist"; + return true; + } + + // Verify the completed flag and the number of check runs. + // + if (!sd.completed) + error << sub << " service data complete flag is false"; + + // Received count will be one higher because we don't store the conclusion + // check run. + // + if (cs.check_suite.check_runs_count != sd.check_runs.size () + 1) + { + error << sub << ": check runs count " << cs.check_suite.check_runs_count + << " does not match service data"; + } + + // Verify that all check runs are built and compute the summary + // conclusion. + // + optional conclusion (result_status::success); + + for (const check_run& cr: sd.check_runs) + { + if (cr.state == build_state::built) + { + assert (cr.status.has_value ()); + *conclusion |= *cr.status; + } + else + { + error << sub << ": unbuilt check run(s) in service data"; + conclusion = nullopt; + break; + } + } + + // Verify the conclusion. + // + if (conclusion) + { + if (cs.check_suite.conclusion) + { + if (gh_to_conclusion (*conclusion, warning_success) != + ucase (*cs.check_suite.conclusion)) + { + error << sub << ": conclusion " << *cs.check_suite.conclusion + << " does not match service data"; + } + } + else + error << sub << ": conclusion is null or absent"; + } + return true; } -- cgit v1.1