Not updating summary if job is de-registered

This commit is contained in:
Diptanu Choudhury 2016-08-03 16:58:12 -07:00
parent 74caed0c7a
commit c24e8ba7d8
2 changed files with 56 additions and 1 deletions

View file

@ -1453,6 +1453,16 @@ func (s *StateStore) updateSummaryWithAlloc(index uint64, alloc *structs.Allocat
return fmt.Errorf("unable to lookup job summary for job id %q: %v", err) return fmt.Errorf("unable to lookup job summary for job id %q: %v", err)
} }
if summaryRaw == nil { if summaryRaw == nil {
// Check if the job is de-registered
rawJob, err := txn.First("jobs", "id", alloc.JobID)
if err != nil {
return fmt.Errorf("unable to query job: %v", err)
}
// If the job is de-registered then we skip updating it's summary
if rawJob == nil {
return nil
}
return fmt.Errorf("job summary for job %q is not present", alloc.JobID) return fmt.Errorf("job summary for job %q is not present", alloc.JobID)
} }
summary := summaryRaw.(structs.JobSummary) summary := summaryRaw.(structs.JobSummary)

View file

@ -2073,7 +2073,7 @@ func TestStateStore_ReconcileJobSummary(t *testing.T) {
// DeleteJobSummary is a helper method and doesn't modify the indexes table // DeleteJobSummary is a helper method and doesn't modify the indexes table
state.DeleteJobSummary(130, alloc.Job.ID) state.DeleteJobSummary(130, alloc.Job.ID)
state.ReconcileJobSummaries() state.ReconcileJobSummaries(120)
summary, _ := state.JobSummaryByID(alloc.Job.ID) summary, _ := state.JobSummaryByID(alloc.Job.ID)
expectedSummary := structs.JobSummary{ expectedSummary := structs.JobSummary{
@ -2092,6 +2092,51 @@ func TestStateStore_ReconcileJobSummary(t *testing.T) {
} }
} }
func TestStateStore_UpdateAlloc_JobNotPresent(t *testing.T) {
state := testStateStore(t)
alloc := mock.Alloc()
state.UpsertJob(100, alloc.Job)
state.UpsertAllocs(200, []*structs.Allocation{alloc})
// Delete the job
state.DeleteJob(300, alloc.Job.ID)
// Update the alloc
alloc1 := alloc.Copy()
alloc1.ClientStatus = structs.AllocClientStatusRunning
// Updating allocation should not throw any error
if err := state.UpdateAllocsFromClient(400, []*structs.Allocation{alloc1}); err != nil {
t.Fatalf("expect err: %v", err)
}
// Re-Register the job
state.UpsertJob(500, alloc.Job)
// Update the alloc again
alloc2 := alloc.Copy()
alloc2.ClientStatus = structs.AllocClientStatusComplete
if err := state.UpdateAllocsFromClient(400, []*structs.Allocation{alloc1}); err != nil {
t.Fatalf("expect err: %v", err)
}
// Job Summary of the newly registered job shouldn't account for the
// allocation update for the older job
expectedSummary := structs.JobSummary{
JobID: alloc1.JobID,
Summary: map[string]structs.TaskGroupSummary{
"web": structs.TaskGroupSummary{},
},
CreateIndex: 500,
ModifyIndex: 500,
}
summary, _ := state.JobSummaryByID(alloc.Job.ID)
if !reflect.DeepEqual(&expectedSummary, summary) {
t.Fatalf("expected: %v, actual: %v", expectedSummary, summary)
}
}
func TestStateStore_EvictAlloc_Alloc(t *testing.T) { func TestStateStore_EvictAlloc_Alloc(t *testing.T) {
state := testStateStore(t) state := testStateStore(t)
alloc := mock.Alloc() alloc := mock.Alloc()