mirror of
https://github.com/kemko/nomad.git
synced 2026-01-01 16:05:42 +03:00
* core: plumbing to support numa aware scheduling * core: apply node resources compatibility upon fsm rstore Handle the case where an upgraded server dequeus an evaluation before a client triggers a new fingerprint - which would be needed to cause the compatibility fix to run. By running the compat fix on restore the server will immediately have the compatible pseudo topology to use. * lint: learn how to spell pseudo
52 lines
1.3 KiB
Go
52 lines
1.3 KiB
Go
// Copyright (c) HashiCorp, Inc.
|
|
// SPDX-License-Identifier: BUSL-1.1
|
|
|
|
package fingerprint
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/hashicorp/nomad/ci"
|
|
"github.com/hashicorp/nomad/client/config"
|
|
"github.com/hashicorp/nomad/helper/testlog"
|
|
"github.com/hashicorp/nomad/nomad/structs"
|
|
"github.com/shoenig/test/must"
|
|
)
|
|
|
|
func TestMemoryFingerprint(t *testing.T) {
|
|
ci.Parallel(t)
|
|
|
|
f := NewMemoryFingerprint(testlog.HCLogger(t))
|
|
node := &structs.Node{
|
|
Attributes: make(map[string]string),
|
|
}
|
|
|
|
request := &FingerprintRequest{Config: &config.Config{}, Node: node}
|
|
var response FingerprintResponse
|
|
err := f.Fingerprint(request, &response)
|
|
must.NoError(t, err)
|
|
|
|
assertNodeAttributeContains(t, response.Attributes, "memory.totalbytes")
|
|
must.Positive(t, response.NodeResources.Memory.MemoryMB)
|
|
}
|
|
|
|
func TestMemoryFingerprint_Override(t *testing.T) {
|
|
ci.Parallel(t)
|
|
|
|
f := NewMemoryFingerprint(testlog.HCLogger(t))
|
|
node := &structs.Node{
|
|
Attributes: make(map[string]string),
|
|
}
|
|
|
|
memoryMB := 15000
|
|
request := &FingerprintRequest{Config: &config.Config{MemoryMB: memoryMB}, Node: node}
|
|
var response FingerprintResponse
|
|
err := f.Fingerprint(request, &response)
|
|
if err != nil {
|
|
t.Fatalf("err: %v", err)
|
|
}
|
|
|
|
assertNodeAttributeContains(t, response.Attributes, "memory.totalbytes")
|
|
must.Eq(t, response.NodeResources.Memory.MemoryMB, int64(memoryMB))
|
|
}
|