mirror of https://github.com/hashicorp/consul
api: finish up maintenance tests
parent
b6a0f2baae
commit
e088240c95
|
@ -1,6 +1,7 @@
|
||||||
package api
|
package api
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -282,7 +283,7 @@ func TestServiceMaintenance(t *testing.T) {
|
||||||
}
|
}
|
||||||
found := false
|
found := false
|
||||||
for _, check := range checks {
|
for _, check := range checks {
|
||||||
if check.ServiceName == "redis" {
|
if strings.Contains(check.CheckID, "maintenance") {
|
||||||
found = true
|
found = true
|
||||||
if check.Status != "critical" {
|
if check.Status != "critical" {
|
||||||
t.Fatalf("bad: %#v", checks)
|
t.Fatalf("bad: %#v", checks)
|
||||||
|
@ -304,7 +305,53 @@ func TestServiceMaintenance(t *testing.T) {
|
||||||
t.Fatalf("err: %s", err)
|
t.Fatalf("err: %s", err)
|
||||||
}
|
}
|
||||||
for _, check := range checks {
|
for _, check := range checks {
|
||||||
if check.ServiceID == "redis" {
|
if strings.Contains(check.CheckID, "maintenance") {
|
||||||
|
t.Fatalf("should have removed health check")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestNodeMaintenance(t *testing.T) {
|
||||||
|
c, s := makeClient(t)
|
||||||
|
defer s.stop()
|
||||||
|
|
||||||
|
agent := c.Agent()
|
||||||
|
|
||||||
|
// Enable maintenance mode
|
||||||
|
if err := agent.EnableNodeMaintenance(); err != nil {
|
||||||
|
t.Fatalf("err: %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check that a critical check was added
|
||||||
|
checks, err := agent.Checks()
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("err: %s", err)
|
||||||
|
}
|
||||||
|
found := false
|
||||||
|
for _, check := range checks {
|
||||||
|
if strings.Contains(check.CheckID, "maintenance") {
|
||||||
|
found = true
|
||||||
|
if check.Status != "critical" {
|
||||||
|
t.Fatalf("bad: %#v", checks)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if !found {
|
||||||
|
t.Fatalf("bad: %#v", checks)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Disable maintenance mode
|
||||||
|
if err := agent.DisableNodeMaintenance(); err != nil {
|
||||||
|
t.Fatalf("err: %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Ensure the check was removed
|
||||||
|
checks, err = agent.Checks()
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("err: %s", err)
|
||||||
|
}
|
||||||
|
for _, check := range checks {
|
||||||
|
if strings.Contains(check.CheckID, "maintenance") {
|
||||||
t.Fatalf("should have removed health check")
|
t.Fatalf("should have removed health check")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue