mirror of https://github.com/hashicorp/consul
agent: test agent service maintenance mode
parent
2973cd9131
commit
3fbb2be6c0
|
@ -999,6 +999,8 @@ func (a *Agent) unloadChecks() error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// EnableServiceMaintenance will register a false health check against the given
|
||||||
|
// service ID with critical status. This will exclude the service from queries.
|
||||||
func (a *Agent) EnableServiceMaintenance(serviceID string) error {
|
func (a *Agent) EnableServiceMaintenance(serviceID string) error {
|
||||||
var service *structs.NodeService
|
var service *structs.NodeService
|
||||||
for _, svc := range a.state.Services() {
|
for _, svc := range a.state.Services() {
|
||||||
|
@ -1034,6 +1036,8 @@ func (a *Agent) EnableServiceMaintenance(serviceID string) error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// DisableServiceMaintenance will deregister the fake maintenance mode check
|
||||||
|
// if the service has been marked as in maintenance.
|
||||||
func (a *Agent) DisableServiceMaintenance(serviceID string) error {
|
func (a *Agent) DisableServiceMaintenance(serviceID string) error {
|
||||||
var service *structs.NodeService
|
var service *structs.NodeService
|
||||||
for _, svc := range a.state.Services() {
|
for _, svc := range a.state.Services() {
|
||||||
|
|
|
@ -781,3 +781,49 @@ func TestAgent_unloadServices(t *testing.T) {
|
||||||
t.Fatalf("consul service should not be removed")
|
t.Fatalf("consul service should not be removed")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestAgent_MaintenanceMode(t *testing.T) {
|
||||||
|
config := nextConfig()
|
||||||
|
dir, agent := makeAgent(t, config)
|
||||||
|
defer os.RemoveAll(dir)
|
||||||
|
defer agent.Shutdown()
|
||||||
|
|
||||||
|
svc := &structs.NodeService{
|
||||||
|
ID: "redis",
|
||||||
|
Service: "redis",
|
||||||
|
Tags: []string{"foo"},
|
||||||
|
Port: 8000,
|
||||||
|
}
|
||||||
|
|
||||||
|
// Register the service
|
||||||
|
if err := agent.AddService(svc, nil, false); err != nil {
|
||||||
|
t.Fatalf("err: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Enter maintenance mode for the service
|
||||||
|
if err := agent.EnableServiceMaintenance("redis"); err != nil {
|
||||||
|
t.Fatalf("err: %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Make sure the critical health check was added
|
||||||
|
for _, check := range agent.state.Checks() {
|
||||||
|
if check.CheckID == maintCheckID {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Didn't find the check
|
||||||
|
t.Fatalf("should have registered critical maintenance check")
|
||||||
|
|
||||||
|
// Leave maintenance mode
|
||||||
|
if err := agent.DisableServiceMaintenance("redis"); err != nil {
|
||||||
|
t.Fatalf("err: %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Ensure the check was deregistered
|
||||||
|
for _, check := range agent.state.Checks() {
|
||||||
|
if check.CheckID == maintCheckID {
|
||||||
|
t.Fatalf("should have deregistered maintenance check")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue