Files
nomad/command/scaling_policy_list_test.go
2024-12-19 15:41:11 +00:00

60 lines
1.6 KiB
Go

// Copyright (c) HashiCorp, Inc.
// SPDX-License-Identifier: BUSL-1.1
package command
import (
"testing"
"github.com/hashicorp/cli"
"github.com/hashicorp/nomad/api"
"github.com/hashicorp/nomad/ci"
"github.com/hashicorp/nomad/helper/pointer"
"github.com/shoenig/test/must"
)
func TestScalingPolicyListCommand_Run(t *testing.T) {
ci.Parallel(t)
srv, client, url := testServer(t, false, nil)
defer srv.Shutdown()
ui := cli.NewMockUi()
cmd := &ScalingPolicyListCommand{Meta: Meta{Ui: ui}}
// Perform an initial list, which should return zero results.
code := cmd.Run([]string{"-address=" + url})
must.Zero(t, code)
out := ui.OutputWriter.String()
must.StrContains(t, out, "No policies found")
// Generate two test jobs.
jobs := []*api.Job{testJob("scaling_policy_list_1"), testJob("scaling_policy_list_2")}
// Generate an example scaling policy.
scalingPolicy := api.ScalingPolicy{
Type: api.ScalingPolicyTypeHorizontal,
Enabled: pointer.Of(true),
Min: pointer.Of(int64(1)),
Max: pointer.Of(int64(1)),
}
// Iterate the jobs, add the scaling policy and register.
for _, job := range jobs {
job.TaskGroups[0].Scaling = &scalingPolicy
_, _, err := client.Jobs().Register(job, nil)
must.NoError(t, err)
}
// Perform a new list which should yield results..
code = cmd.Run([]string{"-address=" + url})
must.Zero(t, code)
out = ui.OutputWriter.String()
must.StrContains(t, out, "ID")
must.StrContains(t, out, "Enabled")
must.StrContains(t, out, "Type")
must.StrContains(t, out, "Target")
must.StrContains(t, out, "scaling_policy_list_1")
must.StrContains(t, out, "scaling_policy_list_2")
}