Leniently parse ml persistent task parameters (#33950)
This commit is contained in:
parent
02fb5aa4ec
commit
7bc7624caf
|
@ -134,7 +134,7 @@ public class OpenJobAction extends Action<AcknowledgedResponse> {
|
||||||
public static final ParseField IGNORE_DOWNTIME = new ParseField("ignore_downtime");
|
public static final ParseField IGNORE_DOWNTIME = new ParseField("ignore_downtime");
|
||||||
|
|
||||||
public static final ParseField TIMEOUT = new ParseField("timeout");
|
public static final ParseField TIMEOUT = new ParseField("timeout");
|
||||||
public static ObjectParser<JobParams, Void> PARSER = new ObjectParser<>(TASK_NAME, JobParams::new);
|
public static ObjectParser<JobParams, Void> PARSER = new ObjectParser<>(TASK_NAME, true, JobParams::new);
|
||||||
|
|
||||||
static {
|
static {
|
||||||
PARSER.declareString(JobParams::setJobId, Job.ID);
|
PARSER.declareString(JobParams::setJobId, Job.ID);
|
||||||
|
|
|
@ -141,7 +141,7 @@ public class StartDatafeedAction extends Action<AcknowledgedResponse> {
|
||||||
|
|
||||||
public static class DatafeedParams implements XPackPlugin.XPackPersistentTaskParams {
|
public static class DatafeedParams implements XPackPlugin.XPackPersistentTaskParams {
|
||||||
|
|
||||||
public static ObjectParser<DatafeedParams, Void> PARSER = new ObjectParser<>(TASK_NAME, DatafeedParams::new);
|
public static ObjectParser<DatafeedParams, Void> PARSER = new ObjectParser<>(TASK_NAME, true, DatafeedParams::new);
|
||||||
|
|
||||||
static {
|
static {
|
||||||
PARSER.declareString((params, datafeedId) -> params.datafeedId = datafeedId, DatafeedConfig.ID);
|
PARSER.declareString((params, datafeedId) -> params.datafeedId = datafeedId, DatafeedConfig.ID);
|
||||||
|
|
|
@ -0,0 +1,48 @@
|
||||||
|
/*
|
||||||
|
* 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.core.ml.action;
|
||||||
|
|
||||||
|
import org.elasticsearch.common.io.stream.Writeable;
|
||||||
|
import org.elasticsearch.common.unit.TimeValue;
|
||||||
|
import org.elasticsearch.common.xcontent.XContentParser;
|
||||||
|
import org.elasticsearch.test.AbstractSerializingTestCase;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
public class DatafeedParamsTests extends AbstractSerializingTestCase<StartDatafeedAction.DatafeedParams> {
|
||||||
|
@Override
|
||||||
|
protected StartDatafeedAction.DatafeedParams doParseInstance(XContentParser parser) throws IOException {
|
||||||
|
return StartDatafeedAction.DatafeedParams.parseRequest(null, parser);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static StartDatafeedAction.DatafeedParams createDatafeedParams() {
|
||||||
|
StartDatafeedAction.DatafeedParams params =
|
||||||
|
new StartDatafeedAction.DatafeedParams(randomAlphaOfLength(10), randomNonNegativeLong());
|
||||||
|
if (randomBoolean()) {
|
||||||
|
params.setEndTime(randomNonNegativeLong());
|
||||||
|
}
|
||||||
|
if (randomBoolean()) {
|
||||||
|
params.setTimeout(TimeValue.timeValueMillis(randomNonNegativeLong()));
|
||||||
|
}
|
||||||
|
return params;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected StartDatafeedAction.DatafeedParams createTestInstance() {
|
||||||
|
return createDatafeedParams();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected Writeable.Reader<StartDatafeedAction.DatafeedParams> instanceReader() {
|
||||||
|
return StartDatafeedAction.DatafeedParams::new;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected boolean supportsUnknownFields() {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,45 @@
|
||||||
|
/*
|
||||||
|
* 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.core.ml.action;
|
||||||
|
|
||||||
|
import org.elasticsearch.common.io.stream.Writeable;
|
||||||
|
import org.elasticsearch.common.unit.TimeValue;
|
||||||
|
import org.elasticsearch.common.xcontent.XContentParser;
|
||||||
|
import org.elasticsearch.test.AbstractSerializingTestCase;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
public class JobParamsTests extends AbstractSerializingTestCase<OpenJobAction.JobParams> {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected OpenJobAction.JobParams doParseInstance(XContentParser parser) throws IOException {
|
||||||
|
return OpenJobAction.JobParams.parseRequest(null, parser);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static OpenJobAction.JobParams createJobParams() {
|
||||||
|
OpenJobAction.JobParams params = new OpenJobAction.JobParams(randomAlphaOfLengthBetween(1, 20));
|
||||||
|
if (randomBoolean()) {
|
||||||
|
params.setTimeout(TimeValue.timeValueMillis(randomNonNegativeLong()));
|
||||||
|
}
|
||||||
|
return params;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected OpenJobAction.JobParams createTestInstance() {
|
||||||
|
return createJobParams();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected Writeable.Reader<OpenJobAction.JobParams> instanceReader() {
|
||||||
|
return OpenJobAction.JobParams::new;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected boolean supportsUnknownFields() {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
|
@ -5,7 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.xpack.core.ml.action;
|
package org.elasticsearch.xpack.core.ml.action;
|
||||||
|
|
||||||
import org.elasticsearch.common.unit.TimeValue;
|
|
||||||
import org.elasticsearch.common.xcontent.XContentParser;
|
import org.elasticsearch.common.xcontent.XContentParser;
|
||||||
import org.elasticsearch.test.AbstractStreamableXContentTestCase;
|
import org.elasticsearch.test.AbstractStreamableXContentTestCase;
|
||||||
import org.elasticsearch.xpack.core.ml.action.OpenJobAction.Request;
|
import org.elasticsearch.xpack.core.ml.action.OpenJobAction.Request;
|
||||||
|
@ -14,11 +13,7 @@ public class OpenJobActionRequestTests extends AbstractStreamableXContentTestCas
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected Request createTestInstance() {
|
protected Request createTestInstance() {
|
||||||
OpenJobAction.JobParams params = new OpenJobAction.JobParams(randomAlphaOfLengthBetween(1, 20));
|
return new Request(JobParamsTests.createJobParams());
|
||||||
if (randomBoolean()) {
|
|
||||||
params.setTimeout(TimeValue.timeValueMillis(randomNonNegativeLong()));
|
|
||||||
}
|
|
||||||
return new Request(params);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -6,10 +6,8 @@
|
||||||
package org.elasticsearch.xpack.core.ml.action;
|
package org.elasticsearch.xpack.core.ml.action;
|
||||||
|
|
||||||
import org.elasticsearch.ElasticsearchParseException;
|
import org.elasticsearch.ElasticsearchParseException;
|
||||||
import org.elasticsearch.common.unit.TimeValue;
|
|
||||||
import org.elasticsearch.common.xcontent.XContentParser;
|
import org.elasticsearch.common.xcontent.XContentParser;
|
||||||
import org.elasticsearch.test.AbstractStreamableXContentTestCase;
|
import org.elasticsearch.test.AbstractStreamableXContentTestCase;
|
||||||
import org.elasticsearch.xpack.core.ml.action.StartDatafeedAction.DatafeedParams;
|
|
||||||
import org.elasticsearch.xpack.core.ml.action.StartDatafeedAction.Request;
|
import org.elasticsearch.xpack.core.ml.action.StartDatafeedAction.Request;
|
||||||
|
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
@ -18,14 +16,7 @@ public class StartDatafeedActionRequestTests extends AbstractStreamableXContentT
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected Request createTestInstance() {
|
protected Request createTestInstance() {
|
||||||
DatafeedParams params = new DatafeedParams(randomAlphaOfLength(10), randomNonNegativeLong());
|
return new Request(DatafeedParamsTests.createDatafeedParams());
|
||||||
if (randomBoolean()) {
|
|
||||||
params.setEndTime(randomNonNegativeLong());
|
|
||||||
}
|
|
||||||
if (randomBoolean()) {
|
|
||||||
params.setTimeout(TimeValue.timeValueMillis(randomNonNegativeLong()));
|
|
||||||
}
|
|
||||||
return new Request(params);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
Loading…
Reference in New Issue