agent: test agent service maintenance mode

pull/606/head
Ryan Uber 2015-01-15 00:25:36 -08:00
parent 2973cd9131
commit 3fbb2be6c0
2 changed files with 50 additions and 0 deletions

View File

@ -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() {

View File

@ -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")
}
}
}