From 0f5e93edc81b276cbd8133bdf5b31f18e47ba7b0 Mon Sep 17 00:00:00 2001 From: Alex Dadgar Date: Fri, 23 Oct 2015 14:52:06 -0700 Subject: [PATCH] Check for environment variable updates for tasks --- nomad/mock/mock.go | 3 +++ scheduler/util.go | 5 ++++- scheduler/util_test.go | 6 ++++++ 3 files changed, 13 insertions(+), 1 deletion(-) diff --git a/nomad/mock/mock.go b/nomad/mock/mock.go index abfb16c8c2e..8aa3d5ba95a 100644 --- a/nomad/mock/mock.go +++ b/nomad/mock/mock.go @@ -80,6 +80,9 @@ func Job() *structs.Job { "command": "/bin/date", "args": "+%s", }, + Env: map[string]string{ + "FOO": "bar", + }, Resources: &structs.Resources{ CPU: 500, MemoryMB: 256, diff --git a/scheduler/util.go b/scheduler/util.go index 3525b2f8db1..43b4b0b0cfd 100644 --- a/scheduler/util.go +++ b/scheduler/util.go @@ -263,7 +263,7 @@ func shuffleNodes(nodes []*structs.Node) { } // tasksUpdated does a diff between task groups to see if the -// tasks, their drivers or config have updated. +// tasks, their drivers, environment variables or config have updated. func tasksUpdated(a, b *structs.TaskGroup) bool { // If the number of tasks do not match, clearly there is an update if len(a.Tasks) != len(b.Tasks) { @@ -282,6 +282,9 @@ func tasksUpdated(a, b *structs.TaskGroup) bool { if !reflect.DeepEqual(at.Config, bt.Config) { return true } + if !reflect.DeepEqual(at.Env, bt.Env) { + return true + } // Inspect the network to see if the dynamic ports are different if len(at.Resources.Networks) != len(bt.Resources.Networks) { diff --git a/scheduler/util_test.go b/scheduler/util_test.go index e1f455da092..15c0a472484 100644 --- a/scheduler/util_test.go +++ b/scheduler/util_test.go @@ -347,6 +347,12 @@ func TestTasksUpdated(t *testing.T) { if !tasksUpdated(j1.TaskGroups[0], j6.TaskGroups[0]) { t.Fatalf("bad") } + + j7 := mock.Job() + j7.TaskGroups[0].Tasks[0].Env["NEW_ENV"] = "NEW_VALUE" + if !tasksUpdated(j1.TaskGroups[0], j7.TaskGroups[0]) { + t.Fatalf("bad") + } } func TestEvictAndPlace_LimitLessThanAllocs(t *testing.T) {