Add exec endpoint
This commit is contained in:
parent
0b26571cfa
commit
a870894475
3 changed files with 55 additions and 0 deletions
|
@ -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);
|
||||
|
|
40
lib/model.ml
40
lib/model.ml
|
@ -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)
|
||||
|
|
|
@ -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
|
||||
|
|
Loading…
Reference in a new issue