* Introduce Safer Chaining of Listeners * The motivation here is to make reasoning about chains of `ActionListener` a little easier, by providing a safe method for nesting `ActionListener` that guarantees that a response is never dropped. Also, it dries up the code a little by removing the need to repeat `listener::onFailure` and `listener.onResponse` over and over. * Refactored a number of obvious/easy spots to use the new listener constructor
This commit is contained in:
parent
c7a2910cc1
commit
547af21a12
|
@ -21,6 +21,7 @@ package org.elasticsearch.action;
|
||||||
|
|
||||||
import org.elasticsearch.ExceptionsHelper;
|
import org.elasticsearch.ExceptionsHelper;
|
||||||
import org.elasticsearch.common.CheckedConsumer;
|
import org.elasticsearch.common.CheckedConsumer;
|
||||||
|
import org.elasticsearch.common.CheckedFunction;
|
||||||
import org.elasticsearch.common.CheckedSupplier;
|
import org.elasticsearch.common.CheckedSupplier;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
@ -83,6 +84,20 @@ public interface ActionListener<Response> {
|
||||||
return wrap(r -> runnable.run(), e -> runnable.run());
|
return wrap(r -> runnable.run(), e -> runnable.run());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a listener that wraps another listener, mapping response values via the given mapping function and passing along
|
||||||
|
* exceptions to the delegate.
|
||||||
|
*
|
||||||
|
* @param listener Listener to delegate to
|
||||||
|
* @param fn Function to apply to listener response
|
||||||
|
* @param <Response> Response type of the new listener
|
||||||
|
* @param <T> Response type of the wrapped listener
|
||||||
|
* @return a listener that maps the received response and then passes it to its delegate listener
|
||||||
|
*/
|
||||||
|
static <T, Response> ActionListener<Response> map(ActionListener<T> listener, CheckedFunction<Response, T, Exception> fn) {
|
||||||
|
return wrap(r -> listener.onResponse(fn.apply(r)), listener::onFailure);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Converts a listener to a {@link BiConsumer} for compatibility with the {@link java.util.concurrent.CompletableFuture}
|
* Converts a listener to a {@link BiConsumer} for compatibility with the {@link java.util.concurrent.CompletableFuture}
|
||||||
* api.
|
* api.
|
||||||
|
|
|
@ -148,13 +148,13 @@ public class TransportClusterRerouteAction extends TransportMasterNodeAction<Clu
|
||||||
private void submitStateUpdate(final ClusterRerouteRequest request, final ActionListener<ClusterRerouteResponse> listener) {
|
private void submitStateUpdate(final ClusterRerouteRequest request, final ActionListener<ClusterRerouteResponse> listener) {
|
||||||
clusterService.submitStateUpdateTask("cluster_reroute (api)",
|
clusterService.submitStateUpdateTask("cluster_reroute (api)",
|
||||||
new ClusterRerouteResponseAckedClusterStateUpdateTask(logger, allocationService, request,
|
new ClusterRerouteResponseAckedClusterStateUpdateTask(logger, allocationService, request,
|
||||||
ActionListener.wrap(
|
ActionListener.map(listener,
|
||||||
response -> {
|
response -> {
|
||||||
if (request.dryRun() == false) {
|
if (request.dryRun() == false) {
|
||||||
response.getExplanations().getYesDecisionMessages().forEach(logger::info);
|
response.getExplanations().getYesDecisionMessages().forEach(logger::info);
|
||||||
}
|
}
|
||||||
listener.onResponse(response);
|
return response;
|
||||||
}, listener::onFailure)));
|
})));
|
||||||
}
|
}
|
||||||
|
|
||||||
static class ClusterRerouteResponseAckedClusterStateUpdateTask extends AckedClusterStateUpdateTask<ClusterRerouteResponse> {
|
static class ClusterRerouteResponseAckedClusterStateUpdateTask extends AckedClusterStateUpdateTask<ClusterRerouteResponse> {
|
||||||
|
|
|
@ -72,11 +72,9 @@ public class TransportCreateSnapshotAction extends TransportMasterNodeAction<Cre
|
||||||
protected void masterOperation(final CreateSnapshotRequest request, ClusterState state,
|
protected void masterOperation(final CreateSnapshotRequest request, ClusterState state,
|
||||||
final ActionListener<CreateSnapshotResponse> listener) {
|
final ActionListener<CreateSnapshotResponse> listener) {
|
||||||
if (request.waitForCompletion()) {
|
if (request.waitForCompletion()) {
|
||||||
snapshotsService.executeSnapshot(request,
|
snapshotsService.executeSnapshot(request, ActionListener.map(listener, CreateSnapshotResponse::new));
|
||||||
ActionListener.wrap(snapshotInfo-> listener.onResponse(new CreateSnapshotResponse(snapshotInfo)), listener::onFailure));
|
|
||||||
} else {
|
} else {
|
||||||
snapshotsService.createSnapshot(request,
|
snapshotsService.createSnapshot(request, ActionListener.map(listener, snapshot -> new CreateSnapshotResponse()));
|
||||||
ActionListener.wrap(snapshot -> listener.onResponse(new CreateSnapshotResponse()), listener::onFailure));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -68,6 +68,6 @@ public class TransportDeleteSnapshotAction extends TransportMasterNodeAction<Del
|
||||||
protected void masterOperation(final DeleteSnapshotRequest request, ClusterState state,
|
protected void masterOperation(final DeleteSnapshotRequest request, ClusterState state,
|
||||||
final ActionListener<AcknowledgedResponse> listener) {
|
final ActionListener<AcknowledgedResponse> listener) {
|
||||||
snapshotsService.deleteSnapshot(request.repository(), request.snapshot(),
|
snapshotsService.deleteSnapshot(request.repository(), request.snapshot(),
|
||||||
ActionListener.wrap(v -> listener.onResponse(new AcknowledgedResponse(true)), listener::onFailure), false);
|
ActionListener.map(listener, v -> new AcknowledgedResponse(true)), false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -80,9 +80,8 @@ public class TransportCreateIndexAction extends TransportMasterNodeAction<Create
|
||||||
.aliases(request.aliases())
|
.aliases(request.aliases())
|
||||||
.waitForActiveShards(request.waitForActiveShards());
|
.waitForActiveShards(request.waitForActiveShards());
|
||||||
|
|
||||||
createIndexService.createIndex(updateRequest, ActionListener.wrap(response ->
|
createIndexService.createIndex(updateRequest, ActionListener.map(listener, response ->
|
||||||
listener.onResponse(new CreateIndexResponse(response.isAcknowledged(), response.isShardsAcknowledged(), indexName)),
|
new CreateIndexResponse(response.isAcknowledged(), response.isShardsAcknowledged(), indexName)));
|
||||||
listener::onFailure));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -107,11 +107,8 @@ public class TransportResizeAction extends TransportMasterNodeAction<ResizeReque
|
||||||
return shard == null ? null : shard.getPrimary().getDocs();
|
return shard == null ? null : shard.getPrimary().getDocs();
|
||||||
}, sourceIndex, targetIndex);
|
}, sourceIndex, targetIndex);
|
||||||
createIndexService.createIndex(
|
createIndexService.createIndex(
|
||||||
updateRequest,
|
updateRequest, ActionListener.map(listener,
|
||||||
ActionListener.wrap(response ->
|
response -> new ResizeResponse(response.isAcknowledged(), response.isShardsAcknowledged(), updateRequest.index()))
|
||||||
listener.onResponse(new ResizeResponse(response.isAcknowledged(), response.isShardsAcknowledged(),
|
|
||||||
updateRequest.index())), listener::onFailure
|
|
||||||
)
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -635,10 +635,8 @@ public class TransportBulkAction extends HandledTransportAction<BulkRequest, Bul
|
||||||
|
|
||||||
ActionListener<BulkResponse> wrapActionListenerIfNeeded(long ingestTookInMillis, ActionListener<BulkResponse> actionListener) {
|
ActionListener<BulkResponse> wrapActionListenerIfNeeded(long ingestTookInMillis, ActionListener<BulkResponse> actionListener) {
|
||||||
if (itemResponses.isEmpty()) {
|
if (itemResponses.isEmpty()) {
|
||||||
return ActionListener.wrap(
|
return ActionListener.map(actionListener,
|
||||||
response -> actionListener.onResponse(new BulkResponse(response.getItems(),
|
response -> new BulkResponse(response.getItems(), response.getTook().getMillis(), ingestTookInMillis));
|
||||||
response.getTook().getMillis(), ingestTookInMillis)),
|
|
||||||
actionListener::onFailure);
|
|
||||||
} else {
|
} else {
|
||||||
return new IngestBulkResponseListener(ingestTookInMillis, originalSlots, itemResponses, actionListener);
|
return new IngestBulkResponseListener(ingestTookInMillis, originalSlots, itemResponses, actionListener);
|
||||||
}
|
}
|
||||||
|
|
|
@ -129,16 +129,8 @@ abstract class SearchScrollAsyncAction<T extends SearchPhaseResult> implements R
|
||||||
listener.onResponse((cluster, node) -> nodes.get(node));
|
listener.onResponse((cluster, node) -> nodes.get(node));
|
||||||
} else {
|
} else {
|
||||||
RemoteClusterService remoteClusterService = searchTransportService.getRemoteClusterService();
|
RemoteClusterService remoteClusterService = searchTransportService.getRemoteClusterService();
|
||||||
remoteClusterService.collectNodes(clusters, ActionListener.wrap(nodeFunction -> {
|
remoteClusterService.collectNodes(clusters, ActionListener.map(listener,
|
||||||
final BiFunction<String, String, DiscoveryNode> clusterNodeLookup = (clusterAlias, node) -> {
|
nodeFunction -> (clusterAlias, node) -> clusterAlias == null ? nodes.get(node) : nodeFunction.apply(clusterAlias, node)));
|
||||||
if (clusterAlias == null) {
|
|
||||||
return nodes.get(node);
|
|
||||||
} else {
|
|
||||||
return nodeFunction.apply(clusterAlias, node);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
listener.onResponse(clusterNodeLookup);
|
|
||||||
}, listener::onFailure));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -501,13 +501,11 @@ public class TermsQueryBuilder extends AbstractQueryBuilder<TermsQueryBuilder> {
|
||||||
return supplier.get() == null ? this : new TermsQueryBuilder(this.fieldName, supplier.get());
|
return supplier.get() == null ? this : new TermsQueryBuilder(this.fieldName, supplier.get());
|
||||||
} else if (this.termsLookup != null) {
|
} else if (this.termsLookup != null) {
|
||||||
SetOnce<List<?>> supplier = new SetOnce<>();
|
SetOnce<List<?>> supplier = new SetOnce<>();
|
||||||
queryRewriteContext.registerAsyncAction((client, listener) -> {
|
queryRewriteContext.registerAsyncAction((client, listener) ->
|
||||||
fetch(termsLookup, client, ActionListener.wrap(list -> {
|
fetch(termsLookup, client, ActionListener.map(listener, list -> {
|
||||||
supplier.set(list);
|
supplier.set(list);
|
||||||
listener.onResponse(null);
|
return null;
|
||||||
}, listener::onFailure));
|
})));
|
||||||
|
|
||||||
});
|
|
||||||
return new TermsQueryBuilder(this.fieldName, supplier::get);
|
return new TermsQueryBuilder(this.fieldName, supplier::get);
|
||||||
}
|
}
|
||||||
return this;
|
return this;
|
||||||
|
|
|
@ -169,9 +169,7 @@ public class RetentionLeaseActions {
|
||||||
request.getId(),
|
request.getId(),
|
||||||
request.getRetainingSequenceNumber(),
|
request.getRetainingSequenceNumber(),
|
||||||
request.getSource(),
|
request.getSource(),
|
||||||
ActionListener.wrap(
|
ActionListener.map(listener, r -> new Response()));
|
||||||
r -> listener.onResponse(new Response()),
|
|
||||||
listener::onFailure));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -264,9 +262,7 @@ public class RetentionLeaseActions {
|
||||||
void doRetentionLeaseAction(final IndexShard indexShard, final RemoveRequest request, final ActionListener<Response> listener) {
|
void doRetentionLeaseAction(final IndexShard indexShard, final RemoveRequest request, final ActionListener<Response> listener) {
|
||||||
indexShard.removeRetentionLease(
|
indexShard.removeRetentionLease(
|
||||||
request.getId(),
|
request.getId(),
|
||||||
ActionListener.wrap(
|
ActionListener.map(listener, r -> new Response()));
|
||||||
r -> listener.onResponse(new Response()),
|
|
||||||
listener::onFailure));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -435,7 +435,7 @@ public class PeerRecoveryTargetService implements IndexEventListener {
|
||||||
try (RecoveryRef recoveryRef = onGoingRecoveries.getRecoverySafe(request.recoveryId(), request.shardId())) {
|
try (RecoveryRef recoveryRef = onGoingRecoveries.getRecoverySafe(request.recoveryId(), request.shardId())) {
|
||||||
final ActionListener<TransportResponse> listener = new ChannelActionListener<>(channel, Actions.PREPARE_TRANSLOG, request);
|
final ActionListener<TransportResponse> listener = new ChannelActionListener<>(channel, Actions.PREPARE_TRANSLOG, request);
|
||||||
recoveryRef.target().prepareForTranslogOperations(request.isFileBasedRecovery(), request.totalTranslogOps(),
|
recoveryRef.target().prepareForTranslogOperations(request.isFileBasedRecovery(), request.totalTranslogOps(),
|
||||||
ActionListener.wrap(nullVal -> listener.onResponse(TransportResponse.Empty.INSTANCE), listener::onFailure));
|
ActionListener.map(listener, nullVal -> TransportResponse.Empty.INSTANCE));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -447,7 +447,7 @@ public class PeerRecoveryTargetService implements IndexEventListener {
|
||||||
try (RecoveryRef recoveryRef = onGoingRecoveries.getRecoverySafe(request.recoveryId(), request.shardId())) {
|
try (RecoveryRef recoveryRef = onGoingRecoveries.getRecoverySafe(request.recoveryId(), request.shardId())) {
|
||||||
final ActionListener<TransportResponse> listener = new ChannelActionListener<>(channel, Actions.FINALIZE, request);
|
final ActionListener<TransportResponse> listener = new ChannelActionListener<>(channel, Actions.FINALIZE, request);
|
||||||
recoveryRef.target().finalizeRecovery(request.globalCheckpoint(),
|
recoveryRef.target().finalizeRecovery(request.globalCheckpoint(),
|
||||||
ActionListener.wrap(nullVal -> listener.onResponse(TransportResponse.Empty.INSTANCE), listener::onFailure));
|
ActionListener.map(listener, nullVal -> TransportResponse.Empty.INSTANCE));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -630,8 +630,7 @@ public class PeerRecoveryTargetService implements IndexEventListener {
|
||||||
}
|
}
|
||||||
final ActionListener<TransportResponse> listener = new ChannelActionListener<>(channel, Actions.FILE_CHUNK, request);
|
final ActionListener<TransportResponse> listener = new ChannelActionListener<>(channel, Actions.FILE_CHUNK, request);
|
||||||
recoveryTarget.writeFileChunk(request.metadata(), request.position(), request.content(), request.lastChunk(),
|
recoveryTarget.writeFileChunk(request.metadata(), request.position(), request.content(), request.lastChunk(),
|
||||||
request.totalTranslogOps(),
|
request.totalTranslogOps(), ActionListener.map(listener, nullVal -> TransportResponse.Empty.INSTANCE));
|
||||||
ActionListener.wrap(nullVal -> listener.onResponse(TransportResponse.Empty.INSTANCE), listener::onFailure));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -552,7 +552,7 @@ public class RecoverySourceHandler {
|
||||||
};
|
};
|
||||||
|
|
||||||
final StopWatch stopWatch = new StopWatch().start();
|
final StopWatch stopWatch = new StopWatch().start();
|
||||||
final ActionListener<Long> batchedListener = ActionListener.wrap(
|
final ActionListener<Long> batchedListener = ActionListener.map(listener,
|
||||||
targetLocalCheckpoint -> {
|
targetLocalCheckpoint -> {
|
||||||
assert snapshot.totalOperations() == snapshot.skippedOperations() + skippedOps.get() + totalSentOps.get()
|
assert snapshot.totalOperations() == snapshot.skippedOperations() + skippedOps.get() + totalSentOps.get()
|
||||||
: String.format(Locale.ROOT, "expected total [%d], overridden [%d], skipped [%d], total sent [%d]",
|
: String.format(Locale.ROOT, "expected total [%d], overridden [%d], skipped [%d], total sent [%d]",
|
||||||
|
@ -560,9 +560,8 @@ public class RecoverySourceHandler {
|
||||||
stopWatch.stop();
|
stopWatch.stop();
|
||||||
final TimeValue tookTime = stopWatch.totalTime();
|
final TimeValue tookTime = stopWatch.totalTime();
|
||||||
logger.trace("recovery [phase2]: took [{}]", tookTime);
|
logger.trace("recovery [phase2]: took [{}]", tookTime);
|
||||||
listener.onResponse(new SendSnapshotResult(targetLocalCheckpoint, totalSentOps.get(), tookTime));
|
return new SendSnapshotResult(targetLocalCheckpoint, totalSentOps.get(), tookTime);
|
||||||
},
|
}
|
||||||
listener::onFailure
|
|
||||||
);
|
);
|
||||||
|
|
||||||
sendBatch(
|
sendBatch(
|
||||||
|
|
|
@ -82,7 +82,7 @@ public class RemoteRecoveryTargetHandler implements RecoveryTargetHandler {
|
||||||
transportService.submitRequest(targetNode, PeerRecoveryTargetService.Actions.PREPARE_TRANSLOG,
|
transportService.submitRequest(targetNode, PeerRecoveryTargetService.Actions.PREPARE_TRANSLOG,
|
||||||
new RecoveryPrepareForTranslogOperationsRequest(recoveryId, shardId, totalTranslogOps, fileBasedRecovery),
|
new RecoveryPrepareForTranslogOperationsRequest(recoveryId, shardId, totalTranslogOps, fileBasedRecovery),
|
||||||
TransportRequestOptions.builder().withTimeout(recoverySettings.internalActionTimeout()).build(),
|
TransportRequestOptions.builder().withTimeout(recoverySettings.internalActionTimeout()).build(),
|
||||||
new ActionListenerResponseHandler<>(ActionListener.wrap(r -> listener.onResponse(null), listener::onFailure),
|
new ActionListenerResponseHandler<>(ActionListener.map(listener, r -> null),
|
||||||
in -> TransportResponse.Empty.INSTANCE, ThreadPool.Names.GENERIC));
|
in -> TransportResponse.Empty.INSTANCE, ThreadPool.Names.GENERIC));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -91,7 +91,7 @@ public class RemoteRecoveryTargetHandler implements RecoveryTargetHandler {
|
||||||
transportService.submitRequest(targetNode, PeerRecoveryTargetService.Actions.FINALIZE,
|
transportService.submitRequest(targetNode, PeerRecoveryTargetService.Actions.FINALIZE,
|
||||||
new RecoveryFinalizeRecoveryRequest(recoveryId, shardId, globalCheckpoint),
|
new RecoveryFinalizeRecoveryRequest(recoveryId, shardId, globalCheckpoint),
|
||||||
TransportRequestOptions.builder().withTimeout(recoverySettings.internalActionLongTimeout()).build(),
|
TransportRequestOptions.builder().withTimeout(recoverySettings.internalActionLongTimeout()).build(),
|
||||||
new ActionListenerResponseHandler<>(ActionListener.wrap(r -> listener.onResponse(null), listener::onFailure),
|
new ActionListenerResponseHandler<>(ActionListener.map(listener, r -> null),
|
||||||
in -> TransportResponse.Empty.INSTANCE, ThreadPool.Names.GENERIC));
|
in -> TransportResponse.Empty.INSTANCE, ThreadPool.Names.GENERIC));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -130,7 +130,7 @@ public class RemoteRecoveryTargetHandler implements RecoveryTargetHandler {
|
||||||
maxSeqNoOfDeletesOrUpdatesOnPrimary,
|
maxSeqNoOfDeletesOrUpdatesOnPrimary,
|
||||||
retentionLeases);
|
retentionLeases);
|
||||||
transportService.submitRequest(targetNode, PeerRecoveryTargetService.Actions.TRANSLOG_OPS, request, translogOpsRequestOptions,
|
transportService.submitRequest(targetNode, PeerRecoveryTargetService.Actions.TRANSLOG_OPS, request, translogOpsRequestOptions,
|
||||||
new ActionListenerResponseHandler<>(ActionListener.wrap(r -> listener.onResponse(r.localCheckpoint), listener::onFailure),
|
new ActionListenerResponseHandler<>(ActionListener.map(listener, r -> r.localCheckpoint),
|
||||||
RecoveryTranslogOperationsResponse::new, ThreadPool.Names.GENERIC));
|
RecoveryTranslogOperationsResponse::new, ThreadPool.Names.GENERIC));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -187,7 +187,7 @@ public class RemoteRecoveryTargetHandler implements RecoveryTargetHandler {
|
||||||
* would be in to restart file copy again (new deltas) if we have too many translog ops are piling up.
|
* would be in to restart file copy again (new deltas) if we have too many translog ops are piling up.
|
||||||
*/
|
*/
|
||||||
throttleTimeInNanos), fileChunkRequestOptions, new ActionListenerResponseHandler<>(
|
throttleTimeInNanos), fileChunkRequestOptions, new ActionListenerResponseHandler<>(
|
||||||
ActionListener.wrap(r -> listener.onResponse(null), listener::onFailure), in -> TransportResponse.Empty.INSTANCE));
|
ActionListener.map(listener, r -> null), in -> TransportResponse.Empty.INSTANCE));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -68,8 +68,7 @@ public class PersistentTasksService {
|
||||||
final Params taskParams,
|
final Params taskParams,
|
||||||
final ActionListener<PersistentTask<Params>> listener) {
|
final ActionListener<PersistentTask<Params>> listener) {
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
final ActionListener<PersistentTask<?>> wrappedListener =
|
final ActionListener<PersistentTask<?>> wrappedListener = ActionListener.map(listener, t -> (PersistentTask<Params>) t);
|
||||||
ActionListener.wrap(t -> listener.onResponse((PersistentTask<Params>) t), listener::onFailure);
|
|
||||||
StartPersistentTaskAction.Request request = new StartPersistentTaskAction.Request(taskId, taskName, taskParams);
|
StartPersistentTaskAction.Request request = new StartPersistentTaskAction.Request(taskId, taskName, taskParams);
|
||||||
execute(request, StartPersistentTaskAction.INSTANCE, wrappedListener);
|
execute(request, StartPersistentTaskAction.INSTANCE, wrappedListener);
|
||||||
}
|
}
|
||||||
|
@ -132,8 +131,7 @@ public class PersistentTasksService {
|
||||||
private <Req extends ActionRequest, Resp extends PersistentTaskResponse>
|
private <Req extends ActionRequest, Resp extends PersistentTaskResponse>
|
||||||
void execute(final Req request, final Action<Resp> action, final ActionListener<PersistentTask<?>> listener) {
|
void execute(final Req request, final Action<Resp> action, final ActionListener<PersistentTask<?>> listener) {
|
||||||
try {
|
try {
|
||||||
client.execute(action, request,
|
client.execute(action, request, ActionListener.map(listener, PersistentTaskResponse::getTask));
|
||||||
ActionListener.wrap(r -> listener.onResponse(r.getTask()), listener::onFailure));
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
listener.onFailure(e);
|
listener.onFailure(e);
|
||||||
}
|
}
|
||||||
|
|
|
@ -2622,12 +2622,10 @@ public class IndexShardTests extends IndexShardTestCase {
|
||||||
maxAutoIdTimestamp,
|
maxAutoIdTimestamp,
|
||||||
maxSeqNoOfUpdatesOrDeletes,
|
maxSeqNoOfUpdatesOrDeletes,
|
||||||
retentionLeases,
|
retentionLeases,
|
||||||
ActionListener.wrap(
|
ActionListener.map(listener, checkpoint -> {
|
||||||
checkpoint -> {
|
assertListenerCalled.accept(replica);
|
||||||
assertListenerCalled.accept(replica);
|
return checkpoint;
|
||||||
listener.onResponse(checkpoint);
|
}));
|
||||||
},
|
|
||||||
listener::onFailure));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
Loading…
Reference in New Issue