shad-go/distbuild/pkg/api/heartbeat.go

90 lines
2.9 KiB
Go
Raw Normal View History

2020-03-29 16:03:07 +00:00
package api
2020-03-10 12:08:59 +00:00
import (
"gitlab.com/slon/shad-go/distbuild/pkg/build"
)
2020-03-23 20:58:08 +00:00
// JobResult описывает результат работы джоба.
type JobResult struct {
2020-03-10 12:08:59 +00:00
ID build.ID
Stdout, Stderr []byte
ExitCode int
// Error описывает сообщение об ошибке, из-за которого джоб не удалось выполнить.
//
// Если Error == nil, значит джоб завершился успешно.
Error *string
}
2020-03-27 22:52:54 +00:00
type WorkerID string
2020-03-28 21:34:09 +00:00
func (w WorkerID) String() string {
return string(w)
}
2020-03-10 12:08:59 +00:00
type HeartbeatRequest struct {
// WorkerID задаёт персистентный идентификатор данного воркера.
//
// WorkerID так же выступает в качестве endpoint-а, к которому можно подключиться по HTTP.
//
// В наших тестов, идентификатор будет иметь вид "localhost:%d".
2020-03-27 22:52:54 +00:00
WorkerID WorkerID
2020-03-10 12:08:59 +00:00
// ProcessID задаёт эфемерный идентификатор текущего процесса воркера.
//
// Координатор запоминает ProcessID для каждого воркера.
//
// Измение ProcessID значит, что воркер перезапустился.
ProcessID string
// RunningJobs перечисляет список джобов, которые выполняются на этом воркере
// в данный момент.
RunningJobs []build.ID
DownloadingSources []build.ID
DownloadingArtifacts []build.ID
// FreeSlots сообщаяет, сколько еще процессов можно запустить на этом воркере.
FreeSlots int
2020-03-23 20:58:08 +00:00
// JobResult сообщает координатору, какие джобы завершили исполнение на этом воркере
2020-03-10 12:08:59 +00:00
// на этой итерации цикла.
2020-03-23 20:58:08 +00:00
FinishedJob []JobResult
2020-03-10 12:08:59 +00:00
// AddedArtifacts говорит, какие артефакты появились в кеше на этой итерации цикла.
AddedArtifacts []build.ID
// AddedSourceFiles говорит, какие файлы появились в кеше на этой итерации цикла.
AddedSourceFiles []build.ID
}
// JobSpec описывает джоб, который нужно запустить.
type JobSpec struct {
SourceFiles map[build.ID]string
Job build.Job
}
// ArtifactSpec описывает артефакт, который нужно скачать с другого воркера.
type ArtifactSpec struct {
}
// SourceFileSpec описывает файл с исходным кодом, который нужно скачать с координатора.
type SourceFileSpec struct {
}
type HeartbeatResponse struct {
JobsToRun map[build.ID]JobSpec
ArtifactsToDownload map[build.ID]ArtifactSpec
ArtifactsToRemove []build.ID
SourceFilesToDownload map[build.ID]SourceFileSpec
SourceFilesToRemove []build.ID
}