mirror of https://github.com/hashicorp/consul
watch: extract makeWatchPlan to facilitate testing
There is a bug in here now that slices in opaque config are unsliced. But to test that bug fix we need a function that can be easily tested.pull/8290/head
parent
2f721504a7
commit
653c938edc
|
@ -1336,44 +1336,10 @@ func (a *Agent) reloadWatches(cfg *config.RuntimeConfig) error {
|
|||
}
|
||||
}
|
||||
|
||||
// Parse the watches, excluding 'handler' and 'args'
|
||||
wp, err := watch.ParseExempt(params, []string{"handler", "args"})
|
||||
wp, err := makeWatchPlan(a.logger, params)
|
||||
if err != nil {
|
||||
return fmt.Errorf("Failed to parse watch (%#v): %v", params, err)
|
||||
return err
|
||||
}
|
||||
|
||||
// Get the handler and subprocess arguments
|
||||
handler, hasHandler := wp.Exempt["handler"]
|
||||
args, hasArgs := wp.Exempt["args"]
|
||||
if hasHandler {
|
||||
a.logger.Warn("The 'handler' field in watches has been deprecated " +
|
||||
"and replaced with the 'args' field. See https://www.consul.io/docs/agent/watches.html")
|
||||
}
|
||||
if _, ok := handler.(string); hasHandler && !ok {
|
||||
return fmt.Errorf("Watch handler must be a string")
|
||||
}
|
||||
if raw, ok := args.([]interface{}); hasArgs && ok {
|
||||
var parsed []string
|
||||
for _, arg := range raw {
|
||||
v, ok := arg.(string)
|
||||
if !ok {
|
||||
return fmt.Errorf("Watch args must be a list of strings")
|
||||
}
|
||||
|
||||
parsed = append(parsed, v)
|
||||
}
|
||||
wp.Exempt["args"] = parsed
|
||||
} else if hasArgs && !ok {
|
||||
return fmt.Errorf("Watch args must be a list of strings")
|
||||
}
|
||||
if hasHandler && hasArgs || hasHandler && wp.HandlerType == "http" || hasArgs && wp.HandlerType == "http" {
|
||||
return fmt.Errorf("Only one watch handler allowed")
|
||||
}
|
||||
if !hasHandler && !hasArgs && wp.HandlerType != "http" {
|
||||
return fmt.Errorf("Must define a watch handler")
|
||||
}
|
||||
|
||||
// Store the watch plan
|
||||
watchPlans = append(watchPlans, wp)
|
||||
}
|
||||
|
||||
|
|
|
@ -184,3 +184,44 @@ func makeHTTPWatchHandler(logger hclog.Logger, config *watch.HttpHandlerConfig)
|
|||
}
|
||||
return fn
|
||||
}
|
||||
|
||||
// TODO: return a fully constructed watch.Plan with a Plan.Handler, so that Except
|
||||
// can be ignored by the caller.
|
||||
func makeWatchPlan(logger hclog.Logger, params map[string]interface{}) (*watch.Plan, error) {
|
||||
wp, err := watch.ParseExempt(params, []string{"handler", "args"})
|
||||
if err != nil {
|
||||
return nil, fmt.Errorf("Failed to parse watch (%#v): %v", params, err)
|
||||
}
|
||||
|
||||
// Get the handler and subprocess arguments
|
||||
handler, hasHandler := wp.Exempt["handler"]
|
||||
args, hasArgs := wp.Exempt["args"]
|
||||
if hasHandler {
|
||||
logger.Warn("The 'handler' field in watches has been deprecated " +
|
||||
"and replaced with the 'args' field. See https://www.consul.io/docs/agent/watches.html")
|
||||
}
|
||||
if _, ok := handler.(string); hasHandler && !ok {
|
||||
return nil, fmt.Errorf("Watch handler must be a string")
|
||||
}
|
||||
if raw, ok := args.([]interface{}); hasArgs && ok {
|
||||
var parsed []string
|
||||
for _, arg := range raw {
|
||||
v, ok := arg.(string)
|
||||
if !ok {
|
||||
return nil, fmt.Errorf("Watch args must be a list of strings")
|
||||
}
|
||||
|
||||
parsed = append(parsed, v)
|
||||
}
|
||||
wp.Exempt["args"] = parsed
|
||||
} else if hasArgs && !ok {
|
||||
return nil, fmt.Errorf("Watch args must be a list of strings")
|
||||
}
|
||||
if hasHandler && hasArgs || hasHandler && wp.HandlerType == "http" || hasArgs && wp.HandlerType == "http" {
|
||||
return nil, fmt.Errorf("Only one watch handler allowed")
|
||||
}
|
||||
if !hasHandler && !hasArgs && wp.HandlerType != "http" {
|
||||
return nil, fmt.Errorf("Must define a watch handler")
|
||||
}
|
||||
return wp, nil
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue