From 1c33da9d642d21815b99e146a29e84921c8ac525 Mon Sep 17 00:00:00 2001 From: James Rasell Date: Fri, 5 Nov 2021 15:52:31 +0100 Subject: [PATCH] Merge pull request #11429 from hashicorp/b-set-scale-eval-priority-correctly rpc: set the job scale eval priority to the job priority. --- .changelog/11429.txt | 3 +++ nomad/job_endpoint.go | 2 +- nomad/job_endpoint_test.go | 50 ++++++++++++++++++++++++++++++++++++++ 3 files changed, 54 insertions(+), 1 deletion(-) create mode 100644 .changelog/11429.txt diff --git a/.changelog/11429.txt b/.changelog/11429.txt new file mode 100644 index 00000000000..51ac2232887 --- /dev/null +++ b/.changelog/11429.txt @@ -0,0 +1,3 @@ +```release-note:bug +rpc: Set the job scale eval priority to the job priority +``` diff --git a/nomad/job_endpoint.go b/nomad/job_endpoint.go index 9f4371481f7..adbcaee68a0 100644 --- a/nomad/job_endpoint.go +++ b/nomad/job_endpoint.go @@ -1125,7 +1125,7 @@ func (j *Job) Scale(args *structs.JobScaleRequest, reply *structs.JobRegisterRes eval := &structs.Evaluation{ ID: uuid.Generate(), Namespace: namespace, - Priority: structs.JobDefaultPriority, + Priority: job.Priority, // Safe as nil check performed above. Type: structs.JobTypeService, TriggeredBy: structs.EvalTriggerScaling, JobID: args.JobID, diff --git a/nomad/job_endpoint_test.go b/nomad/job_endpoint_test.go index 2278ca71ce9..b356b5af7fa 100644 --- a/nomad/job_endpoint_test.go +++ b/nomad/job_endpoint_test.go @@ -6975,6 +6975,56 @@ func TestJobEndpoint_Scale_NoEval(t *testing.T) { require.Equal(int64(originalCount), events[groupName][0].PreviousCount) } +func TestJobEndpoint_Scale_Priority(t *testing.T) { + t.Parallel() + requireAssertion := require.New(t) + + s1, cleanupS1 := TestServer(t, nil) + defer cleanupS1() + codec := rpcClient(t, s1) + testutil.WaitForLeader(t, s1.RPC) + fsmState := s1.fsm.State() + + // Create a job and alter the priority. + job := mock.Job() + job.Priority = 90 + originalCount := job.TaskGroups[0].Count + err := fsmState.UpsertJob(structs.MsgTypeTestSetup, 1000, job) + requireAssertion.Nil(err) + + groupName := job.TaskGroups[0].Name + scale := &structs.JobScaleRequest{ + JobID: job.ID, + Target: map[string]string{ + structs.ScalingTargetGroup: groupName, + }, + Count: helper.Int64ToPtr(int64(originalCount + 1)), + Message: "scotty, we need more power", + PolicyOverride: false, + WriteRequest: structs.WriteRequest{ + Region: "global", + Namespace: job.Namespace, + }, + } + var resp structs.JobRegisterResponse + err = msgpackrpc.CallWithCodec(codec, "Job.Scale", scale, &resp) + requireAssertion.NoError(err) + requireAssertion.NotEmpty(resp.EvalID) + requireAssertion.Greater(resp.EvalCreateIndex, resp.JobModifyIndex) + + // Check the evaluation priority matches the job priority. + eval, err := fsmState.EvalByID(nil, resp.EvalID) + requireAssertion.Nil(err) + requireAssertion.NotNil(eval) + requireAssertion.EqualValues(resp.EvalCreateIndex, eval.CreateIndex) + requireAssertion.Equal(job.Priority, eval.Priority) + requireAssertion.Equal(job.Type, eval.Type) + requireAssertion.Equal(structs.EvalTriggerScaling, eval.TriggeredBy) + requireAssertion.Equal(job.ID, eval.JobID) + requireAssertion.NotZero(eval.CreateTime) + requireAssertion.NotZero(eval.ModifyTime) +} + func TestJobEndpoint_InvalidCount(t *testing.T) { t.Parallel() require := require.New(t)