[Monitoring] Remove unused code in Collectors (elastic/elasticsearch#4240)
This commit removes some unnecessary code: collectors do not need to extend AbstractLifecycleComponent and do not need to be started/stopped. The extra interface Collector is removed and AbstractCollector renamed to Collector. Original commit: elastic/x-pack-elasticsearch@75893d66e3
This commit is contained in:
parent
7f17896927
commit
f1a4a2fb73
|
@ -120,10 +120,6 @@ public class AgentService extends AbstractLifecycleComponent {
|
||||||
@Override
|
@Override
|
||||||
protected void doStart() {
|
protected void doStart() {
|
||||||
logger.debug("monitoring service started");
|
logger.debug("monitoring service started");
|
||||||
|
|
||||||
for (Collector collector : collectors) {
|
|
||||||
collector.start();
|
|
||||||
}
|
|
||||||
exporters.start();
|
exporters.start();
|
||||||
applyIntervalSettings();
|
applyIntervalSettings();
|
||||||
}
|
}
|
||||||
|
@ -140,19 +136,11 @@ public class AgentService extends AbstractLifecycleComponent {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (Collector collector : collectors) {
|
|
||||||
collector.stop();
|
|
||||||
}
|
|
||||||
|
|
||||||
exporters.stop();
|
exporters.stop();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void doClose() {
|
protected void doClose() {
|
||||||
for (Collector collector : collectors) {
|
|
||||||
collector.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
for (Exporter exporter : exporters) {
|
for (Exporter exporter : exporters) {
|
||||||
try {
|
try {
|
||||||
exporter.close();
|
exporter.close();
|
||||||
|
|
|
@ -1,130 +0,0 @@
|
||||||
/*
|
|
||||||
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
|
|
||||||
* or more contributor license agreements. Licensed under the Elastic License;
|
|
||||||
* you may not use this file except in compliance with the Elastic License.
|
|
||||||
*/
|
|
||||||
package org.elasticsearch.xpack.monitoring.collector;
|
|
||||||
|
|
||||||
import org.apache.logging.log4j.message.ParameterizedMessage;
|
|
||||||
import org.apache.logging.log4j.util.Supplier;
|
|
||||||
import org.elasticsearch.ElasticsearchTimeoutException;
|
|
||||||
import org.elasticsearch.Version;
|
|
||||||
import org.elasticsearch.cluster.node.DiscoveryNode;
|
|
||||||
import org.elasticsearch.cluster.service.ClusterService;
|
|
||||||
import org.elasticsearch.common.component.AbstractLifecycleComponent;
|
|
||||||
import org.elasticsearch.common.settings.Settings;
|
|
||||||
import org.elasticsearch.license.XPackLicenseState;
|
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoredSystem;
|
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
|
||||||
|
|
||||||
import java.util.Collection;
|
|
||||||
|
|
||||||
public abstract class AbstractCollector extends AbstractLifecycleComponent implements Collector {
|
|
||||||
|
|
||||||
private final String name;
|
|
||||||
|
|
||||||
protected final ClusterService clusterService;
|
|
||||||
protected final MonitoringSettings monitoringSettings;
|
|
||||||
protected final XPackLicenseState licenseState;
|
|
||||||
|
|
||||||
public AbstractCollector(Settings settings, String name, ClusterService clusterService,
|
|
||||||
MonitoringSettings monitoringSettings, XPackLicenseState licenseState) {
|
|
||||||
super(settings);
|
|
||||||
this.name = name;
|
|
||||||
this.clusterService = clusterService;
|
|
||||||
this.monitoringSettings = monitoringSettings;
|
|
||||||
this.licenseState = licenseState;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String name() {
|
|
||||||
return name;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return name;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void start() {
|
|
||||||
logger.debug("starting collector [{}]", name());
|
|
||||||
super.start();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void doStart() {
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Indicates if the current collector is allowed to collect data
|
|
||||||
*/
|
|
||||||
protected boolean shouldCollect() {
|
|
||||||
if (licenseState.isMonitoringAllowed() == false) {
|
|
||||||
logger.trace("collector [{}] can not collect data due to invalid license", name());
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected boolean isLocalNodeMaster() {
|
|
||||||
return clusterService.state().nodes().isLocalNodeElectedMaster();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Collection<MonitoringDoc> collect() {
|
|
||||||
try {
|
|
||||||
if (shouldCollect()) {
|
|
||||||
logger.trace("collector [{}] - collecting data...", name());
|
|
||||||
return doCollect();
|
|
||||||
}
|
|
||||||
} catch (ElasticsearchTimeoutException e) {
|
|
||||||
logger.error("collector [{}] timed out when collecting data", name());
|
|
||||||
} catch (Exception e) {
|
|
||||||
logger.error((Supplier<?>) () -> new ParameterizedMessage("collector [{}] - failed collecting data", name()), e);
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected abstract Collection<MonitoringDoc> doCollect() throws Exception;
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void stop() {
|
|
||||||
logger.debug("stopping collector [{}]", name());
|
|
||||||
super.stop();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void doStop() {
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void close() {
|
|
||||||
logger.trace("closing collector [{}]", name());
|
|
||||||
super.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void doClose() {
|
|
||||||
}
|
|
||||||
|
|
||||||
protected String clusterUUID() {
|
|
||||||
return clusterService.state().metaData().clusterUUID();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
protected DiscoveryNode localNode() {
|
|
||||||
return clusterService.localNode();
|
|
||||||
}
|
|
||||||
|
|
||||||
protected String monitoringId() {
|
|
||||||
// Collectors always collects data for Elasticsearch
|
|
||||||
return MonitoredSystem.ES.getSystem();
|
|
||||||
}
|
|
||||||
|
|
||||||
protected String monitoringVersion() {
|
|
||||||
// Collectors always collects data for the current version of Elasticsearch
|
|
||||||
return Version.CURRENT.toString();
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -5,14 +5,96 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.xpack.monitoring.collector;
|
package org.elasticsearch.xpack.monitoring.collector;
|
||||||
|
|
||||||
import org.elasticsearch.common.component.LifecycleComponent;
|
import org.apache.logging.log4j.message.ParameterizedMessage;
|
||||||
|
import org.apache.logging.log4j.util.Supplier;
|
||||||
|
import org.elasticsearch.ElasticsearchTimeoutException;
|
||||||
|
import org.elasticsearch.Version;
|
||||||
|
import org.elasticsearch.cluster.node.DiscoveryNode;
|
||||||
|
import org.elasticsearch.cluster.service.ClusterService;
|
||||||
|
import org.elasticsearch.common.component.AbstractComponent;
|
||||||
|
import org.elasticsearch.common.settings.Settings;
|
||||||
|
import org.elasticsearch.license.XPackLicenseState;
|
||||||
|
import org.elasticsearch.xpack.monitoring.MonitoredSystem;
|
||||||
|
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
||||||
|
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
|
|
||||||
public interface Collector extends LifecycleComponent {
|
/**
|
||||||
|
* {@link Collector} are used to collect monitoring data about the cluster, nodes and indices.
|
||||||
|
*/
|
||||||
|
public abstract class Collector extends AbstractComponent {
|
||||||
|
|
||||||
String name();
|
private final String name;
|
||||||
|
|
||||||
Collection<MonitoringDoc> collect();
|
protected final ClusterService clusterService;
|
||||||
|
protected final MonitoringSettings monitoringSettings;
|
||||||
|
protected final XPackLicenseState licenseState;
|
||||||
|
|
||||||
|
public Collector(Settings settings, String name, ClusterService clusterService,
|
||||||
|
MonitoringSettings monitoringSettings, XPackLicenseState licenseState) {
|
||||||
|
super(settings);
|
||||||
|
this.name = name;
|
||||||
|
this.clusterService = clusterService;
|
||||||
|
this.monitoringSettings = monitoringSettings;
|
||||||
|
this.licenseState = licenseState;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String name() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return name();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indicates if the current collector is allowed to collect data
|
||||||
|
*/
|
||||||
|
protected boolean shouldCollect() {
|
||||||
|
if (licenseState.isMonitoringAllowed() == false) {
|
||||||
|
logger.trace("collector [{}] can not collect data due to invalid license", name());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected boolean isLocalNodeMaster() {
|
||||||
|
return clusterService.state().nodes().isLocalNodeElectedMaster();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Collection<MonitoringDoc> collect() {
|
||||||
|
try {
|
||||||
|
if (shouldCollect()) {
|
||||||
|
logger.trace("collector [{}] - collecting data...", name());
|
||||||
|
return doCollect();
|
||||||
|
}
|
||||||
|
} catch (ElasticsearchTimeoutException e) {
|
||||||
|
logger.error((Supplier<?>) () -> new ParameterizedMessage("collector [{}] timed out when collecting data", name()));
|
||||||
|
} catch (Exception e) {
|
||||||
|
logger.error((Supplier<?>) () -> new ParameterizedMessage("collector [{}] failed to collect data", name()), e);
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected abstract Collection<MonitoringDoc> doCollect() throws Exception;
|
||||||
|
|
||||||
|
protected String clusterUUID() {
|
||||||
|
return clusterService.state().metaData().clusterUUID();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected DiscoveryNode localNode() {
|
||||||
|
return clusterService.localNode();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected static String monitoringId() {
|
||||||
|
// Collectors always collects data for Elasticsearch
|
||||||
|
return MonitoredSystem.ES.getSystem();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected static String monitoringVersion() {
|
||||||
|
// Collectors always collects data for the current version of Elasticsearch
|
||||||
|
return Version.CURRENT.toString();
|
||||||
|
}
|
||||||
}
|
}
|
|
@ -19,7 +19,7 @@ import org.elasticsearch.cluster.service.ClusterService;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.license.XPackLicenseState;
|
import org.elasticsearch.license.XPackLicenseState;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
||||||
import org.elasticsearch.xpack.monitoring.collector.AbstractCollector;
|
import org.elasticsearch.xpack.monitoring.collector.Collector;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
||||||
import org.elasticsearch.xpack.security.InternalClient;
|
import org.elasticsearch.xpack.security.InternalClient;
|
||||||
|
|
||||||
|
@ -29,7 +29,7 @@ import org.elasticsearch.xpack.security.InternalClient;
|
||||||
* This collector runs on the master node only and collects {@link ClusterStateMonitoringDoc} document
|
* This collector runs on the master node only and collects {@link ClusterStateMonitoringDoc} document
|
||||||
* at a given frequency.
|
* at a given frequency.
|
||||||
*/
|
*/
|
||||||
public class ClusterStateCollector extends AbstractCollector {
|
public class ClusterStateCollector extends Collector {
|
||||||
|
|
||||||
public static final String NAME = "cluster-state-collector";
|
public static final String NAME = "cluster-state-collector";
|
||||||
|
|
||||||
|
|
|
@ -21,7 +21,7 @@ import org.elasticsearch.license.XPackLicenseState;
|
||||||
import org.elasticsearch.xpack.XPackFeatureSet;
|
import org.elasticsearch.xpack.XPackFeatureSet;
|
||||||
import org.elasticsearch.xpack.action.XPackUsageRequestBuilder;
|
import org.elasticsearch.xpack.action.XPackUsageRequestBuilder;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
||||||
import org.elasticsearch.xpack.monitoring.collector.AbstractCollector;
|
import org.elasticsearch.xpack.monitoring.collector.Collector;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
||||||
import org.elasticsearch.xpack.security.InternalClient;
|
import org.elasticsearch.xpack.security.InternalClient;
|
||||||
|
|
||||||
|
@ -40,7 +40,7 @@ import java.util.List;
|
||||||
* document; the cluster stats are also indexed in the timestamped index in a
|
* document; the cluster stats are also indexed in the timestamped index in a
|
||||||
* "cluster_stats" document.
|
* "cluster_stats" document.
|
||||||
*/
|
*/
|
||||||
public class ClusterStatsCollector extends AbstractCollector {
|
public class ClusterStatsCollector extends Collector {
|
||||||
|
|
||||||
public static final String NAME = "cluster-stats-collector";
|
public static final String NAME = "cluster-stats-collector";
|
||||||
|
|
||||||
|
|
|
@ -12,7 +12,7 @@ import org.elasticsearch.cluster.service.ClusterService;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.license.XPackLicenseState;
|
import org.elasticsearch.license.XPackLicenseState;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
||||||
import org.elasticsearch.xpack.monitoring.collector.AbstractCollector;
|
import org.elasticsearch.xpack.monitoring.collector.Collector;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
||||||
import org.elasticsearch.xpack.security.InternalClient;
|
import org.elasticsearch.xpack.security.InternalClient;
|
||||||
|
|
||||||
|
@ -27,7 +27,7 @@ import java.util.List;
|
||||||
* This collector runs on the master node only and collects a {@link IndexRecoveryMonitoringDoc} document
|
* This collector runs on the master node only and collects a {@link IndexRecoveryMonitoringDoc} document
|
||||||
* for every index that has on-going shard recoveries.
|
* for every index that has on-going shard recoveries.
|
||||||
*/
|
*/
|
||||||
public class IndexRecoveryCollector extends AbstractCollector {
|
public class IndexRecoveryCollector extends Collector {
|
||||||
|
|
||||||
public static final String NAME = "index-recovery-collector";
|
public static final String NAME = "index-recovery-collector";
|
||||||
|
|
||||||
|
|
|
@ -14,7 +14,7 @@ import org.elasticsearch.cluster.service.ClusterService;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.license.XPackLicenseState;
|
import org.elasticsearch.license.XPackLicenseState;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
||||||
import org.elasticsearch.xpack.monitoring.collector.AbstractCollector;
|
import org.elasticsearch.xpack.monitoring.collector.Collector;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
||||||
import org.elasticsearch.xpack.security.InternalClient;
|
import org.elasticsearch.xpack.security.InternalClient;
|
||||||
|
|
||||||
|
@ -29,7 +29,7 @@ import java.util.List;
|
||||||
* This collector runs on the master node only and collect a {@link IndexStatsMonitoringDoc} document
|
* This collector runs on the master node only and collect a {@link IndexStatsMonitoringDoc} document
|
||||||
* for each existing index in the cluster.
|
* for each existing index in the cluster.
|
||||||
*/
|
*/
|
||||||
public class IndexStatsCollector extends AbstractCollector {
|
public class IndexStatsCollector extends Collector {
|
||||||
|
|
||||||
public static final String NAME = "index-stats-collector";
|
public static final String NAME = "index-stats-collector";
|
||||||
|
|
||||||
|
|
|
@ -12,7 +12,7 @@ import org.elasticsearch.cluster.service.ClusterService;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.license.XPackLicenseState;
|
import org.elasticsearch.license.XPackLicenseState;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
||||||
import org.elasticsearch.xpack.monitoring.collector.AbstractCollector;
|
import org.elasticsearch.xpack.monitoring.collector.Collector;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
||||||
import org.elasticsearch.xpack.security.InternalClient;
|
import org.elasticsearch.xpack.security.InternalClient;
|
||||||
|
|
||||||
|
@ -24,7 +24,7 @@ import java.util.Collections;
|
||||||
* <p>
|
* <p>
|
||||||
* This collector runs on the master node only and collect one {@link IndicesStatsMonitoringDoc} document.
|
* This collector runs on the master node only and collect one {@link IndicesStatsMonitoringDoc} document.
|
||||||
*/
|
*/
|
||||||
public class IndicesStatsCollector extends AbstractCollector {
|
public class IndicesStatsCollector extends Collector {
|
||||||
|
|
||||||
public static final String NAME = "indices-stats-collector";
|
public static final String NAME = "indices-stats-collector";
|
||||||
|
|
||||||
|
|
|
@ -19,7 +19,7 @@ import org.elasticsearch.cluster.service.ClusterService;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.license.XPackLicenseState;
|
import org.elasticsearch.license.XPackLicenseState;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
||||||
import org.elasticsearch.xpack.monitoring.collector.AbstractCollector;
|
import org.elasticsearch.xpack.monitoring.collector.Collector;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
||||||
import org.elasticsearch.xpack.security.InternalClient;
|
import org.elasticsearch.xpack.security.InternalClient;
|
||||||
|
|
||||||
|
@ -29,7 +29,7 @@ import org.elasticsearch.xpack.security.InternalClient;
|
||||||
* This collector runs on every non-client node and collect
|
* This collector runs on every non-client node and collect
|
||||||
* a {@link NodeStatsMonitoringDoc} document for each node of the cluster.
|
* a {@link NodeStatsMonitoringDoc} document for each node of the cluster.
|
||||||
*/
|
*/
|
||||||
public class NodeStatsCollector extends AbstractCollector {
|
public class NodeStatsCollector extends Collector {
|
||||||
|
|
||||||
public static final String NAME = "node-stats-collector";
|
public static final String NAME = "node-stats-collector";
|
||||||
|
|
||||||
|
|
|
@ -20,7 +20,7 @@ import org.elasticsearch.common.regex.Regex;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.license.XPackLicenseState;
|
import org.elasticsearch.license.XPackLicenseState;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
||||||
import org.elasticsearch.xpack.monitoring.collector.AbstractCollector;
|
import org.elasticsearch.xpack.monitoring.collector.Collector;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -29,7 +29,7 @@ import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
||||||
* This collector runs on the master node only and collects the {@link ShardMonitoringDoc} documents
|
* This collector runs on the master node only and collects the {@link ShardMonitoringDoc} documents
|
||||||
* for every index shard.
|
* for every index shard.
|
||||||
*/
|
*/
|
||||||
public class ShardsCollector extends AbstractCollector {
|
public class ShardsCollector extends Collector {
|
||||||
|
|
||||||
public static final String NAME = "shards-collector";
|
public static final String NAME = "shards-collector";
|
||||||
|
|
||||||
|
|
|
@ -35,7 +35,7 @@ public abstract class AbstractCollectorTestCase extends MonitoringIntegTestCase
|
||||||
return internalCluster().getInstance(InternalClient.class, nodeId);
|
return internalCluster().getInstance(InternalClient.class, nodeId);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void assertCanCollect(AbstractCollector collector) {
|
protected void assertCanCollect(Collector collector) {
|
||||||
assertNotNull(collector);
|
assertNotNull(collector);
|
||||||
assertTrue("collector [" + collector.name() + "] should be able to collect data", collector.shouldCollect());
|
assertTrue("collector [" + collector.name() + "] should be able to collect data", collector.shouldCollect());
|
||||||
Collection results = collector.collect();
|
Collection results = collector.collect();
|
||||||
|
@ -43,15 +43,12 @@ public abstract class AbstractCollectorTestCase extends MonitoringIntegTestCase
|
||||||
}
|
}
|
||||||
|
|
||||||
public void waitForNoBlocksOnNodes() throws Exception {
|
public void waitForNoBlocksOnNodes() throws Exception {
|
||||||
assertBusy(new Runnable() {
|
assertBusy(() -> {
|
||||||
@Override
|
for (String nodeId : internalCluster().getNodeNames()) {
|
||||||
public void run() {
|
try {
|
||||||
for (String nodeId : internalCluster().getNodeNames()) {
|
waitForNoBlocksOnNode(nodeId);
|
||||||
try {
|
} catch (Exception e) {
|
||||||
waitForNoBlocksOnNode(nodeId);
|
fail("failed to wait for no blocks on node [" + nodeId + "]: " + e.getMessage());
|
||||||
} catch (Exception e) {
|
|
||||||
fail("failed to wait for no blocks on node [" + nodeId + "]: " + e.getMessage());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
|
@ -15,7 +15,7 @@ import org.elasticsearch.license.LicenseService;
|
||||||
import org.elasticsearch.license.XPackLicenseState;
|
import org.elasticsearch.license.XPackLicenseState;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoredSystem;
|
import org.elasticsearch.xpack.monitoring.MonitoredSystem;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
||||||
import org.elasticsearch.xpack.monitoring.collector.AbstractCollector;
|
import org.elasticsearch.xpack.monitoring.collector.Collector;
|
||||||
import org.elasticsearch.xpack.monitoring.collector.AbstractCollectorTestCase;
|
import org.elasticsearch.xpack.monitoring.collector.AbstractCollectorTestCase;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
||||||
|
|
||||||
|
@ -89,15 +89,4 @@ public class ClusterStatsCollectorTests extends AbstractCollectorTestCase {
|
||||||
securedClient(nodeId),
|
securedClient(nodeId),
|
||||||
internalCluster().getInstance(LicenseService.class, nodeId));
|
internalCluster().getInstance(LicenseService.class, nodeId));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void assertCanCollect(AbstractCollector collector, Class<?>... classes) {
|
|
||||||
super.assertCanCollect(collector);
|
|
||||||
Collection results = collector.collect();
|
|
||||||
if (classes != null) {
|
|
||||||
assertThat(results.size(), equalTo(classes.length));
|
|
||||||
for (Class<?> cl : classes) {
|
|
||||||
assertThat(results.stream().filter(o -> cl.isInstance(o)).count(), equalTo(1L));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue