Commit graph

13 commits

Author SHA1 Message Date
058ed2e85c Move typed paths to separate module 2023-08-13 19:30:52 +02:00
3d5a277234 Use typed paths in worker 2023-08-13 16:13:59 +02:00
08e240d7db Fix and add documentation 2023-08-13 01:16:12 +02:00
0196709a64 Make RunInProgress fields private 2023-08-12 21:23:36 +02:00
b7c0443005 Ask servers for runs and perform them 2023-08-12 21:23:36 +02:00
eaca373a6a Prevent status update race condition 2023-08-12 21:23:36 +02:00
e644f2be65 Send actual runner status to server 2023-08-12 21:23:36 +02:00
c7a89867a7 Restructure shared types and db columns
Now, the server sends the runner pretty much all run metadata. This way,
the reservation the server makes for the runner is accurate, providing
the runner responds with the same metadata it was sent. It also means
that only the server's system clock is relevant for tie breakers, and a
run's duration spans from the moment it is reserved to the moment it is
saved.

Also, the bench method is now always called `bench_method` and a
human-readable description is stored in the database for each run.
2023-08-12 21:23:36 +02:00
53be0338f2 Launch idle thread for each server 2023-08-12 21:23:36 +02:00
416e3e6aa1 Implement internal runner 2023-08-12 14:21:48 +02:00
d15d6588f7 Improve and fix runner API
- The server now also signals abort_work if the commit is no longer in
  the queue.
- The server now immediately reserves the work it gives to the worker,
  so other idle workers won't get the same work.
- The server now chooses a run id, not the worker. The worker can still
  submit work under arbitrary run ids when no id is known, for example
  when importing runs from another database.
2023-08-12 13:19:16 +02:00
b23fc6460f Start runs and coordinate with server 2023-08-12 02:16:05 +02:00
6f4793bcf2 Rename runners to workers 2023-08-11 02:12:38 +02:00
Renamed from src/runner/server.rs (Browse further)