Don't reduce twice if failure occurs.
This commit is contained in:
parent
020e68f2a0
commit
a09f217b45
|
@ -203,7 +203,12 @@ public class TransportMultiPercolateAction extends TransportAction<MultiPercolat
|
||||||
|
|
||||||
assert expectedOperationsPerItem[item.slot()].get() >= 1;
|
assert expectedOperationsPerItem[item.slot()].get() >= 1;
|
||||||
if (expectedOperationsPerItem[item.slot()].decrementAndGet() == 0) {
|
if (expectedOperationsPerItem[item.slot()].decrementAndGet() == 0) {
|
||||||
|
try {
|
||||||
reduce(item.slot(), percolateRequests, expectedOperations, reducedResponses, listener, responsesByItemAndShard);
|
reduce(item.slot(), percolateRequests, expectedOperations, reducedResponses, listener, responsesByItemAndShard);
|
||||||
|
} catch (Throwable t) {
|
||||||
|
// Don't let any failure bubble up, otherwise expectedOperationsPerItem will be decremented twice
|
||||||
|
listener.onFailure(t);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} catch (Throwable e) {
|
} catch (Throwable e) {
|
||||||
|
@ -225,7 +230,7 @@ public class TransportMultiPercolateAction extends TransportAction<MultiPercolat
|
||||||
}
|
}
|
||||||
|
|
||||||
shardResults.set(shardId.id(), new BroadcastShardOperationFailedException(shardId, e));
|
shardResults.set(shardId.id(), new BroadcastShardOperationFailedException(shardId, e));
|
||||||
assert expectedOperationsPerItem[slot].get() >= 1;
|
assert expectedOperationsPerItem[slot].get() >= 1 : "Caused by: " + e.getMessage();
|
||||||
if (expectedOperationsPerItem[slot].decrementAndGet() == 0) {
|
if (expectedOperationsPerItem[slot].decrementAndGet() == 0) {
|
||||||
reduce(slot, percolateRequests, expectedOperations, reducedResponses, listener, responsesByItemAndShard);
|
reduce(slot, percolateRequests, expectedOperations, reducedResponses, listener, responsesByItemAndShard);
|
||||||
}
|
}
|
||||||
|
|
|
@ -363,6 +363,7 @@ public class RecoveryPercolatorTests extends AbstractNodesTests {
|
||||||
for (MultiPercolateResponse.Item item : response) {
|
for (MultiPercolateResponse.Item item : response) {
|
||||||
assertThat(item.isFailure(), equalTo(false));
|
assertThat(item.isFailure(), equalTo(false));
|
||||||
assertNoFailures(item.getResponse());
|
assertNoFailures(item.getResponse());
|
||||||
|
assertThat(item.getResponse().getSuccessfulShards(), equalTo(2));
|
||||||
assertThat(item.getResponse().getCount(), equalTo((long) numQueries));
|
assertThat(item.getResponse().getCount(), equalTo((long) numQueries));
|
||||||
assertThat(item.getResponse().getMatches().length, equalTo(numQueries));
|
assertThat(item.getResponse().getMatches().length, equalTo(numQueries));
|
||||||
}
|
}
|
||||||
|
@ -382,6 +383,7 @@ public class RecoveryPercolatorTests extends AbstractNodesTests {
|
||||||
.execute().actionGet();
|
.execute().actionGet();
|
||||||
}
|
}
|
||||||
assertNoFailures(response);
|
assertNoFailures(response);
|
||||||
|
assertThat(response.getSuccessfulShards(), equalTo(2));
|
||||||
assertThat(response.getCount(), equalTo((long) numQueries));
|
assertThat(response.getCount(), equalTo((long) numQueries));
|
||||||
assertThat(response.getMatches().length, equalTo(numQueries));
|
assertThat(response.getMatches().length, equalTo(numQueries));
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue