Remove description from xpack feature sets (#43065)

The description field of xpack featuresets is optionally part of the
xpack info api, when using the verbose flag. However, this information
is unnecessary, as it is better left for documentation (and the existing
descriptions describe anything meaningful). This commit removes the
description field from feature sets.
This commit is contained in:
Ryan Ernst 2019-06-11 09:20:55 -07:00
parent 6108899a2d
commit 172cd4dbfa
22 changed files with 24 additions and 120 deletions

View File

@ -318,11 +318,6 @@ public class XPackInfoResponse {
return name; return name;
} }
@Nullable
public String description() {
return description;
}
public boolean available() { public boolean available() {
return available; return available;
} }

View File

@ -71,17 +71,14 @@ public class PingAndInfoIT extends ESRestHighLevelClientTestCase {
assertEquals(LicenseStatus.ACTIVE, info.getLicenseInfo().getStatus()); assertEquals(LicenseStatus.ACTIVE, info.getLicenseInfo().getStatus());
FeatureSet graph = info.getFeatureSetsInfo().getFeatureSets().get("graph"); FeatureSet graph = info.getFeatureSetsInfo().getFeatureSets().get("graph");
assertNotNull(graph.description());
assertTrue(graph.available()); assertTrue(graph.available());
assertTrue(graph.enabled()); assertTrue(graph.enabled());
assertNull(graph.nativeCodeInfo()); assertNull(graph.nativeCodeInfo());
FeatureSet monitoring = info.getFeatureSetsInfo().getFeatureSets().get("monitoring"); FeatureSet monitoring = info.getFeatureSetsInfo().getFeatureSets().get("monitoring");
assertNotNull(monitoring.description());
assertTrue(monitoring.available()); assertTrue(monitoring.available());
assertTrue(monitoring.enabled()); assertTrue(monitoring.enabled());
assertNull(monitoring.nativeCodeInfo()); assertNull(monitoring.nativeCodeInfo());
FeatureSet ml = info.getFeatureSetsInfo().getFeatureSets().get("ml"); FeatureSet ml = info.getFeatureSetsInfo().getFeatureSets().get("ml");
assertNotNull(ml.description());
assertTrue(ml.available()); assertTrue(ml.available());
assertTrue(ml.enabled()); assertTrue(ml.enabled());
assertEquals(mainResponse.getVersion().getNumber(), ml.nativeCodeInfo().get("version").toString()); assertEquals(mainResponse.getVersion().getNumber(), ml.nativeCodeInfo().get("version").toString());

View File

@ -70,8 +70,7 @@ public class XPackInfoResponseTests extends
private FeatureSetsInfo convertHlrcToInternal(org.elasticsearch.client.xpack.XPackInfoResponse.FeatureSetsInfo featureSetsInfo) { private FeatureSetsInfo convertHlrcToInternal(org.elasticsearch.client.xpack.XPackInfoResponse.FeatureSetsInfo featureSetsInfo) {
return featureSetsInfo != null return featureSetsInfo != null
? new FeatureSetsInfo(featureSetsInfo.getFeatureSets().values().stream() ? new FeatureSetsInfo(featureSetsInfo.getFeatureSets().values().stream()
.map(fs -> new FeatureSet(fs.name(), fs.description(), fs.available(), fs.enabled(), .map(fs -> new FeatureSet(fs.name(), fs.available(), fs.enabled(), fs.nativeCodeInfo()))
fs.nativeCodeInfo()))
.collect(Collectors.toSet())) .collect(Collectors.toSet()))
: null; : null;
} }
@ -169,7 +168,6 @@ public class XPackInfoResponseTests extends
private FeatureSet randomFeatureSet() { private FeatureSet randomFeatureSet() {
return new FeatureSet( return new FeatureSet(
randomAlphaOfLength(5), randomAlphaOfLength(5),
randomBoolean() ? null : randomAlphaOfLength(20),
randomBoolean(), randomBoolean(),
randomBoolean(), randomBoolean(),
randomNativeCodeInfo()); randomNativeCodeInfo());

View File

@ -64,32 +64,26 @@ Example response:
}, },
"features" : { "features" : {
"ccr" : { "ccr" : {
"description" : "Cross Cluster Replication",
"available" : true, "available" : true,
"enabled" : true "enabled" : true
}, },
"data_frame" : { "data_frame" : {
"description" : "Data Frame for the Elastic Stack",
"available" : true, "available" : true,
"enabled" : true "enabled" : true
}, },
"graph" : { "graph" : {
"description" : "Graph Data Exploration for the Elastic Stack",
"available" : true, "available" : true,
"enabled" : true "enabled" : true
}, },
"ilm" : { "ilm" : {
"description" : "Index lifecycle management for the Elastic Stack",
"available" : true, "available" : true,
"enabled" : true "enabled" : true
}, },
"logstash" : { "logstash" : {
"description" : "Logstash management component for X-Pack",
"available" : true, "available" : true,
"enabled" : true "enabled" : true
}, },
"ml" : { "ml" : {
"description" : "Machine Learning for the Elastic Stack",
"available" : true, "available" : true,
"enabled" : true, "enabled" : true,
"native_code_info" : { "native_code_info" : {
@ -98,27 +92,22 @@ Example response:
} }
}, },
"monitoring" : { "monitoring" : {
"description" : "Monitoring for the Elastic Stack",
"available" : true, "available" : true,
"enabled" : true "enabled" : true
}, },
"rollup": { "rollup": {
"description": "Time series pre-aggregation and rollup",
"available": true, "available": true,
"enabled": true "enabled": true
}, },
"security" : { "security" : {
"description" : "Security for the Elastic Stack",
"available" : true, "available" : true,
"enabled" : false "enabled" : false
}, },
"sql" : { "sql" : {
"description" : "SQL access to Elasticsearch",
"available" : true, "available" : true,
"enabled" : true "enabled" : true
}, },
"watcher" : { "watcher" : {
"description" : "Alerting, Notification and Automation for the Elastic Stack",
"available" : true, "available" : true,
"enabled" : true "enabled" : true
} }

View File

@ -5,6 +5,7 @@
*/ */
package org.elasticsearch.protocol.xpack; package org.elasticsearch.protocol.xpack;
import org.elasticsearch.Version;
import org.elasticsearch.action.ActionResponse; import org.elasticsearch.action.ActionResponse;
import org.elasticsearch.common.Nullable; import org.elasticsearch.common.Nullable;
import org.elasticsearch.common.ParseField; import org.elasticsearch.common.ParseField;
@ -331,28 +332,37 @@ public class XPackInfoResponse extends ActionResponse implements ToXContentObjec
public static class FeatureSet implements ToXContentObject, Writeable { public static class FeatureSet implements ToXContentObject, Writeable {
private final String name; private final String name;
@Nullable private final String description;
private final boolean available; private final boolean available;
private final boolean enabled; private final boolean enabled;
@Nullable private final Map<String, Object> nativeCodeInfo; @Nullable private final Map<String, Object> nativeCodeInfo;
public FeatureSet(String name, @Nullable String description, boolean available, boolean enabled, public FeatureSet(String name, boolean available, boolean enabled,
@Nullable Map<String, Object> nativeCodeInfo) { @Nullable Map<String, Object> nativeCodeInfo) {
this.name = name; this.name = name;
this.description = description;
this.available = available; this.available = available;
this.enabled = enabled; this.enabled = enabled;
this.nativeCodeInfo = nativeCodeInfo; this.nativeCodeInfo = nativeCodeInfo;
} }
public FeatureSet(StreamInput in) throws IOException { public FeatureSet(StreamInput in) throws IOException {
this(in.readString(), in.readOptionalString(), in.readBoolean(), in.readBoolean(), in.readMap()); this(in.readString(), readAvailable(in), in.readBoolean(), in.readMap());
}
// this is separated out so that the removed description can be read from the stream on construction
// TODO: remove this for 8.0
private static boolean readAvailable(StreamInput in) throws IOException {
if (in.getVersion().before(Version.V_7_3_0)) {
in.readOptionalString();
}
return in.readBoolean();
} }
@Override @Override
public void writeTo(StreamOutput out) throws IOException { public void writeTo(StreamOutput out) throws IOException {
out.writeString(name); out.writeString(name);
out.writeOptionalString(description); if (out.getVersion().before(Version.V_7_3_0)) {
out.writeOptionalString(null);
}
out.writeBoolean(available); out.writeBoolean(available);
out.writeBoolean(enabled); out.writeBoolean(enabled);
out.writeMap(nativeCodeInfo); out.writeMap(nativeCodeInfo);
@ -362,11 +372,6 @@ public class XPackInfoResponse extends ActionResponse implements ToXContentObjec
return name; return name;
} }
@Nullable
public String description() {
return description;
}
public boolean available() { public boolean available() {
return available; return available;
} }
@ -386,7 +391,6 @@ public class XPackInfoResponse extends ActionResponse implements ToXContentObjec
if (this == other) return true; if (this == other) return true;
FeatureSet rhs = (FeatureSet) other; FeatureSet rhs = (FeatureSet) other;
return Objects.equals(name, rhs.name) return Objects.equals(name, rhs.name)
&& Objects.equals(description, rhs.description)
&& available == rhs.available && available == rhs.available
&& enabled == rhs.enabled && enabled == rhs.enabled
&& Objects.equals(nativeCodeInfo, rhs.nativeCodeInfo); && Objects.equals(nativeCodeInfo, rhs.nativeCodeInfo);
@ -394,15 +398,12 @@ public class XPackInfoResponse extends ActionResponse implements ToXContentObjec
@Override @Override
public int hashCode() { public int hashCode() {
return Objects.hash(name, description, available, enabled, nativeCodeInfo); return Objects.hash(name, available, enabled, nativeCodeInfo);
} }
@Override @Override
public XContentBuilder toXContent(XContentBuilder builder, Params params) throws IOException { public XContentBuilder toXContent(XContentBuilder builder, Params params) throws IOException {
builder.startObject(); builder.startObject();
if (description != null) {
builder.field("description", description);
}
builder.field("available", available); builder.field("available", available);
builder.field("enabled", enabled); builder.field("enabled", enabled);
if (nativeCodeInfo != null) { if (nativeCodeInfo != null) {

View File

@ -16,11 +16,6 @@ public class EmptyXPackFeatureSet implements XPackFeatureSet {
return "Empty XPackFeatureSet"; return "Empty XPackFeatureSet";
} }
@Override
public String description() {
return "Core will not function without this empty featureset compliments of the way the TransportXPackInfoAction Guice works";
}
@Override @Override
public boolean available() { public boolean available() {
return false; return false;

View File

@ -19,8 +19,6 @@ public interface XPackFeatureSet {
String name(); String name();
String description();
boolean available(); boolean available();
boolean enabled(); boolean enabled();

View File

@ -58,7 +58,7 @@ public class TransportXPackInfoAction extends HandledTransportAction<XPackInfoRe
XPackInfoResponse.FeatureSetsInfo featureSetsInfo = null; XPackInfoResponse.FeatureSetsInfo featureSetsInfo = null;
if (request.getCategories().contains(XPackInfoRequest.Category.FEATURES)) { if (request.getCategories().contains(XPackInfoRequest.Category.FEATURES)) {
Set<FeatureSet> featureSets = this.featureSets.stream().map(fs -> Set<FeatureSet> featureSets = this.featureSets.stream().map(fs ->
new FeatureSet(fs.name(), request.isVerbose() ? fs.description() : null, fs.available(), fs.enabled(), new FeatureSet(fs.name(), fs.available(), fs.enabled(),
request.isVerbose() ? fs.nativeCodeInfo() : null)) request.isVerbose() ? fs.nativeCodeInfo() : null))
.collect(Collectors.toSet()); .collect(Collectors.toSet());
featureSetsInfo = new XPackInfoResponse.FeatureSetsInfo(featureSets); featureSetsInfo = new XPackInfoResponse.FeatureSetsInfo(featureSets);

View File

@ -43,11 +43,6 @@ public class CCRFeatureSet implements XPackFeatureSet {
return XPackField.CCR; return XPackField.CCR;
} }
@Override
public String description() {
return "Cross Cluster Replication";
}
@Override @Override
public boolean available() { public boolean available() {
return licenseState != null && licenseState.isCcrAllowed(); return licenseState != null && licenseState.isCcrAllowed();

View File

@ -49,7 +49,6 @@ public class TransportXPackInfoActionTests extends ESTestCase {
for (int i = 0; i < featureSetCount; i++) { for (int i = 0; i < featureSetCount; i++) {
XPackFeatureSet fs = mock(XPackFeatureSet.class); XPackFeatureSet fs = mock(XPackFeatureSet.class);
when(fs.name()).thenReturn(randomAlphaOfLength(5)); when(fs.name()).thenReturn(randomAlphaOfLength(5));
when(fs.description()).thenReturn(randomAlphaOfLength(10));
when(fs.available()).thenReturn(randomBoolean()); when(fs.available()).thenReturn(randomBoolean());
when(fs.enabled()).thenReturn(randomBoolean()); when(fs.enabled()).thenReturn(randomBoolean());
featureSets.add(fs); featureSets.add(fs);
@ -131,11 +130,6 @@ public class TransportXPackInfoActionTests extends ESTestCase {
for (XPackFeatureSet fs : featureSets) { for (XPackFeatureSet fs : featureSets) {
assertThat(features, hasKey(fs.name())); assertThat(features, hasKey(fs.name()));
assertThat(features.get(fs.name()).name(), equalTo(fs.name())); assertThat(features.get(fs.name()).name(), equalTo(fs.name()));
if (!request.isVerbose()) {
assertThat(features.get(fs.name()).description(), is(nullValue()));
} else {
assertThat(features.get(fs.name()).description(), is(fs.description()));
}
assertThat(features.get(fs.name()).available(), equalTo(fs.available())); assertThat(features.get(fs.name()).available(), equalTo(fs.available()));
assertThat(features.get(fs.name()).enabled(), equalTo(fs.enabled())); assertThat(features.get(fs.name()).enabled(), equalTo(fs.enabled()));
} }

View File

@ -84,11 +84,6 @@ public class DataFrameFeatureSet implements XPackFeatureSet {
return XPackField.DATA_FRAME; return XPackField.DATA_FRAME;
} }
@Override
public String description() {
return "Data Frame for the Elastic Stack";
}
@Override @Override
public boolean available() { public boolean available() {
return licenseState != null && licenseState.isDataFrameAllowed(); return licenseState != null && licenseState.isDataFrameAllowed();

View File

@ -33,11 +33,6 @@ public class GraphFeatureSet implements XPackFeatureSet {
return XPackField.GRAPH; return XPackField.GRAPH;
} }
@Override
public String description() {
return "Graph Data Exploration for the Elastic Stack";
}
@Override @Override
public boolean available() { public boolean available() {
return licenseState != null && licenseState.isGraphAllowed(); return licenseState != null && licenseState.isGraphAllowed();

View File

@ -45,11 +45,6 @@ public class IndexLifecycleFeatureSet implements XPackFeatureSet {
return XPackField.INDEX_LIFECYCLE; return XPackField.INDEX_LIFECYCLE;
} }
@Override
public String description() {
return "Index lifecycle management for the Elastic Stack";
}
@Override @Override
public boolean available() { public boolean available() {
return licenseState != null && licenseState.isIndexLifecycleAllowed(); return licenseState != null && licenseState.isIndexLifecycleAllowed();

View File

@ -34,11 +34,6 @@ public class LogstashFeatureSet implements XPackFeatureSet {
return XPackField.LOGSTASH; return XPackField.LOGSTASH;
} }
@Override
public String description() {
return "Logstash management component for X-Pack";
}
@Override @Override
public boolean available() { public boolean available() {
return licenseState != null && licenseState.isLogstashAllowed(); return licenseState != null && licenseState.isLogstashAllowed();

View File

@ -114,11 +114,6 @@ public class MachineLearningFeatureSet implements XPackFeatureSet {
return XPackField.MACHINE_LEARNING; return XPackField.MACHINE_LEARNING;
} }
@Override
public String description() {
return "Machine Learning for the Elastic Stack";
}
@Override @Override
public boolean available() { public boolean available() {
return licenseState != null && licenseState.isMachineLearningAllowed(); return licenseState != null && licenseState.isMachineLearningAllowed();

View File

@ -43,11 +43,6 @@ public class MonitoringFeatureSet implements XPackFeatureSet {
return XPackField.MONITORING; return XPackField.MONITORING;
} }
@Override
public String description() {
return "Monitoring for the Elastic Stack";
}
@Override @Override
public boolean available() { public boolean available() {
return licenseState != null && licenseState.isMonitoringAllowed(); return licenseState != null && licenseState.isMonitoringAllowed();

View File

@ -33,11 +33,6 @@ public class RollupFeatureSet implements XPackFeatureSet {
return XPackField.ROLLUP; return XPackField.ROLLUP;
} }
@Override
public String description() {
return "Time series pre-aggregation and rollup";
}
@Override @Override
public boolean available() { public boolean available() {
return licenseState != null && licenseState.isRollupAllowed(); return licenseState != null && licenseState.isRollupAllowed();

View File

@ -68,11 +68,6 @@ public class SecurityFeatureSet implements XPackFeatureSet {
return XPackField.SECURITY; return XPackField.SECURITY;
} }
@Override
public String description() {
return "Security for the Elastic Stack";
}
@Override @Override
public boolean available() { public boolean available() {
return licenseState != null && licenseState.isSecurityAvailable(); return licenseState != null && licenseState.isSecurityAvailable();

View File

@ -236,8 +236,8 @@ public class SetupPasswordToolTests extends CommandTestCase {
URL xpackSecurityPluginQueryURL = queryXPackSecurityFeatureConfigURL(url); URL xpackSecurityPluginQueryURL = queryXPackSecurityFeatureConfigURL(url);
Set<FeatureSet> featureSets = new HashSet<>(); Set<FeatureSet> featureSets = new HashSet<>();
featureSets.add(new FeatureSet("logstash", null, true, true, null)); featureSets.add(new FeatureSet("logstash", true, true, null));
featureSets.add(new FeatureSet("security", null, true, true, null)); featureSets.add(new FeatureSet("security", true, true, null));
FeatureSetsInfo featureInfos = new FeatureSetsInfo(featureSets); FeatureSetsInfo featureInfos = new FeatureSetsInfo(featureSets);
XPackInfoResponse xpackInfo = new XPackInfoResponse(null, null, featureInfos); XPackInfoResponse xpackInfo = new XPackInfoResponse(null, null, featureInfos);
String securityPluginQueryResponseBody = null; String securityPluginQueryResponseBody = null;
@ -267,8 +267,8 @@ public class SetupPasswordToolTests extends CommandTestCase {
any(CheckedFunction.class))).thenReturn(httpResponse); any(CheckedFunction.class))).thenReturn(httpResponse);
Set<FeatureSet> featureSets = new HashSet<>(); Set<FeatureSet> featureSets = new HashSet<>();
featureSets.add(new FeatureSet("logstash", null, true, true, null)); featureSets.add(new FeatureSet("logstash", true, true, null));
featureSets.add(new FeatureSet("security", null, false, false, null)); featureSets.add(new FeatureSet("security", false, false, null));
FeatureSetsInfo featureInfos = new FeatureSetsInfo(featureSets); FeatureSetsInfo featureInfos = new FeatureSetsInfo(featureSets);
XPackInfoResponse xpackInfo = new XPackInfoResponse(null, null, featureInfos); XPackInfoResponse xpackInfo = new XPackInfoResponse(null, null, featureInfos);
String securityPluginQueryResponseBody = null; String securityPluginQueryResponseBody = null;
@ -298,8 +298,8 @@ public class SetupPasswordToolTests extends CommandTestCase {
any(CheckedFunction.class))).thenReturn(httpResponse); any(CheckedFunction.class))).thenReturn(httpResponse);
Set<FeatureSet> featureSets = new HashSet<>(); Set<FeatureSet> featureSets = new HashSet<>();
featureSets.add(new FeatureSet("logstash", null, true, true, null)); featureSets.add(new FeatureSet("logstash", true, true, null));
featureSets.add(new FeatureSet("security", null, true, false, null)); featureSets.add(new FeatureSet("security", true, false, null));
FeatureSetsInfo featureInfos = new FeatureSetsInfo(featureSets); FeatureSetsInfo featureInfos = new FeatureSetsInfo(featureSets);
XPackInfoResponse xpackInfo = new XPackInfoResponse(null, null, featureInfos); XPackInfoResponse xpackInfo = new XPackInfoResponse(null, null, featureInfos);
String securityPluginQueryResponseBody = null; String securityPluginQueryResponseBody = null;

View File

@ -45,11 +45,6 @@ public class SqlFeatureSet implements XPackFeatureSet {
return XPackField.SQL; return XPackField.SQL;
} }
@Override
public String description() {
return "SQL access to Elasticsearch";
}
@Override @Override
public boolean available() { public boolean available() {
return licenseState != null && licenseState.isSqlAllowed(); return licenseState != null && licenseState.isSqlAllowed();

View File

@ -68,19 +68,15 @@
- is_true: features.watcher - is_true: features.watcher
- is_true: features.watcher.enabled - is_true: features.watcher.enabled
- is_true: features.watcher.available - is_true: features.watcher.available
- is_true: features.watcher.description
- is_true: features.security - is_true: features.security
- is_true: features.security.enabled - is_true: features.security.enabled
- is_true: features.security.available - is_true: features.security.available
- is_true: features.security.description
- is_true: features.graph - is_true: features.graph
- is_true: features.graph.enabled - is_true: features.graph.enabled
- is_true: features.graph.available - is_true: features.graph.available
- is_true: features.graph.description
- is_true: features.monitoring - is_true: features.monitoring
- is_true: features.monitoring.enabled - is_true: features.monitoring.enabled
- is_true: features.monitoring.available - is_true: features.monitoring.available
- is_true: features.monitoring.description
- is_true: tagline - is_true: tagline
- do: - do:
@ -152,19 +148,15 @@
- is_true: features.watcher - is_true: features.watcher
- is_true: features.watcher.enabled - is_true: features.watcher.enabled
- is_true: features.watcher.available - is_true: features.watcher.available
- is_false: features.watcher.description
- is_true: features.security - is_true: features.security
- is_true: features.security.enabled - is_true: features.security.enabled
- is_true: features.security.available - is_true: features.security.available
- is_false: features.security.description
- is_true: features.graph - is_true: features.graph
- is_true: features.graph.enabled - is_true: features.graph.enabled
- is_true: features.graph.available - is_true: features.graph.available
- is_false: features.graph.description
- is_true: features.monitoring - is_true: features.monitoring
- is_true: features.monitoring.enabled - is_true: features.monitoring.enabled
- is_true: features.monitoring.available - is_true: features.monitoring.available
- is_false: features.monitoring.description
- is_false: tagline - is_false: tagline

View File

@ -47,11 +47,6 @@ public class WatcherFeatureSet implements XPackFeatureSet {
return XPackField.WATCHER; return XPackField.WATCHER;
} }
@Override
public String description() {
return "Alerting, Notification and Automation for the Elastic Stack";
}
@Override @Override
public boolean available() { public boolean available() {
return licenseState != null && licenseState.isWatcherAllowed(); return licenseState != null && licenseState.isWatcherAllowed();