2015-08-20 23:07:26 +00:00
|
|
|
package client
|
|
|
|
|
|
|
|
import (
|
2015-08-30 01:03:00 +00:00
|
|
|
"os"
|
2015-08-20 23:07:26 +00:00
|
|
|
"reflect"
|
|
|
|
"testing"
|
2015-08-21 00:49:04 +00:00
|
|
|
"time"
|
2015-08-23 21:47:51 +00:00
|
|
|
|
|
|
|
"github.com/hashicorp/nomad/nomad/mock"
|
|
|
|
"github.com/hashicorp/nomad/nomad/structs"
|
2015-08-20 23:07:26 +00:00
|
|
|
)
|
|
|
|
|
2015-08-23 21:47:51 +00:00
|
|
|
func TestDiffAllocs(t *testing.T) {
|
|
|
|
alloc1 := mock.Alloc() // Ignore
|
|
|
|
alloc2 := mock.Alloc() // Update
|
|
|
|
alloc2u := new(structs.Allocation)
|
|
|
|
*alloc2u = *alloc2
|
|
|
|
alloc2u.ModifyIndex += 1
|
|
|
|
alloc3 := mock.Alloc() // Remove
|
|
|
|
alloc4 := mock.Alloc() // Add
|
|
|
|
|
|
|
|
exist := []*structs.Allocation{
|
|
|
|
alloc1,
|
|
|
|
alloc2,
|
|
|
|
alloc3,
|
|
|
|
}
|
|
|
|
updated := []*structs.Allocation{
|
|
|
|
alloc1,
|
|
|
|
alloc2u,
|
|
|
|
alloc4,
|
|
|
|
}
|
|
|
|
|
|
|
|
result := diffAllocs(exist, updated)
|
|
|
|
|
|
|
|
if len(result.ignore) != 1 || result.ignore[0] != alloc1 {
|
|
|
|
t.Fatalf("Bad: %#v", result.ignore)
|
|
|
|
}
|
|
|
|
if len(result.added) != 1 || result.added[0] != alloc4 {
|
|
|
|
t.Fatalf("Bad: %#v", result.added)
|
|
|
|
}
|
|
|
|
if len(result.removed) != 1 || result.removed[0] != alloc3 {
|
|
|
|
t.Fatalf("Bad: %#v", result.removed)
|
|
|
|
}
|
|
|
|
if len(result.updated) != 1 {
|
|
|
|
t.Fatalf("Bad: %#v", result.updated)
|
|
|
|
}
|
|
|
|
if result.updated[0].exist != alloc2 || result.updated[0].updated != alloc2u {
|
|
|
|
t.Fatalf("Bad: %#v", result.updated)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-08-21 00:49:04 +00:00
|
|
|
func TestRandomStagger(t *testing.T) {
|
|
|
|
intv := time.Minute
|
|
|
|
for i := 0; i < 10; i++ {
|
|
|
|
stagger := randomStagger(intv)
|
|
|
|
if stagger < 0 || stagger >= intv {
|
|
|
|
t.Fatalf("Bad: %v", stagger)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-08-20 23:07:26 +00:00
|
|
|
func TestShuffleStrings(t *testing.T) {
|
|
|
|
// Generate input
|
|
|
|
inp := make([]string, 10)
|
|
|
|
for idx := range inp {
|
2015-09-07 22:23:03 +00:00
|
|
|
inp[idx] = structs.GenerateUUID()
|
2015-08-20 23:07:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Copy the input
|
|
|
|
orig := make([]string, len(inp))
|
|
|
|
copy(orig, inp)
|
|
|
|
|
|
|
|
// Shuffle
|
|
|
|
shuffleStrings(inp)
|
|
|
|
|
|
|
|
// Ensure order is not the same
|
|
|
|
if reflect.DeepEqual(inp, orig) {
|
|
|
|
t.Fatalf("shuffle failed")
|
|
|
|
}
|
|
|
|
}
|
2015-08-30 01:03:00 +00:00
|
|
|
|
|
|
|
func TestPersistRestoreState(t *testing.T) {
|
|
|
|
type stateTest struct {
|
|
|
|
Foo int
|
|
|
|
Bar string
|
|
|
|
Baz bool
|
|
|
|
}
|
|
|
|
state := stateTest{
|
|
|
|
Foo: 42,
|
|
|
|
Bar: "the quick brown fox",
|
|
|
|
Baz: true,
|
|
|
|
}
|
|
|
|
defer os.Remove("test-persist")
|
|
|
|
|
|
|
|
err := persistState("test-persist", &state)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
var out stateTest
|
|
|
|
err = restoreState("test-persist", &out)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if !reflect.DeepEqual(state, out) {
|
|
|
|
t.Fatalf("bad: %#v %#v", state, out)
|
|
|
|
}
|
|
|
|
}
|