[task scheduler] Add JOB_STATUS_REQUESTED
This indicates that a job has been requested (eg. by Buildbucket) but we are not ready to start running tasks for it yet.
Bug: b/288158829
Change-Id: I9fa6fbf75d7332557e459423f1a4d920a9bfedc5
Reviewed-on: https://skia-review.googlesource.com/c/buildbot/+/777226
Commit-Queue: Eric Boren <borenet@google.com>
Reviewed-by: Kevin Lubick <kjlubick@google.com>
diff --git a/task_scheduler/go/db/cache/cache.go b/task_scheduler/go/db/cache/cache.go
index 26d9c0e..928ab72 100644
--- a/task_scheduler/go/db/cache/cache.go
+++ b/task_scheduler/go/db/cache/cache.go
@@ -479,8 +479,12 @@
// in the given date range and match one of the given job names.
GetMatchingJobsFromDateRange(names []string, from time.Time, to time.Time) (map[string][]*types.Job, error)
- // UnfinishedJobs returns a list of jobs which were not finished at
+ // NotYetStartedJobs returns a list of jobs which were not yet started at
// the time of the last cache update.
+ NotYetStartedJobs() ([]*types.Job, error)
+
+ // UnfinishedJobs returns a list of jobs which were started but not finished
+ // at the time of the last cache update.
UnfinishedJobs() ([]*types.Job, error)
// Update loads new jobs from the database.
@@ -496,9 +500,10 @@
jobs map[string]*types.Job
jobsByNameAndState map[types.RepoState]map[string]map[string]*types.Job
// jobsByTime is sorted by Task.Created.
- jobsByTime []*types.Job
- timeWindow window.Window
- unfinished map[string]*types.Job
+ jobsByTime []*types.Job
+ timeWindow window.Window
+ notYetStarted map[string]*types.Job
+ unfinished map[string]*types.Job
modified map[string]*types.Job
modMtx sync.Mutex
@@ -603,6 +608,18 @@
}
// See documentation for JobCache interface.
+func (c *jobCache) NotYetStartedJobs() ([]*types.Job, error) {
+ c.mtx.RLock()
+ defer c.mtx.RUnlock()
+
+ rv := make([]*types.Job, 0, len(c.notYetStarted))
+ for _, t := range c.notYetStarted {
+ rv = append(rv, t.Copy())
+ }
+ return rv, nil
+}
+
+// See documentation for JobCache interface.
func (c *jobCache) UnfinishedJobs() ([]*types.Job, error) {
c.mtx.RLock()
defer c.mtx.RUnlock()
@@ -693,10 +710,17 @@
byId[job.Id] = job
// Unfinished jobs.
- if job.Done() {
- delete(c.unfinished, job.Id)
- } else {
+ if job.Status == types.JOB_STATUS_IN_PROGRESS {
c.unfinished[job.Id] = job
+ } else {
+ delete(c.unfinished, job.Id)
+ }
+
+ // Requested but not started jobs.
+ if job.Status == types.JOB_STATUS_REQUESTED {
+ c.notYetStarted[job.Id] = job
+ } else {
+ delete(c.notYetStarted, job.Id)
}
if isUpdate {
@@ -783,6 +807,7 @@
db: d,
jobs: map[string]*types.Job{},
jobsByNameAndState: map[types.RepoState]map[string]map[string]*types.Job{},
+ notYetStarted: map[string]*types.Job{},
unfinished: map[string]*types.Job{},
modified: map[string]*types.Job{},
timeWindow: timeWindow,
diff --git a/task_scheduler/go/db/cache/cache_test.go b/task_scheduler/go/db/cache/cache_test.go
index 6bfe0b8..b25a25c 100644
--- a/task_scheduler/go/db/cache/cache_test.go
+++ b/task_scheduler/go/db/cache/cache_test.go
@@ -884,3 +884,57 @@
test([]string{j1.Name, j2.Name}, j1.Created.Add(time.Nanosecond), time.Now().Add(24*time.Hour))
test([]string{j1.Name}, j1.Created, j1.Created.Add(time.Nanosecond), j1)
}
+
+func TestJobCache_NotYetStartedJobs(t *testing.T) {
+ ctx, cancel := context.WithCancel(context.Background())
+ defer cancel()
+ d := memory.NewInMemoryJobDB()
+
+ // Pre-load a job into the DB.
+ startTime := time.Now().Add(-30 * time.Minute) // Arbitrary starting point.
+ j1 := types.MakeTestJob(startTime)
+ j1.Status = types.JOB_STATUS_REQUESTED
+ require.NoError(t, d.PutJobs(ctx, []*types.Job{j1}))
+ d.Wait()
+
+ // Create the cache. Ensure that the job is present and is returned by the
+ // correct methods.
+ w, err := window.New(ctx, time.Hour, 0, nil)
+ require.NoError(t, err)
+ c, err := NewJobCache(ctx, d, w, nil)
+ require.NoError(t, err)
+
+ assertPresent := func(jobs []*types.Job, err error) {
+ require.NoError(t, err)
+ require.Len(t, jobs, 1)
+ require.Equal(t, j1, jobs[0])
+ }
+
+ // Assert that the job is returned by NotYetStartedJobs.
+ assertPresent(c.NotYetStartedJobs())
+
+ // Assert that the job is NOT returned by UnfinishedJobs.
+ jobs, err := c.UnfinishedJobs()
+ require.NoError(t, err)
+ require.Empty(t, jobs)
+
+ // Assert that the job is returned by all other methods.
+ assertPresent(c.GetAllCachedJobs(), nil)
+
+ job, err := c.GetJob(j1.Id)
+ require.NoError(t, err)
+ require.Equal(t, j1, job)
+
+ job, err = c.GetJobMaybeExpired(ctx, j1.Id)
+ require.NoError(t, err)
+ require.Equal(t, j1, job)
+
+ assertPresent(c.GetJobsByRepoState(j1.Name, j1.RepoState))
+
+ start := j1.Created.Add(-10 * time.Second)
+ end := j1.Created.Add(10 * time.Second)
+ assertPresent(c.GetJobsFromDateRange(start, end))
+
+ jobMap, err := c.GetMatchingJobsFromDateRange([]string{j1.Name}, start, end)
+ assertPresent(jobMap[j1.Name], err)
+}
diff --git a/task_scheduler/go/db/cache/mocks/JobCache.go b/task_scheduler/go/db/cache/mocks/JobCache.go
index 972c7d7..8dbffbf 100644
--- a/task_scheduler/go/db/cache/mocks/JobCache.go
+++ b/task_scheduler/go/db/cache/mocks/JobCache.go
@@ -154,6 +154,29 @@
return r0, r1
}
+// NotYetStartedJobs provides a mock function with given fields:
+func (_m *JobCache) NotYetStartedJobs() ([]*types.Job, error) {
+ ret := _m.Called()
+
+ var r0 []*types.Job
+ if rf, ok := ret.Get(0).(func() []*types.Job); ok {
+ r0 = rf()
+ } else {
+ if ret.Get(0) != nil {
+ r0 = ret.Get(0).([]*types.Job)
+ }
+ }
+
+ var r1 error
+ if rf, ok := ret.Get(1).(func() error); ok {
+ r1 = rf()
+ } else {
+ r1 = ret.Error(1)
+ }
+
+ return r0, r1
+}
+
// UnfinishedJobs provides a mock function with given fields:
func (_m *JobCache) UnfinishedJobs() ([]*types.Job, error) {
ret := _m.Called()
diff --git a/task_scheduler/go/rpc/rpc.go b/task_scheduler/go/rpc/rpc.go
index 3262c33..6440760 100644
--- a/task_scheduler/go/rpc/rpc.go
+++ b/task_scheduler/go/rpc/rpc.go
@@ -210,6 +210,8 @@
if req.HasStatus {
status := types.JobStatus("")
switch req.Status {
+ case JobStatus_JOB_STATUS_REQUESTED:
+ status = types.JOB_STATUS_REQUESTED
case JobStatus_JOB_STATUS_IN_PROGRESS:
status = types.JOB_STATUS_IN_PROGRESS
case JobStatus_JOB_STATUS_SUCCESS:
@@ -488,6 +490,8 @@
// convertJobStatus converts a types.JobStatus to rpc.JobStatus.
func convertJobStatus(st types.JobStatus) (JobStatus, error) {
switch st {
+ case types.JOB_STATUS_REQUESTED:
+ return JobStatus_JOB_STATUS_REQUESTED, nil
case types.JOB_STATUS_IN_PROGRESS:
return JobStatus_JOB_STATUS_IN_PROGRESS, nil
case types.JOB_STATUS_SUCCESS:
diff --git a/task_scheduler/go/rpc/rpc.pb.go b/task_scheduler/go/rpc/rpc.pb.go
index 98a3316..fa16ae6 100644
--- a/task_scheduler/go/rpc/rpc.pb.go
+++ b/task_scheduler/go/rpc/rpc.pb.go
@@ -95,6 +95,7 @@
JobStatus_JOB_STATUS_FAILURE JobStatus = 2
JobStatus_JOB_STATUS_MISHAP JobStatus = 3
JobStatus_JOB_STATUS_CANCELED JobStatus = 4
+ JobStatus_JOB_STATUS_REQUESTED JobStatus = 5
)
// Enum value maps for JobStatus.
@@ -105,6 +106,7 @@
2: "JOB_STATUS_FAILURE",
3: "JOB_STATUS_MISHAP",
4: "JOB_STATUS_CANCELED",
+ 5: "JOB_STATUS_REQUESTED",
}
JobStatus_value = map[string]int32{
"JOB_STATUS_IN_PROGRESS": 0,
@@ -112,6 +114,7 @@
"JOB_STATUS_FAILURE": 2,
"JOB_STATUS_MISHAP": 3,
"JOB_STATUS_CANCELED": 4,
+ "JOB_STATUS_REQUESTED": 5,
}
)
@@ -2771,7 +2774,7 @@
0x53, 0x5f, 0x53, 0x55, 0x43, 0x43, 0x45, 0x53, 0x53, 0x10, 0x02, 0x12, 0x17, 0x0a, 0x13, 0x54,
0x41, 0x53, 0x4b, 0x5f, 0x53, 0x54, 0x41, 0x54, 0x55, 0x53, 0x5f, 0x46, 0x41, 0x49, 0x4c, 0x55,
0x52, 0x45, 0x10, 0x03, 0x12, 0x16, 0x0a, 0x12, 0x54, 0x41, 0x53, 0x4b, 0x5f, 0x53, 0x54, 0x41,
- 0x54, 0x55, 0x53, 0x5f, 0x4d, 0x49, 0x53, 0x48, 0x41, 0x50, 0x10, 0x04, 0x2a, 0x87, 0x01, 0x0a,
+ 0x54, 0x55, 0x53, 0x5f, 0x4d, 0x49, 0x53, 0x48, 0x41, 0x50, 0x10, 0x04, 0x2a, 0xa1, 0x01, 0x0a,
0x09, 0x4a, 0x6f, 0x62, 0x53, 0x74, 0x61, 0x74, 0x75, 0x73, 0x12, 0x1a, 0x0a, 0x16, 0x4a, 0x4f,
0x42, 0x5f, 0x53, 0x54, 0x41, 0x54, 0x55, 0x53, 0x5f, 0x49, 0x4e, 0x5f, 0x50, 0x52, 0x4f, 0x47,
0x52, 0x45, 0x53, 0x53, 0x10, 0x00, 0x12, 0x16, 0x0a, 0x12, 0x4a, 0x4f, 0x42, 0x5f, 0x53, 0x54,
@@ -2780,66 +2783,68 @@
0x4c, 0x55, 0x52, 0x45, 0x10, 0x02, 0x12, 0x15, 0x0a, 0x11, 0x4a, 0x4f, 0x42, 0x5f, 0x53, 0x54,
0x41, 0x54, 0x55, 0x53, 0x5f, 0x4d, 0x49, 0x53, 0x48, 0x41, 0x50, 0x10, 0x03, 0x12, 0x17, 0x0a,
0x13, 0x4a, 0x4f, 0x42, 0x5f, 0x53, 0x54, 0x41, 0x54, 0x55, 0x53, 0x5f, 0x43, 0x41, 0x4e, 0x43,
- 0x45, 0x4c, 0x45, 0x44, 0x10, 0x04, 0x32, 0x82, 0x07, 0x0a, 0x14, 0x54, 0x61, 0x73, 0x6b, 0x53,
- 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x53, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x12,
- 0x5e, 0x0a, 0x0b, 0x54, 0x72, 0x69, 0x67, 0x67, 0x65, 0x72, 0x4a, 0x6f, 0x62, 0x73, 0x12, 0x26,
- 0x2e, 0x74, 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2e,
- 0x72, 0x70, 0x63, 0x2e, 0x54, 0x72, 0x69, 0x67, 0x67, 0x65, 0x72, 0x4a, 0x6f, 0x62, 0x73, 0x52,
- 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x27, 0x2e, 0x74, 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63,
- 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70, 0x63, 0x2e, 0x54, 0x72, 0x69, 0x67,
- 0x67, 0x65, 0x72, 0x4a, 0x6f, 0x62, 0x73, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12,
- 0x4f, 0x0a, 0x06, 0x47, 0x65, 0x74, 0x4a, 0x6f, 0x62, 0x12, 0x21, 0x2e, 0x74, 0x61, 0x73, 0x6b,
+ 0x45, 0x4c, 0x45, 0x44, 0x10, 0x04, 0x12, 0x18, 0x0a, 0x14, 0x4a, 0x4f, 0x42, 0x5f, 0x53, 0x54,
+ 0x41, 0x54, 0x55, 0x53, 0x5f, 0x52, 0x45, 0x51, 0x55, 0x45, 0x53, 0x54, 0x45, 0x44, 0x10, 0x05,
+ 0x32, 0x82, 0x07, 0x0a, 0x14, 0x54, 0x61, 0x73, 0x6b, 0x53, 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c,
+ 0x65, 0x72, 0x53, 0x65, 0x72, 0x76, 0x69, 0x63, 0x65, 0x12, 0x5e, 0x0a, 0x0b, 0x54, 0x72, 0x69,
+ 0x67, 0x67, 0x65, 0x72, 0x4a, 0x6f, 0x62, 0x73, 0x12, 0x26, 0x2e, 0x74, 0x61, 0x73, 0x6b, 0x5f,
+ 0x73, 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70, 0x63, 0x2e, 0x54, 0x72,
+ 0x69, 0x67, 0x67, 0x65, 0x72, 0x4a, 0x6f, 0x62, 0x73, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74,
+ 0x1a, 0x27, 0x2e, 0x74, 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65,
+ 0x72, 0x2e, 0x72, 0x70, 0x63, 0x2e, 0x54, 0x72, 0x69, 0x67, 0x67, 0x65, 0x72, 0x4a, 0x6f, 0x62,
+ 0x73, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x4f, 0x0a, 0x06, 0x47, 0x65, 0x74,
+ 0x4a, 0x6f, 0x62, 0x12, 0x21, 0x2e, 0x74, 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63, 0x68, 0x65, 0x64,
+ 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70, 0x63, 0x2e, 0x47, 0x65, 0x74, 0x4a, 0x6f, 0x62, 0x52,
+ 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x22, 0x2e, 0x74, 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63,
+ 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70, 0x63, 0x2e, 0x47, 0x65, 0x74, 0x4a,
+ 0x6f, 0x62, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x58, 0x0a, 0x09, 0x43, 0x61,
+ 0x6e, 0x63, 0x65, 0x6c, 0x4a, 0x6f, 0x62, 0x12, 0x24, 0x2e, 0x74, 0x61, 0x73, 0x6b, 0x5f, 0x73,
+ 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70, 0x63, 0x2e, 0x43, 0x61, 0x6e,
+ 0x63, 0x65, 0x6c, 0x4a, 0x6f, 0x62, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x25, 0x2e,
+ 0x74, 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72,
+ 0x70, 0x63, 0x2e, 0x43, 0x61, 0x6e, 0x63, 0x65, 0x6c, 0x4a, 0x6f, 0x62, 0x52, 0x65, 0x73, 0x70,
+ 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x5b, 0x0a, 0x0a, 0x53, 0x65, 0x61, 0x72, 0x63, 0x68, 0x4a, 0x6f,
+ 0x62, 0x73, 0x12, 0x25, 0x2e, 0x74, 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63, 0x68, 0x65, 0x64, 0x75,
+ 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70, 0x63, 0x2e, 0x53, 0x65, 0x61, 0x72, 0x63, 0x68, 0x4a, 0x6f,
+ 0x62, 0x73, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x26, 0x2e, 0x74, 0x61, 0x73, 0x6b,
+ 0x5f, 0x73, 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70, 0x63, 0x2e, 0x53,
+ 0x65, 0x61, 0x72, 0x63, 0x68, 0x4a, 0x6f, 0x62, 0x73, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73,
+ 0x65, 0x12, 0x52, 0x0a, 0x07, 0x47, 0x65, 0x74, 0x54, 0x61, 0x73, 0x6b, 0x12, 0x22, 0x2e, 0x74,
+ 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70,
+ 0x63, 0x2e, 0x47, 0x65, 0x74, 0x54, 0x61, 0x73, 0x6b, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74,
+ 0x1a, 0x23, 0x2e, 0x74, 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65,
+ 0x72, 0x2e, 0x72, 0x70, 0x63, 0x2e, 0x47, 0x65, 0x74, 0x54, 0x61, 0x73, 0x6b, 0x52, 0x65, 0x73,
+ 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x5e, 0x0a, 0x0b, 0x53, 0x65, 0x61, 0x72, 0x63, 0x68, 0x54,
+ 0x61, 0x73, 0x6b, 0x73, 0x12, 0x26, 0x2e, 0x74, 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63, 0x68, 0x65,
+ 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70, 0x63, 0x2e, 0x53, 0x65, 0x61, 0x72, 0x63, 0x68,
+ 0x54, 0x61, 0x73, 0x6b, 0x73, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x27, 0x2e, 0x74,
+ 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70,
+ 0x63, 0x2e, 0x53, 0x65, 0x61, 0x72, 0x63, 0x68, 0x54, 0x61, 0x73, 0x6b, 0x73, 0x52, 0x65, 0x73,
+ 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x6d, 0x0a, 0x10, 0x47, 0x65, 0x74, 0x53, 0x6b, 0x69, 0x70,
+ 0x54, 0x61, 0x73, 0x6b, 0x52, 0x75, 0x6c, 0x65, 0x73, 0x12, 0x2b, 0x2e, 0x74, 0x61, 0x73, 0x6b,
0x5f, 0x73, 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70, 0x63, 0x2e, 0x47,
- 0x65, 0x74, 0x4a, 0x6f, 0x62, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x22, 0x2e, 0x74,
- 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70,
- 0x63, 0x2e, 0x47, 0x65, 0x74, 0x4a, 0x6f, 0x62, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65,
- 0x12, 0x58, 0x0a, 0x09, 0x43, 0x61, 0x6e, 0x63, 0x65, 0x6c, 0x4a, 0x6f, 0x62, 0x12, 0x24, 0x2e,
- 0x74, 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72,
- 0x70, 0x63, 0x2e, 0x43, 0x61, 0x6e, 0x63, 0x65, 0x6c, 0x4a, 0x6f, 0x62, 0x52, 0x65, 0x71, 0x75,
- 0x65, 0x73, 0x74, 0x1a, 0x25, 0x2e, 0x74, 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63, 0x68, 0x65, 0x64,
- 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70, 0x63, 0x2e, 0x43, 0x61, 0x6e, 0x63, 0x65, 0x6c, 0x4a,
- 0x6f, 0x62, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x5b, 0x0a, 0x0a, 0x53, 0x65,
- 0x61, 0x72, 0x63, 0x68, 0x4a, 0x6f, 0x62, 0x73, 0x12, 0x25, 0x2e, 0x74, 0x61, 0x73, 0x6b, 0x5f,
- 0x73, 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70, 0x63, 0x2e, 0x53, 0x65,
- 0x61, 0x72, 0x63, 0x68, 0x4a, 0x6f, 0x62, 0x73, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a,
- 0x26, 0x2e, 0x74, 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72,
- 0x2e, 0x72, 0x70, 0x63, 0x2e, 0x53, 0x65, 0x61, 0x72, 0x63, 0x68, 0x4a, 0x6f, 0x62, 0x73, 0x52,
- 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x52, 0x0a, 0x07, 0x47, 0x65, 0x74, 0x54, 0x61,
- 0x73, 0x6b, 0x12, 0x22, 0x2e, 0x74, 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63, 0x68, 0x65, 0x64, 0x75,
- 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70, 0x63, 0x2e, 0x47, 0x65, 0x74, 0x54, 0x61, 0x73, 0x6b, 0x52,
- 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x23, 0x2e, 0x74, 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63,
- 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70, 0x63, 0x2e, 0x47, 0x65, 0x74, 0x54,
- 0x61, 0x73, 0x6b, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x5e, 0x0a, 0x0b, 0x53,
- 0x65, 0x61, 0x72, 0x63, 0x68, 0x54, 0x61, 0x73, 0x6b, 0x73, 0x12, 0x26, 0x2e, 0x74, 0x61, 0x73,
- 0x6b, 0x5f, 0x73, 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70, 0x63, 0x2e,
- 0x53, 0x65, 0x61, 0x72, 0x63, 0x68, 0x54, 0x61, 0x73, 0x6b, 0x73, 0x52, 0x65, 0x71, 0x75, 0x65,
- 0x73, 0x74, 0x1a, 0x27, 0x2e, 0x74, 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63, 0x68, 0x65, 0x64, 0x75,
- 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70, 0x63, 0x2e, 0x53, 0x65, 0x61, 0x72, 0x63, 0x68, 0x54, 0x61,
- 0x73, 0x6b, 0x73, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x6d, 0x0a, 0x10, 0x47,
- 0x65, 0x74, 0x53, 0x6b, 0x69, 0x70, 0x54, 0x61, 0x73, 0x6b, 0x52, 0x75, 0x6c, 0x65, 0x73, 0x12,
- 0x2b, 0x2e, 0x74, 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72,
- 0x2e, 0x72, 0x70, 0x63, 0x2e, 0x47, 0x65, 0x74, 0x53, 0x6b, 0x69, 0x70, 0x54, 0x61, 0x73, 0x6b,
- 0x52, 0x75, 0x6c, 0x65, 0x73, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x2c, 0x2e, 0x74,
- 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70,
- 0x63, 0x2e, 0x47, 0x65, 0x74, 0x53, 0x6b, 0x69, 0x70, 0x54, 0x61, 0x73, 0x6b, 0x52, 0x75, 0x6c,
- 0x65, 0x73, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x6a, 0x0a, 0x0f, 0x41, 0x64,
- 0x64, 0x53, 0x6b, 0x69, 0x70, 0x54, 0x61, 0x73, 0x6b, 0x52, 0x75, 0x6c, 0x65, 0x12, 0x2a, 0x2e,
- 0x74, 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72,
- 0x70, 0x63, 0x2e, 0x41, 0x64, 0x64, 0x53, 0x6b, 0x69, 0x70, 0x54, 0x61, 0x73, 0x6b, 0x52, 0x75,
- 0x6c, 0x65, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x2b, 0x2e, 0x74, 0x61, 0x73, 0x6b,
- 0x5f, 0x73, 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70, 0x63, 0x2e, 0x41,
- 0x64, 0x64, 0x53, 0x6b, 0x69, 0x70, 0x54, 0x61, 0x73, 0x6b, 0x52, 0x75, 0x6c, 0x65, 0x52, 0x65,
- 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x73, 0x0a, 0x12, 0x44, 0x65, 0x6c, 0x65, 0x74, 0x65,
- 0x53, 0x6b, 0x69, 0x70, 0x54, 0x61, 0x73, 0x6b, 0x52, 0x75, 0x6c, 0x65, 0x12, 0x2d, 0x2e, 0x74,
- 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70,
- 0x63, 0x2e, 0x44, 0x65, 0x6c, 0x65, 0x74, 0x65, 0x53, 0x6b, 0x69, 0x70, 0x54, 0x61, 0x73, 0x6b,
- 0x52, 0x75, 0x6c, 0x65, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x2e, 0x2e, 0x74, 0x61,
- 0x73, 0x6b, 0x5f, 0x73, 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70, 0x63,
- 0x2e, 0x44, 0x65, 0x6c, 0x65, 0x74, 0x65, 0x53, 0x6b, 0x69, 0x70, 0x54, 0x61, 0x73, 0x6b, 0x52,
- 0x75, 0x6c, 0x65, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x42, 0x29, 0x5a, 0x27, 0x67,
- 0x6f, 0x2e, 0x73, 0x6b, 0x69, 0x61, 0x2e, 0x6f, 0x72, 0x67, 0x2f, 0x69, 0x6e, 0x66, 0x72, 0x61,
- 0x2f, 0x74, 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2f,
- 0x67, 0x6f, 0x2f, 0x72, 0x70, 0x63, 0x62, 0x06, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x33,
+ 0x65, 0x74, 0x53, 0x6b, 0x69, 0x70, 0x54, 0x61, 0x73, 0x6b, 0x52, 0x75, 0x6c, 0x65, 0x73, 0x52,
+ 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x2c, 0x2e, 0x74, 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63,
+ 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70, 0x63, 0x2e, 0x47, 0x65, 0x74, 0x53,
+ 0x6b, 0x69, 0x70, 0x54, 0x61, 0x73, 0x6b, 0x52, 0x75, 0x6c, 0x65, 0x73, 0x52, 0x65, 0x73, 0x70,
+ 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x6a, 0x0a, 0x0f, 0x41, 0x64, 0x64, 0x53, 0x6b, 0x69, 0x70, 0x54,
+ 0x61, 0x73, 0x6b, 0x52, 0x75, 0x6c, 0x65, 0x12, 0x2a, 0x2e, 0x74, 0x61, 0x73, 0x6b, 0x5f, 0x73,
+ 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70, 0x63, 0x2e, 0x41, 0x64, 0x64,
+ 0x53, 0x6b, 0x69, 0x70, 0x54, 0x61, 0x73, 0x6b, 0x52, 0x75, 0x6c, 0x65, 0x52, 0x65, 0x71, 0x75,
+ 0x65, 0x73, 0x74, 0x1a, 0x2b, 0x2e, 0x74, 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63, 0x68, 0x65, 0x64,
+ 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70, 0x63, 0x2e, 0x41, 0x64, 0x64, 0x53, 0x6b, 0x69, 0x70,
+ 0x54, 0x61, 0x73, 0x6b, 0x52, 0x75, 0x6c, 0x65, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65,
+ 0x12, 0x73, 0x0a, 0x12, 0x44, 0x65, 0x6c, 0x65, 0x74, 0x65, 0x53, 0x6b, 0x69, 0x70, 0x54, 0x61,
+ 0x73, 0x6b, 0x52, 0x75, 0x6c, 0x65, 0x12, 0x2d, 0x2e, 0x74, 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63,
+ 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70, 0x63, 0x2e, 0x44, 0x65, 0x6c, 0x65,
+ 0x74, 0x65, 0x53, 0x6b, 0x69, 0x70, 0x54, 0x61, 0x73, 0x6b, 0x52, 0x75, 0x6c, 0x65, 0x52, 0x65,
+ 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x2e, 0x2e, 0x74, 0x61, 0x73, 0x6b, 0x5f, 0x73, 0x63, 0x68,
+ 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2e, 0x72, 0x70, 0x63, 0x2e, 0x44, 0x65, 0x6c, 0x65, 0x74,
+ 0x65, 0x53, 0x6b, 0x69, 0x70, 0x54, 0x61, 0x73, 0x6b, 0x52, 0x75, 0x6c, 0x65, 0x52, 0x65, 0x73,
+ 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x42, 0x29, 0x5a, 0x27, 0x67, 0x6f, 0x2e, 0x73, 0x6b, 0x69, 0x61,
+ 0x2e, 0x6f, 0x72, 0x67, 0x2f, 0x69, 0x6e, 0x66, 0x72, 0x61, 0x2f, 0x74, 0x61, 0x73, 0x6b, 0x5f,
+ 0x73, 0x63, 0x68, 0x65, 0x64, 0x75, 0x6c, 0x65, 0x72, 0x2f, 0x67, 0x6f, 0x2f, 0x72, 0x70, 0x63,
+ 0x62, 0x06, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x33,
}
var (
diff --git a/task_scheduler/go/rpc/rpc.proto b/task_scheduler/go/rpc/rpc.proto
index 1d4358a..d92390a 100644
--- a/task_scheduler/go/rpc/rpc.proto
+++ b/task_scheduler/go/rpc/rpc.proto
@@ -330,6 +330,7 @@
JOB_STATUS_FAILURE = 2;
JOB_STATUS_MISHAP = 3;
JOB_STATUS_CANCELED = 4;
+ JOB_STATUS_REQUESTED = 5;
}
// TaskDependencies represents dependencies of a task.
diff --git a/task_scheduler/go/rpc/rpc.twirp.go b/task_scheduler/go/rpc/rpc.twirp.go
index 6340d70..07209f6 100644
--- a/task_scheduler/go/rpc/rpc.twirp.go
+++ b/task_scheduler/go/rpc/rpc.twirp.go
@@ -3263,133 +3263,134 @@
}
var twirpFileDescriptor0 = []byte{
- // 2043 bytes of a gzipped FileDescriptorProto
+ // 2058 bytes of a gzipped FileDescriptorProto
0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xc4, 0x58, 0xcd, 0x72, 0x1b, 0xc7,
- 0x11, 0x36, 0xfe, 0x81, 0x06, 0xf1, 0xc3, 0xa1, 0x24, 0x42, 0x70, 0x49, 0xa2, 0x57, 0x8e, 0x44,
- 0x4b, 0x0a, 0x98, 0xa2, 0x4b, 0x72, 0x14, 0xc7, 0x49, 0x40, 0x0a, 0x16, 0x41, 0x49, 0x24, 0xb3,
- 0x80, 0xaa, 0x52, 0x4e, 0x95, 0xb7, 0x16, 0xd8, 0x21, 0xb1, 0x24, 0x80, 0xdd, 0xec, 0x0c, 0x68,
- 0xe3, 0x94, 0xaa, 0x54, 0xaa, 0x92, 0x6b, 0x2e, 0x79, 0x85, 0xbc, 0x44, 0x9e, 0x24, 0xc7, 0x9c,
- 0x72, 0xcb, 0x2b, 0xb8, 0xe6, 0x6f, 0x39, 0x00, 0x76, 0x01, 0x51, 0x3a, 0xe8, 0xb6, 0xd3, 0xfd,
- 0x75, 0xcf, 0x4c, 0x4f, 0x7f, 0x3d, 0xbd, 0x03, 0x85, 0xc0, 0xef, 0x37, 0xfc, 0xc0, 0xa3, 0x1e,
- 0x42, 0xd4, 0x26, 0x17, 0x16, 0xe9, 0x0f, 0xb0, 0x33, 0x19, 0xe2, 0xa0, 0x11, 0xf8, 0xfd, 0xfa,
- 0xbd, 0x33, 0xcf, 0x3b, 0x1b, 0xe2, 0x1d, 0x8e, 0xe8, 0x4d, 0x4e, 0x77, 0xa8, 0x3b, 0xc2, 0x84,
- 0xda, 0x23, 0x5f, 0x18, 0x19, 0x07, 0x00, 0xdd, 0xc0, 0x3d, 0x3b, 0xc3, 0xc1, 0xa1, 0xd7, 0x43,
- 0xb7, 0x21, 0x7f, 0xee, 0xf5, 0xac, 0xb1, 0x3d, 0xc2, 0xb5, 0xc4, 0x56, 0x62, 0xbb, 0x60, 0xe6,
- 0xce, 0xbd, 0xde, 0x91, 0x3d, 0xc2, 0xe8, 0x1e, 0x14, 0xfb, 0xde, 0x68, 0xe4, 0x52, 0x6b, 0x60,
- 0x93, 0x41, 0x2d, 0xc9, 0xb5, 0x20, 0x44, 0x07, 0x36, 0x19, 0x18, 0x07, 0x80, 0xae, 0x3c, 0x11,
- 0x13, 0xff, 0x69, 0x82, 0x09, 0x45, 0xbb, 0x90, 0x3e, 0xf7, 0x7a, 0xa4, 0x96, 0xd8, 0x4a, 0x6d,
- 0x17, 0x77, 0xef, 0x36, 0x16, 0xd7, 0xd8, 0xb8, 0xb2, 0x32, 0x39, 0xd6, 0x68, 0xc0, 0xc6, 0x8c,
- 0x27, 0xe2, 0x7b, 0x63, 0x82, 0xd1, 0x26, 0xb0, 0xc5, 0x58, 0xae, 0x23, 0xbc, 0x15, 0xcc, 0xec,
- 0xb9, 0xd7, 0x6b, 0x3b, 0xc4, 0xb8, 0x07, 0xa5, 0x97, 0x98, 0x32, 0x7b, 0x39, 0x69, 0x19, 0x92,
- 0xae, 0x23, 0x37, 0x90, 0x74, 0x1d, 0xe3, 0x6b, 0x28, 0x2b, 0x80, 0xf4, 0xf5, 0x05, 0xa4, 0xce,
- 0xbd, 0x1e, 0x87, 0x14, 0x77, 0x37, 0xa3, 0x56, 0xc5, 0xd0, 0x0c, 0x63, 0x18, 0x50, 0xdd, 0xb7,
- 0xc7, 0x7d, 0x3c, 0x5c, 0x32, 0xc1, 0x6f, 0x60, 0x5d, 0xc3, 0x5c, 0x7f, 0x8e, 0xff, 0x64, 0x60,
- 0xbd, 0x83, 0xed, 0xa0, 0x3f, 0xd0, 0x63, 0xf7, 0x0b, 0xb8, 0xd1, 0x9b, 0xb8, 0x43, 0xa7, 0x37,
- 0xe9, 0x5f, 0x60, 0x6a, 0xf1, 0x6f, 0x2b, 0x9c, 0x17, 0x69, 0xba, 0x3d, 0xf6, 0xd9, 0x76, 0xd0,
- 0x57, 0x50, 0x1b, 0xd8, 0xc4, 0x8a, 0xb4, 0x62, 0x27, 0x96, 0x37, 0x6f, 0x0e, 0x6c, 0xb2, 0xb7,
- 0x68, 0x78, 0x1b, 0xf2, 0x2e, 0xb1, 0x4e, 0xbd, 0xa0, 0x8f, 0x6b, 0x29, 0x0e, 0xcc, 0xb9, 0xe4,
- 0x5b, 0x36, 0x44, 0x5b, 0xb0, 0xc6, 0x7c, 0x86, 0xea, 0x34, 0x57, 0xc3, 0xc0, 0x26, 0x6d, 0x89,
- 0xb8, 0x01, 0x19, 0x97, 0x90, 0x09, 0xae, 0x65, 0xf8, 0xc2, 0xc4, 0x00, 0x7d, 0x0a, 0x05, 0x61,
- 0xc7, 0x34, 0x59, 0x6e, 0x94, 0xe7, 0x46, 0x4c, 0x89, 0x20, 0xcd, 0x93, 0x2c, 0xc7, 0x2d, 0xf8,
- 0x37, 0x5b, 0x03, 0x33, 0xe0, 0xf2, 0xbc, 0x58, 0xc3, 0xc0, 0x26, 0x3c, 0xf9, 0xea, 0x90, 0xf7,
- 0x6d, 0xda, 0x1f, 0x10, 0x4c, 0x6b, 0x05, 0x6e, 0x12, 0x8e, 0xd1, 0x67, 0x62, 0x7d, 0xa1, 0x1e,
- 0xb8, 0x69, 0x71, 0x60, 0x93, 0x13, 0x05, 0x41, 0x90, 0x0e, 0xb0, 0xef, 0xd5, 0x8a, 0x62, 0x36,
- 0xf6, 0xad, 0x66, 0xe3, 0xf2, 0xb5, 0x70, 0x36, 0x93, 0xa9, 0xea, 0x90, 0x0f, 0xf0, 0xa5, 0x4b,
- 0x5c, 0x6f, 0x5c, 0x2b, 0x89, 0xd9, 0xd4, 0x58, 0xcd, 0x16, 0xea, 0xcb, 0xe1, 0x6c, 0xa6, 0x82,
- 0x3c, 0x85, 0x2c, 0xa1, 0x36, 0x9d, 0x90, 0x5a, 0x65, 0x2b, 0xb1, 0x5d, 0xde, 0xbd, 0x13, 0x73,
- 0xf4, 0x1d, 0x0e, 0x32, 0x25, 0x18, 0xdd, 0x01, 0x16, 0x53, 0x4b, 0x9a, 0x56, 0xb9, 0x5f, 0x16,
- 0x41, 0x01, 0x43, 0xcf, 0x01, 0x18, 0x77, 0x99, 0x3e, 0xa0, 0xb5, 0x75, 0x9e, 0x54, 0xf5, 0x86,
- 0xa0, 0x77, 0x43, 0xd1, 0xbb, 0xd1, 0x55, 0xf4, 0x36, 0x0b, 0x0c, 0xdd, 0x61, 0x60, 0xf4, 0x39,
- 0x94, 0x99, 0x67, 0xcd, 0x1c, 0x71, 0xef, 0x6c, 0x27, 0xdd, 0x10, 0xf5, 0x14, 0xf2, 0x1c, 0x81,
- 0xc7, 0x4e, 0x6d, 0x63, 0xa5, 0xfb, 0x1c, 0xc3, 0xb6, 0xc6, 0x8e, 0x4a, 0x8f, 0xd0, 0xf4, 0x46,
- 0x98, 0x1e, 0x5d, 0x81, 0x30, 0x9a, 0x80, 0xf4, 0xdc, 0x96, 0xec, 0x78, 0x3c, 0x53, 0x18, 0x62,
- 0xe9, 0x21, 0x2a, 0x42, 0x8b, 0x13, 0xb8, 0x6b, 0x93, 0x8b, 0x18, 0x06, 0xa2, 0xfb, 0x50, 0x72,
- 0xc7, 0xfd, 0xe1, 0xc4, 0xe1, 0x5b, 0xa4, 0x44, 0xa6, 0xfb, 0x9a, 0x14, 0xb2, 0x20, 0x12, 0xe3,
- 0xb7, 0x50, 0x09, 0xdd, 0xc8, 0x65, 0x3c, 0x81, 0x34, 0x9b, 0x59, 0xb2, 0xb4, 0x16, 0x59, 0x9f,
- 0x18, 0x9e, 0xa3, 0x8c, 0xff, 0xa7, 0xd5, 0x5e, 0x98, 0x30, 0x24, 0x6a, 0x0d, 0x72, 0x36, 0xa5,
- 0x78, 0xe4, 0x53, 0xee, 0x27, 0x63, 0xaa, 0x21, 0xab, 0x9a, 0x2c, 0x3a, 0x4a, 0x9b, 0x0c, 0x83,
- 0xd3, 0x94, 0x80, 0x90, 0x3b, 0xa9, 0x58, 0xee, 0xa4, 0x63, 0xb8, 0x93, 0x89, 0xe1, 0x4e, 0x36,
- 0x9e, 0x3b, 0xb9, 0x15, 0xdc, 0xc9, 0xc7, 0x73, 0xa7, 0x10, 0xc3, 0x1d, 0x88, 0xe7, 0x4e, 0x71,
- 0x05, 0x77, 0xd6, 0x16, 0xb9, 0xf3, 0x2c, 0xe4, 0x4e, 0x89, 0x73, 0xe7, 0x6e, 0xdc, 0x81, 0x2c,
- 0x25, 0x4f, 0x79, 0x39, 0x79, 0x2a, 0x1f, 0x46, 0x9e, 0xea, 0x0a, 0xf2, 0xac, 0xbf, 0x3f, 0x79,
- 0xd0, 0x02, 0x79, 0x5a, 0xb0, 0x31, 0x93, 0x70, 0x32, 0x6d, 0x1b, 0x90, 0x61, 0x81, 0x51, 0xf4,
- 0x89, 0xcf, 0x5b, 0x01, 0x33, 0x6e, 0xc3, 0xe6, 0x4b, 0x4c, 0x3b, 0x17, 0xae, 0xcf, 0xa5, 0x93,
- 0x21, 0x56, 0xc9, 0x6b, 0xfc, 0x2b, 0x01, 0x6b, 0xba, 0x82, 0x9d, 0xae, 0xed, 0x38, 0xd8, 0xb1,
- 0x7a, 0x53, 0xd5, 0x04, 0xf0, 0xf1, 0xde, 0x14, 0x3d, 0x01, 0xd9, 0x64, 0xf8, 0xb8, 0xcf, 0xb2,
- 0x86, 0xe2, 0x60, 0xcc, 0xa8, 0xc6, 0x6e, 0xe3, 0x2a, 0xd3, 0x74, 0x7c, 0xdc, 0x3f, 0x91, 0x72,
- 0x46, 0x0b, 0xd1, 0x1f, 0x90, 0x5a, 0x8a, 0x43, 0xd4, 0x10, 0x6d, 0x41, 0xd1, 0xc1, 0xa4, 0x1f,
- 0xb8, 0x3e, 0x65, 0x89, 0x90, 0xe6, 0xb3, 0xe8, 0xa2, 0xa8, 0x24, 0x37, 0x4c, 0xa8, 0x2d, 0x6e,
- 0x42, 0x06, 0xe4, 0x19, 0x64, 0x02, 0x26, 0x90, 0x01, 0xd9, 0x8a, 0x0a, 0x88, 0x6e, 0x69, 0x0a,
- 0xb8, 0xf1, 0xcf, 0x04, 0xdc, 0x6a, 0x3a, 0xce, 0x8c, 0x4a, 0xb2, 0xfa, 0xe3, 0x6e, 0xf6, 0xf7,
- 0xb0, 0xb9, 0xb0, 0xae, 0x0f, 0xdc, 0xeb, 0x63, 0xb8, 0xfd, 0x02, 0x0f, 0x31, 0xc5, 0x51, 0xbb,
- 0x9d, 0x6f, 0x69, 0xba, 0x50, 0x8f, 0x02, 0x7f, 0xe0, 0x12, 0xfe, 0x97, 0x80, 0x02, 0xab, 0x13,
- 0x8c, 0x97, 0x18, 0x3d, 0x87, 0x0c, 0x2f, 0x3d, 0xb2, 0xfa, 0xde, 0x8f, 0xf2, 0x12, 0xa2, 0x1b,
- 0xbc, 0x24, 0x99, 0xc2, 0x22, 0x2c, 0x4b, 0x49, 0xad, 0x2c, 0xe9, 0xb5, 0x27, 0x35, 0x5b, 0x7b,
- 0xea, 0x3e, 0x64, 0xb8, 0xfd, 0x55, 0xc1, 0x4d, 0xe8, 0x05, 0xf7, 0x0e, 0x00, 0xf7, 0x6b, 0x69,
- 0x4e, 0x0b, 0x5c, 0xa2, 0xaa, 0x5a, 0x58, 0x23, 0x53, 0x73, 0x35, 0xf4, 0x16, 0x64, 0x09, 0x0e,
- 0x2e, 0x71, 0x20, 0x4f, 0x56, 0x8e, 0x8c, 0x3f, 0x43, 0x8e, 0xed, 0xfe, 0x15, 0x9e, 0xa2, 0x5f,
- 0x03, 0x30, 0xbf, 0xbc, 0x3c, 0x61, 0xb9, 0xd9, 0x3b, 0x4b, 0x37, 0x6b, 0x16, 0x82, 0x30, 0x4a,
- 0x2a, 0x3b, 0x92, 0x5a, 0xbd, 0x37, 0xa0, 0xc4, 0xbb, 0x31, 0xc7, 0x12, 0x2d, 0xb1, 0x5c, 0x55,
- 0x51, 0x08, 0x0f, 0x59, 0x5f, 0x6c, 0xfc, 0x37, 0x0b, 0x69, 0xb6, 0x82, 0x25, 0xd7, 0x93, 0x96,
- 0xb4, 0xc9, 0xd9, 0xa4, 0x7d, 0x0e, 0xd0, 0x0f, 0xb0, 0x4d, 0xb1, 0x63, 0xd9, 0x62, 0xcf, 0x2b,
- 0x2a, 0xa6, 0x44, 0x37, 0x29, 0xfa, 0x1d, 0x94, 0x9d, 0x9e, 0x35, 0xf2, 0x1c, 0xf7, 0xd4, 0x15,
- 0xe6, 0xe9, 0x95, 0xe6, 0x6b, 0x4e, 0xef, 0x8d, 0x34, 0x68, 0x52, 0xf4, 0x35, 0x14, 0x4f, 0xdd,
- 0xb1, 0x4b, 0x06, 0xc2, 0x3c, 0xb3, 0xd2, 0x1c, 0x14, 0xbc, 0xa9, 0x12, 0x39, 0x1b, 0x76, 0x06,
- 0x0f, 0xa1, 0xe2, 0x12, 0x6f, 0xc8, 0xb7, 0xe2, 0x4d, 0xa8, 0x3f, 0x51, 0xd7, 0x60, 0x59, 0x89,
- 0x8f, 0xb9, 0x94, 0xc5, 0x99, 0x77, 0x24, 0x79, 0x1e, 0x09, 0xfe, 0xcd, 0xae, 0xac, 0x91, 0xfd,
- 0xa3, 0xba, 0xbf, 0x09, 0xbf, 0x05, 0x33, 0x66, 0x71, 0x64, 0xff, 0x28, 0x2f, 0x70, 0x82, 0x1e,
- 0x40, 0xc5, 0xb7, 0x03, 0x3c, 0xa6, 0x16, 0x3f, 0x50, 0xf6, 0x7b, 0x02, 0xdc, 0x43, 0x49, 0x88,
- 0xd9, 0x11, 0xb4, 0x1d, 0x82, 0x0e, 0x00, 0xfc, 0xc0, 0xf3, 0x71, 0x40, 0x5d, 0x4c, 0x6a, 0x45,
- 0xce, 0x9b, 0xed, 0xb8, 0xba, 0xdd, 0x38, 0x09, 0xa1, 0xad, 0x31, 0x0d, 0xa6, 0xa6, 0x66, 0xcb,
- 0x0a, 0x74, 0x80, 0x69, 0x30, 0xb5, 0xbc, 0x53, 0x7e, 0x87, 0x16, 0xcc, 0x1c, 0x1f, 0x1f, 0x9f,
- 0xb2, 0x63, 0xe3, 0x97, 0x94, 0x08, 0x5c, 0x69, 0xf5, 0xb1, 0x49, 0x74, 0x93, 0x6a, 0x57, 0x6f,
- 0xf9, 0x5a, 0x57, 0xef, 0x03, 0xa8, 0x90, 0x1f, 0xec, 0x60, 0xe4, 0x8e, 0xcf, 0xac, 0x9e, 0x47,
- 0x59, 0x32, 0x56, 0xf8, 0xa2, 0x4a, 0x4a, 0xbc, 0xe7, 0xd1, 0xb6, 0x83, 0xb6, 0xa1, 0x1a, 0xe2,
- 0x64, 0xa4, 0xf8, 0x55, 0x5a, 0x30, 0xcb, 0x4a, 0x2e, 0x42, 0x85, 0x9e, 0x41, 0x9e, 0x03, 0x2e,
- 0xf0, 0x54, 0x5e, 0xa6, 0x9f, 0xc6, 0xad, 0xe5, 0x15, 0x9e, 0x9a, 0x39, 0x2a, 0x69, 0xf6, 0x25,
- 0x64, 0x44, 0xef, 0x87, 0xe2, 0x19, 0xa6, 0x36, 0x40, 0x4c, 0x81, 0xad, 0x7f, 0x03, 0x95, 0xb9,
- 0x58, 0xa3, 0x2a, 0xa4, 0xd8, 0xd4, 0xa2, 0x40, 0xb0, 0x4f, 0x56, 0x34, 0x2e, 0xed, 0xe1, 0x44,
- 0x71, 0x50, 0x0c, 0x7e, 0x95, 0xfc, 0x65, 0xc2, 0x38, 0x84, 0x2a, 0x73, 0xf9, 0x02, 0xfb, 0x78,
- 0xec, 0xe0, 0x71, 0x9f, 0x9d, 0x0f, 0xd2, 0x7a, 0xca, 0x82, 0xe8, 0x1c, 0x91, 0x01, 0x6b, 0x8e,
- 0x86, 0x91, 0x74, 0x9b, 0x91, 0x19, 0xff, 0x4e, 0x40, 0x91, 0xaf, 0x6f, 0x32, 0x1a, 0xd9, 0xc1,
- 0x74, 0xa1, 0xc7, 0xd5, 0x78, 0x9c, 0x9c, 0xe5, 0xf1, 0x7c, 0x9a, 0xa6, 0x16, 0xd3, 0xf4, 0xea,
- 0x78, 0xd3, 0xd7, 0x3a, 0xde, 0xa8, 0x63, 0xcb, 0x44, 0x1d, 0x9b, 0xf1, 0x1d, 0x94, 0xae, 0x56,
- 0x2f, 0xe3, 0xa0, 0xbd, 0x24, 0x88, 0xc2, 0xf5, 0x54, 0x35, 0x2e, 0x49, 0x4e, 0x80, 0x7b, 0xb1,
- 0xab, 0x10, 0x31, 0x50, 0xfd, 0xcb, 0x1b, 0x28, 0xf3, 0x30, 0xbb, 0x23, 0x3c, 0x66, 0xf5, 0x9c,
- 0xb0, 0x16, 0x99, 0x9b, 0x6a, 0x33, 0xf0, 0xac, 0xe1, 0x3d, 0xef, 0x5d, 0x00, 0x27, 0x84, 0xca,
- 0x58, 0x6b, 0x12, 0xe3, 0x1f, 0x09, 0x28, 0x84, 0x99, 0xc0, 0xb6, 0x48, 0x3d, 0x6a, 0x0f, 0x2d,
- 0xef, 0x12, 0x07, 0x03, 0x6c, 0x3b, 0x16, 0xe1, 0x1e, 0x93, 0x66, 0x99, 0xcb, 0x8f, 0xa5, 0xb8,
- 0x83, 0x1a, 0xb0, 0xe1, 0x78, 0x3f, 0x8c, 0x87, 0x9e, 0xed, 0xe8, 0xe0, 0x24, 0x07, 0xaf, 0x2b,
- 0xd5, 0x15, 0xfe, 0x11, 0xac, 0x4f, 0xfc, 0x79, 0x74, 0x8a, 0xa3, 0x2b, 0x42, 0x11, 0x62, 0x8d,
- 0xbf, 0x66, 0x21, 0x75, 0xe8, 0xf5, 0xde, 0xe3, 0xaf, 0x7f, 0x17, 0x6e, 0xea, 0x16, 0x43, 0x6c,
- 0x13, 0xcc, 0xc9, 0x23, 0xb2, 0x75, 0x43, 0x53, 0xbe, 0x66, 0x3a, 0xc6, 0x95, 0x8f, 0x5a, 0xdf,
- 0x0f, 0xe6, 0xc8, 0x90, 0xe1, 0xb9, 0xf0, 0x79, 0x5c, 0x2e, 0xe8, 0xe4, 0x9a, 0xa5, 0xcc, 0xfc,
- 0x4d, 0x91, 0x7d, 0x8f, 0x9b, 0x22, 0x17, 0xf2, 0x4b, 0x7f, 0x04, 0xc9, 0xcf, 0x3e, 0x82, 0xa8,
- 0x54, 0x2e, 0x68, 0xa9, 0xcc, 0x9a, 0x82, 0xc0, 0xf5, 0x02, 0x97, 0x4e, 0xf9, 0x5f, 0x50, 0xd2,
- 0x0c, 0xc7, 0x73, 0x37, 0x7e, 0xf1, 0x9a, 0x37, 0xfe, 0x37, 0xb0, 0x16, 0x88, 0xb6, 0x4c, 0x6c,
- 0x6b, 0x6d, 0xe5, 0xb6, 0x8a, 0x21, 0xbe, 0x49, 0xb5, 0x07, 0x88, 0xd2, 0x75, 0x1e, 0x20, 0xbe,
- 0x52, 0xd4, 0x2c, 0xf3, 0xe3, 0xf8, 0x6c, 0x39, 0x35, 0xd9, 0x59, 0x08, 0x3c, 0x7a, 0x05, 0x15,
- 0x0e, 0xd5, 0x28, 0x57, 0xe1, 0x2e, 0x8c, 0xd8, 0x13, 0x0d, 0x91, 0x66, 0x99, 0xce, 0x8c, 0x1f,
- 0xfd, 0x3d, 0x01, 0x70, 0x55, 0x86, 0xd0, 0x26, 0x6c, 0x74, 0x9b, 0x9d, 0x57, 0x56, 0xa7, 0xdb,
- 0xec, 0xbe, 0xed, 0x58, 0x27, 0xad, 0xa3, 0x17, 0xed, 0xa3, 0x97, 0xd5, 0x4f, 0xe6, 0x15, 0xe6,
- 0xdb, 0xa3, 0x23, 0xa6, 0x48, 0xcc, 0x2b, 0x3a, 0x6f, 0xf7, 0xf7, 0x5b, 0x9d, 0x4e, 0x35, 0x39,
- 0xaf, 0xf8, 0xb6, 0xd9, 0x7e, 0xfd, 0xd6, 0x6c, 0x55, 0x53, 0xe8, 0x16, 0x20, 0x5d, 0xf1, 0xa6,
- 0xdd, 0x39, 0x68, 0x9e, 0x54, 0xd3, 0x8f, 0xfe, 0x96, 0x80, 0x42, 0x18, 0x26, 0x54, 0x87, 0x5b,
- 0x87, 0xc7, 0x7b, 0x0a, 0xd4, 0x3e, 0xb2, 0x4e, 0xcc, 0xe3, 0x97, 0x26, 0x73, 0xfd, 0x09, 0xf3,
- 0xa0, 0xe9, 0xd4, 0x94, 0x89, 0x39, 0xb9, 0x9a, 0x31, 0x89, 0x6e, 0xc2, 0xba, 0x26, 0x97, 0x13,
- 0xa6, 0xd8, 0x0a, 0x35, 0xf1, 0x7e, 0xf3, 0x68, 0xbf, 0xf5, 0xba, 0xf5, 0xa2, 0x9a, 0xde, 0xfd,
- 0x4b, 0x0e, 0x6e, 0xf0, 0xa0, 0xa8, 0x48, 0x76, 0x70, 0x70, 0xe9, 0xf6, 0x31, 0xfa, 0x1e, 0x8a,
- 0xda, 0x53, 0x29, 0x7a, 0xb0, 0xfc, 0x7d, 0x55, 0xfd, 0xf3, 0xd5, 0x1f, 0xae, 0xc4, 0xc9, 0x3e,
- 0xff, 0x18, 0xb2, 0xe2, 0xe5, 0x14, 0x45, 0xa6, 0xc3, 0xcc, 0xb3, 0x6b, 0xdd, 0x58, 0x06, 0x91,
- 0x0e, 0xff, 0x00, 0x85, 0xf0, 0xa5, 0x14, 0x45, 0x32, 0x7e, 0xfe, 0xb1, 0xb5, 0xfe, 0xb3, 0x15,
- 0x28, 0xe9, 0xf9, 0x8f, 0x00, 0x57, 0xcf, 0x4c, 0x28, 0xd2, 0x68, 0xe1, 0x89, 0xb5, 0xfe, 0x60,
- 0x15, 0x4c, 0x3a, 0x37, 0x21, 0x27, 0x5f, 0x8e, 0x50, 0xdc, 0x2e, 0xb5, 0xd7, 0xa9, 0xfa, 0xfd,
- 0xa5, 0x18, 0xe9, 0xf3, 0x7b, 0x28, 0x6a, 0xbf, 0xf6, 0x68, 0xc9, 0x52, 0xf4, 0xc7, 0xa6, 0xe8,
- 0xb3, 0x8b, 0x7a, 0x23, 0x18, 0x41, 0x75, 0xfe, 0x77, 0x19, 0x3d, 0x8e, 0x59, 0x58, 0xd4, 0xcb,
- 0x40, 0xfd, 0xc9, 0xbb, 0x81, 0xe5, 0x74, 0xe7, 0x50, 0x99, 0xfb, 0x61, 0x45, 0x8f, 0xa2, 0x1c,
- 0x44, 0xff, 0x6d, 0xd7, 0x1f, 0xbf, 0x13, 0x56, 0xce, 0x45, 0x00, 0x2d, 0xfe, 0x9c, 0xa2, 0x9f,
- 0x47, 0xb9, 0x88, 0xfd, 0xe3, 0xad, 0x37, 0xde, 0x15, 0x2e, 0x26, 0xdd, 0xfb, 0xe2, 0xbb, 0x87,
- 0x67, 0x5e, 0x83, 0x5c, 0xb8, 0x76, 0xc3, 0x0b, 0xce, 0x76, 0xdc, 0xf1, 0x69, 0x60, 0xef, 0xcc,
- 0xba, 0xd8, 0x39, 0xf3, 0x76, 0x02, 0xbf, 0xdf, 0xcb, 0xf2, 0x12, 0xfd, 0xe5, 0x4f, 0x01, 0x00,
- 0x00, 0xff, 0xff, 0xea, 0x45, 0x87, 0x19, 0x9e, 0x19, 0x00, 0x00,
+ 0x11, 0x36, 0xfe, 0x81, 0x06, 0xf1, 0xc3, 0x21, 0x2d, 0x42, 0x70, 0x49, 0xa2, 0x57, 0x8e, 0x44,
+ 0x4b, 0x0a, 0x98, 0xa2, 0x4b, 0x72, 0x14, 0xc7, 0x49, 0x40, 0x12, 0x16, 0x49, 0x49, 0x24, 0xbd,
+ 0x00, 0xab, 0x52, 0x4e, 0x95, 0xb7, 0x16, 0xd8, 0x21, 0xb1, 0x24, 0x80, 0xdd, 0xec, 0x0c, 0x68,
+ 0xe3, 0x94, 0xaa, 0x54, 0x0e, 0xb9, 0xe6, 0x92, 0x7b, 0x4e, 0x79, 0x89, 0x3c, 0x49, 0x8e, 0x39,
+ 0xe5, 0x96, 0x57, 0x48, 0xcd, 0xdf, 0x72, 0x00, 0xec, 0x02, 0xa2, 0x74, 0xf0, 0x6d, 0xa7, 0xfb,
+ 0xeb, 0x9e, 0x9e, 0x9e, 0xfe, 0x7a, 0x66, 0x07, 0x0a, 0x81, 0xdf, 0x6b, 0xf8, 0x81, 0x47, 0x3d,
+ 0x84, 0xa8, 0x4d, 0xae, 0x2c, 0xd2, 0xeb, 0x63, 0x67, 0x3c, 0xc0, 0x41, 0x23, 0xf0, 0x7b, 0xf5,
+ 0x07, 0x17, 0x9e, 0x77, 0x31, 0xc0, 0xdb, 0x1c, 0xd1, 0x1d, 0x9f, 0x6f, 0x53, 0x77, 0x88, 0x09,
+ 0xb5, 0x87, 0xbe, 0x30, 0x32, 0x0e, 0x00, 0x3a, 0x81, 0x7b, 0x71, 0x81, 0x83, 0x23, 0xaf, 0x8b,
+ 0xee, 0x42, 0xfe, 0xd2, 0xeb, 0x5a, 0x23, 0x7b, 0x88, 0x6b, 0x89, 0xcd, 0xc4, 0x56, 0xc1, 0xcc,
+ 0x5d, 0x7a, 0xdd, 0x63, 0x7b, 0x88, 0xd1, 0x03, 0x28, 0xf6, 0xbc, 0xe1, 0xd0, 0xa5, 0x56, 0xdf,
+ 0x26, 0xfd, 0x5a, 0x92, 0x6b, 0x41, 0x88, 0x0e, 0x6c, 0xd2, 0x37, 0x0e, 0x00, 0xdd, 0x78, 0x22,
+ 0x26, 0xfe, 0xe3, 0x18, 0x13, 0x8a, 0x76, 0x20, 0x7d, 0xe9, 0x75, 0x49, 0x2d, 0xb1, 0x99, 0xda,
+ 0x2a, 0xee, 0xdc, 0x6f, 0xcc, 0xc7, 0xd8, 0xb8, 0xb1, 0x32, 0x39, 0xd6, 0x68, 0xc0, 0xda, 0x94,
+ 0x27, 0xe2, 0x7b, 0x23, 0x82, 0xd1, 0x06, 0xb0, 0x60, 0x2c, 0xd7, 0x11, 0xde, 0x0a, 0x66, 0xf6,
+ 0xd2, 0xeb, 0x1e, 0x3a, 0xc4, 0x78, 0x00, 0xa5, 0x57, 0x98, 0x32, 0x7b, 0x39, 0x69, 0x19, 0x92,
+ 0xae, 0x23, 0x17, 0x90, 0x74, 0x1d, 0xe3, 0x2b, 0x28, 0x2b, 0x80, 0xf4, 0xf5, 0x39, 0xa4, 0x2e,
+ 0xbd, 0x2e, 0x87, 0x14, 0x77, 0x36, 0xa2, 0xa2, 0x62, 0x68, 0x86, 0x31, 0x0c, 0xa8, 0xee, 0xd9,
+ 0xa3, 0x1e, 0x1e, 0x2c, 0x98, 0xe0, 0x37, 0xb0, 0xaa, 0x61, 0x6e, 0x3f, 0xc7, 0xbf, 0x33, 0xb0,
+ 0xda, 0xc6, 0x76, 0xd0, 0xeb, 0xeb, 0xb9, 0xfb, 0x05, 0xac, 0x77, 0xc7, 0xee, 0xc0, 0xe9, 0x8e,
+ 0x7b, 0x57, 0x98, 0x5a, 0xfc, 0xdb, 0x0a, 0xe7, 0x45, 0x9a, 0x6e, 0x97, 0x7d, 0x1e, 0x3a, 0xe8,
+ 0x4b, 0xa8, 0xf5, 0x6d, 0x62, 0x45, 0x5a, 0xb1, 0x1d, 0xcb, 0x9b, 0x1f, 0xf7, 0x6d, 0xb2, 0x3b,
+ 0x6f, 0x78, 0x17, 0xf2, 0x2e, 0xb1, 0xce, 0xbd, 0xa0, 0x87, 0x6b, 0x29, 0x0e, 0xcc, 0xb9, 0xe4,
+ 0x1b, 0x36, 0x44, 0x9b, 0xb0, 0xc2, 0x7c, 0x86, 0xea, 0x34, 0x57, 0x43, 0xdf, 0x26, 0x87, 0x12,
+ 0xb1, 0x0e, 0x19, 0x97, 0x90, 0x31, 0xae, 0x65, 0x78, 0x60, 0x62, 0x80, 0x3e, 0x81, 0x82, 0xb0,
+ 0x63, 0x9a, 0x2c, 0x37, 0xca, 0x73, 0x23, 0xa6, 0x44, 0x90, 0xe6, 0x45, 0x96, 0xe3, 0x16, 0xfc,
+ 0x9b, 0xc5, 0xc0, 0x0c, 0xb8, 0x3c, 0x2f, 0x62, 0xe8, 0xdb, 0x84, 0x17, 0x5f, 0x1d, 0xf2, 0xbe,
+ 0x4d, 0x7b, 0x7d, 0x82, 0x69, 0xad, 0xc0, 0x4d, 0xc2, 0x31, 0xfa, 0x54, 0xc4, 0x17, 0xea, 0x81,
+ 0x9b, 0x16, 0xfb, 0x36, 0x39, 0x55, 0x10, 0x04, 0xe9, 0x00, 0xfb, 0x5e, 0xad, 0x28, 0x66, 0x63,
+ 0xdf, 0x6a, 0x36, 0x2e, 0x5f, 0x09, 0x67, 0x33, 0x99, 0xaa, 0x0e, 0xf9, 0x00, 0x5f, 0xbb, 0xc4,
+ 0xf5, 0x46, 0xb5, 0x92, 0x98, 0x4d, 0x8d, 0xd5, 0x6c, 0xa1, 0xbe, 0x1c, 0xce, 0x66, 0x2a, 0xc8,
+ 0x73, 0xc8, 0x12, 0x6a, 0xd3, 0x31, 0xa9, 0x55, 0x36, 0x13, 0x5b, 0xe5, 0x9d, 0x7b, 0x31, 0x5b,
+ 0xdf, 0xe6, 0x20, 0x53, 0x82, 0xd1, 0x3d, 0x60, 0x39, 0xb5, 0xa4, 0x69, 0x95, 0xfb, 0x65, 0x19,
+ 0x14, 0x30, 0xf4, 0x12, 0x80, 0x71, 0x97, 0xe9, 0x03, 0x5a, 0x5b, 0xe5, 0x45, 0x55, 0x6f, 0x08,
+ 0x7a, 0x37, 0x14, 0xbd, 0x1b, 0x1d, 0x45, 0x6f, 0xb3, 0xc0, 0xd0, 0x6d, 0x06, 0x46, 0x9f, 0x41,
+ 0x99, 0x79, 0xd6, 0xcc, 0x11, 0xf7, 0xce, 0x56, 0xd2, 0x09, 0x51, 0xcf, 0x21, 0xcf, 0x11, 0x78,
+ 0xe4, 0xd4, 0xd6, 0x96, 0xba, 0xcf, 0x31, 0x6c, 0x6b, 0xe4, 0xa8, 0xf2, 0x08, 0x4d, 0xd7, 0xc3,
+ 0xf2, 0xe8, 0x08, 0x84, 0xd1, 0x04, 0xa4, 0xd7, 0xb6, 0x64, 0xc7, 0xd3, 0xa9, 0xc6, 0x10, 0x4b,
+ 0x0f, 0xd1, 0x11, 0x5a, 0x9c, 0xc0, 0x1d, 0x9b, 0x5c, 0xc5, 0x30, 0x10, 0x3d, 0x84, 0x92, 0x3b,
+ 0xea, 0x0d, 0xc6, 0x0e, 0x5f, 0x22, 0x25, 0xb2, 0xdc, 0x57, 0xa4, 0x90, 0x25, 0x91, 0x18, 0xbf,
+ 0x85, 0x4a, 0xe8, 0x46, 0x86, 0xf1, 0x0c, 0xd2, 0x6c, 0x66, 0xc9, 0xd2, 0x5a, 0x64, 0x7f, 0x62,
+ 0x78, 0x8e, 0x32, 0xfe, 0x97, 0x56, 0x6b, 0x61, 0xc2, 0x90, 0xa8, 0x35, 0xc8, 0xd9, 0x94, 0xe2,
+ 0xa1, 0x4f, 0xb9, 0x9f, 0x8c, 0xa9, 0x86, 0xac, 0x6b, 0xb2, 0xec, 0x28, 0x6d, 0x32, 0x4c, 0x4e,
+ 0x53, 0x02, 0x42, 0xee, 0xa4, 0x62, 0xb9, 0x93, 0x8e, 0xe1, 0x4e, 0x26, 0x86, 0x3b, 0xd9, 0x78,
+ 0xee, 0xe4, 0x96, 0x70, 0x27, 0x1f, 0xcf, 0x9d, 0x42, 0x0c, 0x77, 0x20, 0x9e, 0x3b, 0xc5, 0x25,
+ 0xdc, 0x59, 0x99, 0xe7, 0xce, 0x8b, 0x90, 0x3b, 0x25, 0xce, 0x9d, 0xfb, 0x71, 0x1b, 0xb2, 0x90,
+ 0x3c, 0xe5, 0xc5, 0xe4, 0xa9, 0x7c, 0x18, 0x79, 0xaa, 0x4b, 0xc8, 0xb3, 0xfa, 0xfe, 0xe4, 0x41,
+ 0x73, 0xe4, 0x69, 0xc1, 0xda, 0x54, 0xc1, 0xc9, 0xb2, 0x6d, 0x40, 0x86, 0x25, 0x46, 0xd1, 0x27,
+ 0xbe, 0x6e, 0x05, 0xcc, 0xb8, 0x0b, 0x1b, 0xaf, 0x30, 0x6d, 0x5f, 0xb9, 0x3e, 0x97, 0x8e, 0x07,
+ 0x58, 0x15, 0xaf, 0xf1, 0xcf, 0x04, 0xac, 0xe8, 0x0a, 0xb6, 0xbb, 0xb6, 0xe3, 0x60, 0xc7, 0xea,
+ 0x4e, 0xd4, 0x25, 0x80, 0x8f, 0x77, 0x27, 0xe8, 0x19, 0xc8, 0x4b, 0x86, 0x8f, 0x7b, 0xac, 0x6a,
+ 0x28, 0x0e, 0x46, 0x8c, 0x6a, 0xec, 0x34, 0xae, 0x32, 0x4d, 0xdb, 0xc7, 0xbd, 0x53, 0x29, 0x67,
+ 0xb4, 0x10, 0xf7, 0x03, 0x52, 0x4b, 0x71, 0x88, 0x1a, 0xa2, 0x4d, 0x28, 0x3a, 0x98, 0xf4, 0x02,
+ 0xd7, 0xa7, 0xac, 0x10, 0xd2, 0x7c, 0x16, 0x5d, 0x14, 0x55, 0xe4, 0x86, 0x09, 0xb5, 0xf9, 0x45,
+ 0xc8, 0x84, 0xbc, 0x80, 0x4c, 0xc0, 0x04, 0x32, 0x21, 0x9b, 0x51, 0x09, 0xd1, 0x2d, 0x4d, 0x01,
+ 0x37, 0xfe, 0x9e, 0x80, 0x3b, 0x4d, 0xc7, 0x99, 0x52, 0x49, 0x56, 0xff, 0xb4, 0x8b, 0xfd, 0x16,
+ 0x36, 0xe6, 0xe2, 0xfa, 0xc0, 0xb5, 0x3e, 0x85, 0xbb, 0xfb, 0x78, 0x80, 0x29, 0x8e, 0x5a, 0xed,
+ 0xec, 0x95, 0xa6, 0x03, 0xf5, 0x28, 0xf0, 0x07, 0x86, 0xf0, 0xdf, 0x04, 0x14, 0x58, 0x9f, 0x60,
+ 0xbc, 0xc4, 0xe8, 0x25, 0x64, 0x78, 0xeb, 0x91, 0xdd, 0xf7, 0x61, 0x94, 0x97, 0x10, 0xdd, 0xe0,
+ 0x2d, 0xc9, 0x14, 0x16, 0x61, 0x5b, 0x4a, 0x6a, 0x6d, 0x49, 0xef, 0x3d, 0xa9, 0xe9, 0xde, 0x53,
+ 0xf7, 0x21, 0xc3, 0xed, 0x6f, 0x1a, 0x6e, 0x42, 0x6f, 0xb8, 0xf7, 0x00, 0xb8, 0x5f, 0x4b, 0x73,
+ 0x5a, 0xe0, 0x12, 0xd5, 0xd5, 0xc2, 0x1e, 0x99, 0x9a, 0xe9, 0xa1, 0x77, 0x20, 0x4b, 0x70, 0x70,
+ 0x8d, 0x03, 0xb9, 0xb3, 0x72, 0x64, 0xfc, 0x09, 0x72, 0x6c, 0xf5, 0xaf, 0xf1, 0x04, 0xfd, 0x1a,
+ 0x80, 0xf9, 0xe5, 0xed, 0x09, 0xcb, 0xc5, 0xde, 0x5b, 0xb8, 0x58, 0xb3, 0x10, 0x84, 0x59, 0x52,
+ 0xd5, 0x91, 0xd4, 0xfa, 0xbd, 0x01, 0x25, 0x7e, 0x1b, 0x73, 0x2c, 0x71, 0x25, 0x96, 0x51, 0x15,
+ 0x85, 0xf0, 0x88, 0xdd, 0x8b, 0x8d, 0xff, 0x64, 0x21, 0xcd, 0x22, 0x58, 0x70, 0x3c, 0x69, 0x45,
+ 0x9b, 0x9c, 0x2e, 0xda, 0x97, 0x00, 0xbd, 0x00, 0xdb, 0x14, 0x3b, 0x96, 0x2d, 0xd6, 0xbc, 0xa4,
+ 0x63, 0x4a, 0x74, 0x93, 0xa2, 0xdf, 0x41, 0xd9, 0xe9, 0x5a, 0x43, 0xcf, 0x71, 0xcf, 0x5d, 0x61,
+ 0x9e, 0x5e, 0x6a, 0xbe, 0xe2, 0x74, 0xdf, 0x4a, 0x83, 0x26, 0x45, 0x5f, 0x41, 0xf1, 0xdc, 0x1d,
+ 0xb9, 0xa4, 0x2f, 0xcc, 0x33, 0x4b, 0xcd, 0x41, 0xc1, 0x9b, 0xaa, 0x90, 0xb3, 0xe1, 0xcd, 0xe0,
+ 0x31, 0x54, 0x5c, 0xe2, 0x0d, 0xf8, 0x52, 0xbc, 0x31, 0xf5, 0xc7, 0xea, 0x18, 0x2c, 0x2b, 0xf1,
+ 0x09, 0x97, 0xb2, 0x3c, 0xf3, 0x1b, 0x49, 0x9e, 0x67, 0x82, 0x7f, 0xb3, 0x23, 0x6b, 0x68, 0xff,
+ 0xa8, 0xce, 0x6f, 0xc2, 0x4f, 0xc1, 0x8c, 0x59, 0x1c, 0xda, 0x3f, 0xca, 0x03, 0x9c, 0xa0, 0x47,
+ 0x50, 0xf1, 0xed, 0x00, 0x8f, 0xa8, 0xc5, 0x37, 0x94, 0xfd, 0x9e, 0x00, 0xf7, 0x50, 0x12, 0x62,
+ 0xb6, 0x05, 0x87, 0x0e, 0x41, 0x07, 0x00, 0x7e, 0xe0, 0xf9, 0x38, 0xa0, 0x2e, 0x26, 0xb5, 0x22,
+ 0xe7, 0xcd, 0x56, 0x5c, 0xdf, 0x6e, 0x9c, 0x86, 0xd0, 0xd6, 0x88, 0x06, 0x13, 0x53, 0xb3, 0x65,
+ 0x0d, 0x3a, 0xc0, 0x34, 0x98, 0x58, 0xde, 0x39, 0x3f, 0x43, 0x0b, 0x66, 0x8e, 0x8f, 0x4f, 0xce,
+ 0xd9, 0xb6, 0xf1, 0x43, 0x4a, 0x24, 0xae, 0xb4, 0x7c, 0xdb, 0x24, 0xba, 0x49, 0xb5, 0xa3, 0xb7,
+ 0x7c, 0xab, 0xa3, 0xf7, 0x11, 0x54, 0xc8, 0x0f, 0x76, 0x30, 0x74, 0x47, 0x17, 0x56, 0xd7, 0xa3,
+ 0xac, 0x18, 0x2b, 0x3c, 0xa8, 0x92, 0x12, 0xef, 0x7a, 0xf4, 0xd0, 0x41, 0x5b, 0x50, 0x0d, 0x71,
+ 0x32, 0x53, 0xfc, 0x28, 0x2d, 0x98, 0x65, 0x25, 0x17, 0xa9, 0x42, 0x2f, 0x20, 0xcf, 0x01, 0x57,
+ 0x78, 0x22, 0x0f, 0xd3, 0x4f, 0xe2, 0x62, 0x79, 0x8d, 0x27, 0x66, 0x8e, 0x4a, 0x9a, 0x7d, 0x01,
+ 0x19, 0x71, 0xf7, 0x43, 0xf1, 0x0c, 0x53, 0x0b, 0x20, 0xa6, 0xc0, 0xd6, 0xbf, 0x86, 0xca, 0x4c,
+ 0xae, 0x51, 0x15, 0x52, 0x6c, 0x6a, 0xd1, 0x20, 0xd8, 0x27, 0x6b, 0x1a, 0xd7, 0xf6, 0x60, 0xac,
+ 0x38, 0x28, 0x06, 0xbf, 0x4a, 0xfe, 0x32, 0x61, 0x1c, 0x41, 0x95, 0xb9, 0xdc, 0xc7, 0x3e, 0x1e,
+ 0x39, 0x78, 0xd4, 0x63, 0xfb, 0x83, 0xb4, 0x3b, 0x65, 0x41, 0xdc, 0x1c, 0x91, 0x01, 0x2b, 0x8e,
+ 0x86, 0x91, 0x74, 0x9b, 0x92, 0x19, 0xff, 0x4a, 0x40, 0x91, 0xc7, 0x37, 0x1e, 0x0e, 0xed, 0x60,
+ 0x32, 0x77, 0xc7, 0xd5, 0x78, 0x9c, 0x9c, 0xe6, 0xf1, 0x6c, 0x99, 0xa6, 0xe6, 0xcb, 0xf4, 0x66,
+ 0x7b, 0xd3, 0xb7, 0xda, 0xde, 0xa8, 0x6d, 0xcb, 0x44, 0x6d, 0x9b, 0xf1, 0x1d, 0x94, 0x6e, 0xa2,
+ 0x97, 0x79, 0xd0, 0x5e, 0x12, 0x44, 0xe3, 0x7a, 0xae, 0x2e, 0x2e, 0x49, 0x4e, 0x80, 0x07, 0xb1,
+ 0x51, 0x88, 0x1c, 0xa8, 0xfb, 0xcb, 0x5b, 0x28, 0xf3, 0x34, 0xbb, 0x43, 0x3c, 0x62, 0xfd, 0x9c,
+ 0xb0, 0x2b, 0x32, 0x37, 0xd5, 0x66, 0xe0, 0x55, 0xc3, 0xef, 0xbc, 0xf7, 0x01, 0x9c, 0x10, 0x2a,
+ 0x73, 0xad, 0x49, 0x8c, 0xbf, 0x25, 0xa0, 0x10, 0x56, 0x02, 0x5b, 0x22, 0xf5, 0xa8, 0x3d, 0xb0,
+ 0xbc, 0x6b, 0x1c, 0xf4, 0xb1, 0xed, 0x58, 0x84, 0x7b, 0x4c, 0x9a, 0x65, 0x2e, 0x3f, 0x91, 0xe2,
+ 0x36, 0x6a, 0xc0, 0x9a, 0xe3, 0xfd, 0x30, 0x1a, 0x78, 0xb6, 0xa3, 0x83, 0x93, 0x1c, 0xbc, 0xaa,
+ 0x54, 0x37, 0xf8, 0x27, 0xb0, 0x3a, 0xf6, 0x67, 0xd1, 0x29, 0x8e, 0xae, 0x08, 0x45, 0x88, 0x35,
+ 0xfe, 0x92, 0x85, 0xd4, 0x91, 0xd7, 0x7d, 0x8f, 0xbf, 0xfe, 0x1d, 0xf8, 0x58, 0xb7, 0x18, 0x60,
+ 0x9b, 0x60, 0x4e, 0x1e, 0x51, 0xad, 0x6b, 0x9a, 0xf2, 0x0d, 0xd3, 0x31, 0xae, 0xfc, 0xa4, 0xfd,
+ 0xfd, 0x60, 0x86, 0x0c, 0x19, 0x5e, 0x0b, 0x9f, 0xc5, 0xd5, 0x82, 0x4e, 0xae, 0x69, 0xca, 0xcc,
+ 0x9e, 0x14, 0xd9, 0xf7, 0x38, 0x29, 0x72, 0x21, 0xbf, 0xf4, 0x47, 0x90, 0xfc, 0xf4, 0x23, 0x88,
+ 0x2a, 0xe5, 0x82, 0x56, 0xca, 0xec, 0x52, 0x10, 0xb8, 0x5e, 0xe0, 0xd2, 0x09, 0xff, 0x0b, 0x4a,
+ 0x9a, 0xe1, 0x78, 0xe6, 0xc4, 0x2f, 0xde, 0xf2, 0xc4, 0xff, 0x1a, 0x56, 0x02, 0x71, 0x2d, 0x13,
+ 0xcb, 0x5a, 0x59, 0xba, 0xac, 0x62, 0x88, 0x6f, 0x52, 0xed, 0x01, 0xa2, 0x74, 0x9b, 0x07, 0x88,
+ 0x2f, 0x15, 0x35, 0xcb, 0x7c, 0x3b, 0x3e, 0x5d, 0x4c, 0x4d, 0xb6, 0x17, 0x02, 0x8f, 0x5e, 0x43,
+ 0x85, 0x43, 0x35, 0xca, 0x55, 0xb8, 0x0b, 0x23, 0x76, 0x47, 0x43, 0xa4, 0x59, 0xa6, 0x53, 0xe3,
+ 0x27, 0x7f, 0x4d, 0x00, 0xdc, 0xb4, 0x21, 0xb4, 0x01, 0x6b, 0x9d, 0x66, 0xfb, 0xb5, 0xd5, 0xee,
+ 0x34, 0x3b, 0x67, 0x6d, 0xeb, 0xb4, 0x75, 0xbc, 0x7f, 0x78, 0xfc, 0xaa, 0xfa, 0xd1, 0xac, 0xc2,
+ 0x3c, 0x3b, 0x3e, 0x66, 0x8a, 0xc4, 0xac, 0xa2, 0x7d, 0xb6, 0xb7, 0xd7, 0x6a, 0xb7, 0xab, 0xc9,
+ 0x59, 0xc5, 0x37, 0xcd, 0xc3, 0x37, 0x67, 0x66, 0xab, 0x9a, 0x42, 0x77, 0x00, 0xe9, 0x8a, 0xb7,
+ 0x87, 0xed, 0x83, 0xe6, 0x69, 0x35, 0xfd, 0xe4, 0x1f, 0x09, 0x28, 0x84, 0x69, 0x42, 0x75, 0xb8,
+ 0x73, 0x74, 0xb2, 0xab, 0x40, 0x87, 0xc7, 0xd6, 0xa9, 0x79, 0xf2, 0xca, 0x64, 0xae, 0x3f, 0x62,
+ 0x1e, 0x34, 0x9d, 0x9a, 0x32, 0x31, 0x23, 0x57, 0x33, 0x26, 0xd1, 0xc7, 0xb0, 0xaa, 0xc9, 0xe5,
+ 0x84, 0x29, 0x16, 0xa1, 0x26, 0xde, 0x6b, 0x1e, 0xef, 0xb5, 0xde, 0xb4, 0xf6, 0xab, 0x69, 0x54,
+ 0x83, 0x75, 0x4d, 0x61, 0xb6, 0xbe, 0x3d, 0x6b, 0xb5, 0x3b, 0xad, 0xfd, 0x6a, 0x66, 0xe7, 0xcf,
+ 0x39, 0x58, 0xe7, 0xe9, 0x52, 0x39, 0x6e, 0xe3, 0xe0, 0xda, 0xed, 0x61, 0xf4, 0x3d, 0x14, 0xb5,
+ 0x47, 0x54, 0xf4, 0x68, 0xf1, 0xcb, 0xab, 0xfa, 0x1b, 0xac, 0x3f, 0x5e, 0x8a, 0x93, 0x7f, 0x00,
+ 0x27, 0x90, 0x15, 0x6f, 0xaa, 0x28, 0xb2, 0x50, 0xa6, 0x1e, 0x64, 0xeb, 0xc6, 0x22, 0x88, 0x74,
+ 0xf8, 0x7b, 0x28, 0x84, 0x6f, 0xa8, 0x28, 0xb2, 0x17, 0xcc, 0x3e, 0xc3, 0xd6, 0x7f, 0xb6, 0x04,
+ 0x25, 0x3d, 0xff, 0x01, 0xe0, 0xe6, 0x01, 0x0a, 0x45, 0x1a, 0xcd, 0x3d, 0xbe, 0xd6, 0x1f, 0x2d,
+ 0x83, 0x49, 0xe7, 0x26, 0xe4, 0xe4, 0x9b, 0x12, 0x8a, 0x5b, 0xa5, 0xf6, 0x6e, 0x55, 0x7f, 0xb8,
+ 0x10, 0x23, 0x7d, 0x7e, 0x0f, 0x45, 0xed, 0xa7, 0x1f, 0x2d, 0x08, 0x45, 0x7f, 0x86, 0x8a, 0xde,
+ 0xbb, 0xa8, 0xd7, 0x83, 0x21, 0x54, 0x67, 0x7f, 0xa4, 0xd1, 0xd3, 0x98, 0xc0, 0xa2, 0xde, 0x0c,
+ 0xea, 0xcf, 0xde, 0x0d, 0x2c, 0xa7, 0xbb, 0x84, 0xca, 0xcc, 0xaf, 0x2c, 0x7a, 0x12, 0xe5, 0x20,
+ 0xfa, 0x3f, 0xbc, 0xfe, 0xf4, 0x9d, 0xb0, 0x72, 0x2e, 0x02, 0x68, 0xfe, 0xb7, 0x15, 0xfd, 0x3c,
+ 0xca, 0x45, 0xec, 0xbf, 0x70, 0xbd, 0xf1, 0xae, 0x70, 0x31, 0xe9, 0xee, 0xe7, 0xdf, 0x3d, 0xbe,
+ 0xf0, 0x1a, 0xe4, 0xca, 0xb5, 0x1b, 0x5e, 0x70, 0xb1, 0xed, 0x8e, 0xce, 0x03, 0x7b, 0x7b, 0xda,
+ 0xc5, 0xf6, 0x85, 0xb7, 0x1d, 0xf8, 0xbd, 0x6e, 0x96, 0x37, 0xef, 0x2f, 0xfe, 0x1f, 0x00, 0x00,
+ 0xff, 0xff, 0x2c, 0x29, 0x38, 0xa7, 0xb8, 0x19, 0x00, 0x00,
}
diff --git a/task_scheduler/go/rpc/rpc_test.go b/task_scheduler/go/rpc/rpc_test.go
index 9607d53..bcb11e1 100644
--- a/task_scheduler/go/rpc/rpc_test.go
+++ b/task_scheduler/go/rpc/rpc_test.go
@@ -537,6 +537,7 @@
require.Equal(t, expect, actual)
}
+ test(types.JOB_STATUS_REQUESTED, JobStatus_JOB_STATUS_REQUESTED)
test(types.JOB_STATUS_IN_PROGRESS, JobStatus_JOB_STATUS_IN_PROGRESS)
test(types.JOB_STATUS_SUCCESS, JobStatus_JOB_STATUS_SUCCESS)
test(types.JOB_STATUS_FAILURE, JobStatus_JOB_STATUS_FAILURE)
diff --git a/task_scheduler/go/types/job.go b/task_scheduler/go/types/job.go
index d408a28..360c562 100644
--- a/task_scheduler/go/types/job.go
+++ b/task_scheduler/go/types/job.go
@@ -8,6 +8,10 @@
)
const (
+ // JOB_STATUS_REQUESTED indicates that we are aware of the Job but are not
+ // yet ready to start running Tasks for it.
+ JOB_STATUS_REQUESTED JobStatus = "REQUESTED"
+
// JOB_STATUS_IN_PROGRESS indicates that one or more of the Job's
// Task dependencies has not yet been satisfied.
JOB_STATUS_IN_PROGRESS JobStatus = ""
@@ -41,11 +45,13 @@
JOB_STATUS_BADNESS = map[JobStatus]int{
JOB_STATUS_SUCCESS: 0,
JOB_STATUS_IN_PROGRESS: 1,
- JOB_STATUS_CANCELED: 2,
- JOB_STATUS_FAILURE: 3,
- JOB_STATUS_MISHAP: 4,
+ JOB_STATUS_REQUESTED: 2,
+ JOB_STATUS_CANCELED: 3,
+ JOB_STATUS_FAILURE: 4,
+ JOB_STATUS_MISHAP: 5,
}
VALID_JOB_STATUSES = []JobStatus{
+ JOB_STATUS_REQUESTED,
JOB_STATUS_IN_PROGRESS,
JOB_STATUS_SUCCESS,
JOB_STATUS_FAILURE,
diff --git a/task_scheduler/modules/rpc/rpc.ts b/task_scheduler/modules/rpc/rpc.ts
index 4dd8dbd..98cd3ef 100644
--- a/task_scheduler/modules/rpc/rpc.ts
+++ b/task_scheduler/modules/rpc/rpc.ts
@@ -14,6 +14,7 @@
JOB_STATUS_FAILURE = "JOB_STATUS_FAILURE",
JOB_STATUS_MISHAP = "JOB_STATUS_MISHAP",
JOB_STATUS_CANCELED = "JOB_STATUS_CANCELED",
+ JOB_STATUS_REQUESTED = "JOB_STATUS_REQUESTED",
}
export interface TriggerJob {