diff --git a/heartbeat/beater/heartbeat.go b/heartbeat/beater/heartbeat.go index 48a89a923940..34268aee431c 100644 --- a/heartbeat/beater/heartbeat.go +++ b/heartbeat/beater/heartbeat.go @@ -18,15 +18,13 @@ package beater import ( + "errors" "fmt" "time" - "github.com/pkg/errors" - "github.com/elastic/beats/v7/heartbeat/config" "github.com/elastic/beats/v7/heartbeat/hbregistry" "github.com/elastic/beats/v7/heartbeat/monitors" - "github.com/elastic/beats/v7/heartbeat/monitors/stdfields" "github.com/elastic/beats/v7/heartbeat/scheduler" "github.com/elastic/beats/v7/libbeat/autodiscover" "github.com/elastic/beats/v7/libbeat/beat" @@ -132,11 +130,12 @@ func (bt *Heartbeat) RunStaticMonitors(b *beat.Beat) (stop func(), err error) { for _, cfg := range bt.config.Monitors { created, err := factory.Create(b.Publisher, cfg) if err != nil { - if err == stdfields.ErrPluginDisabled { + if errors.Is(err, monitors.ErrMonitorDisabled) { + logp.Info("skipping disabled monitor: %s", err) continue // don't stop loading monitors just because they're disabled } - return nil, errors.Wrap(err, "could not create monitor") + return nil, fmt.Errorf("could not create monitor: %w", err) } created.Start() @@ -163,7 +162,7 @@ func (bt *Heartbeat) RunCentralMgmtMonitors(b *beat.Beat) { func (bt *Heartbeat) RunReloadableMonitors(b *beat.Beat) (err error) { // Check monitor configs if err := bt.monitorReloader.Check(bt.dynamicFactory); err != nil { - logp.Error(errors.Wrap(err, "error loading reloadable monitors")) + logp.Error(fmt.Errorf("error loading reloadable monitors: %w", err)) } // Execute the monitor diff --git a/heartbeat/monitors/monitor.go b/heartbeat/monitors/monitor.go index 4003cacdf422..caac7b8aa0cf 100644 --- a/heartbeat/monitors/monitor.go +++ b/heartbeat/monitors/monitor.go @@ -37,6 +37,9 @@ import ( "github.com/elastic/beats/v7/libbeat/logp" ) +// ErrMonitorDisabled is returned when the monitor plugin is marked as disabled. +var ErrMonitorDisabled = errors.New("monitor not loaded, plugin is disabled") + // Monitor represents a configured recurring monitoring configuredJob loaded from a config file. Starting it // will cause it to run with the given scheduler until Stop() is called. type Monitor struct { @@ -126,6 +129,10 @@ func newMonitorUnsafe( return nil, err } + if !config.Enabled() { + return nil, fmt.Errorf("monitor '%s' with id '%s' skipped: %w", standardFields.Name, standardFields.ID, ErrMonitorDisabled) + } + pluginFactory, found := registrar.Get(standardFields.Type) if !found { return nil, fmt.Errorf("monitor type %v does not exist, valid types are %v", standardFields.Type, registrar.MonitorNames()) diff --git a/heartbeat/monitors/stdfields/stdfields.go b/heartbeat/monitors/stdfields/stdfields.go index 26b28628fc35..f09161c2adf0 100644 --- a/heartbeat/monitors/stdfields/stdfields.go +++ b/heartbeat/monitors/stdfields/stdfields.go @@ -26,9 +26,6 @@ import ( "github.com/elastic/beats/v7/libbeat/common" ) -// ErrPluginDisabled is returned when the monitor plugin is marked as disabled. -var ErrPluginDisabled = errors.New("monitor not loaded, plugin is disabled") - type ServiceFields struct { Name string `config:"name"` } @@ -60,9 +57,5 @@ func ConfigToStdMonitorFields(config *common.Config) (StdMonitorFields, error) { } } - if !mpi.Enabled { - return mpi, ErrPluginDisabled - } - return mpi, nil } diff --git a/heartbeat/tests/system/config/heartbeat.yml.j2 b/heartbeat/tests/system/config/heartbeat.yml.j2 index 40990b393583..0555c5729cba 100644 --- a/heartbeat/tests/system/config/heartbeat.yml.j2 +++ b/heartbeat/tests/system/config/heartbeat.yml.j2 @@ -8,6 +8,10 @@ heartbeat.monitors: timeout: {{monitor.timeout}} {% endif -%} + {%- if monitor.enabled is defined %} + enabled: {{monitor.enabled}} + {% endif -%} + {%- if monitor.tags is defined %} tags: {% for tag in monitor.tags -%} diff --git a/heartbeat/tests/system/test_base.py b/heartbeat/tests/system/test_base.py index e0361761e041..b65ccea587df 100644 --- a/heartbeat/tests/system/test_base.py +++ b/heartbeat/tests/system/test_base.py @@ -5,6 +5,7 @@ from elasticsearch import Elasticsearch from beat.beat import INTEGRATION_TESTS from beat import common_tests +from time import sleep class Test(BaseTest, common_tests.TestExportsMixin): @@ -53,7 +54,7 @@ def test_disabled(self): ) heartbeat_proc = self.start_beat() - self.wait_until(lambda: self.log_contains("heartbeat is running")) + self.wait_until(lambda: self.log_contains("skipping disabled monitor")) heartbeat_proc.check_kill_and_wait() def test_fields_under_root(self):