From 2e1761040620b2fe6da87784630007eac9efb79d Mon Sep 17 00:00:00 2001 From: Joel May Date: Sat, 5 Dec 2020 01:46:51 +0000 Subject: [PATCH] Allow client.cpu_total_compute to override attr.cpu.totalcompute --- client/fingerprint/cpu.go | 5 ----- client/fingerprint/cpu_test.go | 4 ++++ client/fingerprint/env_aws.go | 2 ++ client/fingerprint/env_aws_test.go | 2 +- 4 files changed, 7 insertions(+), 6 deletions(-) diff --git a/client/fingerprint/cpu.go b/client/fingerprint/cpu.go index a4b1c091ed3..2791698ca8d 100644 --- a/client/fingerprint/cpu.go +++ b/client/fingerprint/cpu.go @@ -47,11 +47,6 @@ func (f *CPUFingerprint) Fingerprint(req *FingerprintRequest, resp *FingerprintR f.logger.Warn("failed initializing stats collector", "error", err) } - if cfg.CpuCompute != 0 { - setResourcesCPU(cfg.CpuCompute) - return nil - } - if modelName := stats.CPUModelName(); modelName != "" { resp.AddAttribute("cpu.modelname", modelName) } diff --git a/client/fingerprint/cpu_test.go b/client/fingerprint/cpu_test.go index 7546f9e746c..b6f4fdaca1c 100644 --- a/client/fingerprint/cpu_test.go +++ b/client/fingerprint/cpu_test.go @@ -1,6 +1,7 @@ package fingerprint import ( + "strconv" "testing" "github.com/hashicorp/nomad/client/config" @@ -102,5 +103,8 @@ func TestCPUFingerprint_OverrideCompute(t *testing.T) { if response.NodeResources.Cpu.CpuShares != int64(cfg.CpuCompute) { t.Fatalf("expected override cpu of %d but found %d", cfg.CpuCompute, response.NodeResources.Cpu.CpuShares) } + if response.Attributes["cpu.totalcompute"] != strconv.Itoa(cfg.CpuCompute) { + t.Fatalf("expected override cpu.totalcompute of %d but found %s", cfg.CpuCompute, response.Attributes["cpu.totalcompute"]) + } } } diff --git a/client/fingerprint/env_aws.go b/client/fingerprint/env_aws.go index 6e54076de1b..9d77c997dea 100644 --- a/client/fingerprint/env_aws.go +++ b/client/fingerprint/env_aws.go @@ -187,6 +187,8 @@ func (f *EnvAWSFingerprint) Fingerprint(request *FingerprintRequest, response *F nodeResources = new(structs.NodeResources) } nodeResources.Cpu = structs.NodeCpuResources{CpuShares: int64(ticks)} + } else { + response.AddAttribute("cpu.totalcompute", fmt.Sprintf("%d", request.Config.CpuCompute)) } } else { f.logger.Warn("failed to find the cpu specification for this instance type") diff --git a/client/fingerprint/env_aws_test.go b/client/fingerprint/env_aws_test.go index 7b50e43f088..fb3f0510b2b 100644 --- a/client/fingerprint/env_aws_test.go +++ b/client/fingerprint/env_aws_test.go @@ -241,7 +241,7 @@ func TestCPUFingerprint_AWS_OverrideCompute(t *testing.T) { require.True(t, response.Detected) require.Equal(t, "2200", response.Attributes["cpu.frequency"]) require.Equal(t, "8", response.Attributes["cpu.numcores"]) - require.NotContains(t, response.Attributes, "cpu.totalcompute") + require.Equal(t, "99999", response.Attributes["cpu.totalcompute"]) require.Nil(t, response.Resources) // defaults in cpu fingerprinter require.Zero(t, response.NodeResources.Cpu) // defaults in cpu fingerprinter }