Add exec endpoint

This commit is contained in:
Reynir Björnsson 2025-01-14 17:11:35 +01:00
parent 0b26571cfa
commit a870894475
3 changed files with 55 additions and 0 deletions

View file

@ -516,6 +516,17 @@ let routes ~datadir ~cachedir ~configdir ~expired_jobs =
|> Lwt_result.ok
in
let job_build_full req =
let _job_name = Dream.param req "job"
and build = Dream.param req "build" in
get_uuid build >>= fun uuid ->
Dream.sql req (Model.exec_of_build datadir uuid)
|> if_error "Error getting build" >>= fun exec ->
ignore exec;
Dream.respond ~status:`Not_Found ""
|> Lwt_result.ok
in
let upload req =
let* body = Dream.body req in
Builder.Asn.exec_of_str body |> Lwt.return
@ -708,6 +719,7 @@ let routes ~datadir ~cachedir ~configdir ~expired_jobs =
`Get, "/job/:job/build/:build/script", (w (job_build_static_file `Script));
`Get, "/job/:job/build/:build/console", (w (job_build_static_file `Console));
`Get, "/job/:job/build/:build/all.tar.gz", (w job_build_targz);
`Get, "/job/:job/build/:build/exec", (w job_build_full);
`Get, "/failed-builds", (w failed_builds);
`Get, "/all-builds", (w (builds ~all:true));
`Get, "/hash", (w hash);

View file

@ -523,3 +523,43 @@ let add_build
| End_of_file ->
Unix.closedir dh;
Lwt.return (Ok ())
let console_of_string data =
let lines = String.split_on_char '\n' data in
(* remove last empty line *)
let lines =
match List.rev lines with
| "" :: lines -> List.rev lines
| _ -> lines
in
List.map (fun line ->
match String.split_on_char ':' line with
| ts :: tail ->
let delta = float_of_string (String.sub ts 0 (String.length ts - 1)) in
Int64.to_int (Duration.of_f delta), String.concat ":" tail
| _ -> assert false)
lines
let exec_of_build datadir uuid (module Db : CONN) =
let open Builder_db in
Db.find_opt Build.get_by_uuid uuid >>= not_found >>= fun (build_id, build) ->
let { Builder_db.Build.start; finish; result;
job_id; console; script; platform; _ } =
build
in
Db.find Builder_db.Job.get job_id >>= fun job_name ->
read_file datadir script >>= fun script ->
let job = { Builder.name = job_name; platform; script } in
read_file datadir console >>= fun console ->
let out = console_of_string console in
Db.collect_list Builder_db.Build_artifact.get_all_by_build build_id >>= fun artifacts ->
Lwt_list.fold_left_s (fun acc (_id, ({ filepath; _ } as file)) ->
match acc with
| Error _ as e -> Lwt.return e
| Ok acc ->
build_artifact_data datadir file >>= fun data ->
Lwt.return (Ok ((filepath, data) :: acc)))
(Ok []) artifacts >>= fun data ->
let exec = (job, uuid, out, start, finish, result, data) in
let data = Builder.Asn.exec_to_str exec in
Lwt.return (Ok data)

View file

@ -104,3 +104,6 @@ val add_build :
Builder.execution_result * (Fpath.t * string) list) ->
Caqti_lwt.connection ->
(unit, [> Caqti_error.call_or_retrieve | `Msg of string ]) result Lwt.t
val exec_of_build : Fpath.t -> Uuidm.t -> Caqti_lwt.connection ->
(string, [> Caqti_error.call_or_retrieve | `Not_found | `File_error of Fpath.t ]) result Lwt.t