Skip to content

Commit

Permalink
Changed type for tookTime from long to Long, to address Sagar's comment
Browse files Browse the repository at this point in the history
  • Loading branch information
Peter Alfonsi committed Oct 26, 2023
1 parent a9ab327 commit a68f44e
Show file tree
Hide file tree
Showing 3 changed files with 30 additions and 22 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -88,7 +88,7 @@ public final class QuerySearchResult extends SearchPhaseResult {
private int nodeQueueSize = -1;

private final boolean isNull;
private long tookTimeNanos;
private Long tookTimeNanos = null;

public QuerySearchResult() {
this(false);
Expand Down Expand Up @@ -367,9 +367,9 @@ public void readFromWithId(ShardSearchContextId id, StreamInput in) throws IOExc
setShardSearchRequest(in.readOptionalWriteable(ShardSearchRequest::new));
setRescoreDocIds(new RescoreDocIds(in));
if (in.getVersion().onOrAfter(Version.V_3_0_0)) {
tookTimeNanos = in.readVLong();
tookTimeNanos = in.readOptionalLong();
} else {
tookTimeNanos = -1L;
tookTimeNanos = null;
}
}

Expand Down Expand Up @@ -414,7 +414,7 @@ public void writeToNoId(StreamOutput out) throws IOException {
out.writeOptionalWriteable(getShardSearchRequest());
getRescoreDocIds().writeTo(out);
if (out.getVersion().onOrAfter(Version.V_3_0_0)) {
out.writeVLong(tookTimeNanos); // VLong as took time should always be positive
out.writeOptionalLong(tookTimeNanos);
}
}

Expand All @@ -426,7 +426,7 @@ public float getMaxScore() {
return maxScore;
}

public long getTookTimeNanos() {
public Long getTookTimeNanos() {
return tookTimeNanos;
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1204,7 +1204,7 @@ public void testQuerySearchResultTookTime() throws IOException {

QueryPhase queryPhase = new QueryPhase(delayedQueryPhaseSearcher);
queryPhase.execute(searchContext);
long tookTime = searchContext.queryResult().getTookTimeNanos();
Long tookTime = searchContext.queryResult().getTookTimeNanos();
assertTrue(tookTime >= (long) sleepMillis * 1000000);
reader.close();
dir.close();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -99,27 +99,35 @@ private static QuerySearchResult createTestInstance() throws Exception {
if (randomBoolean()) {
result.aggregations(InternalAggregationsTests.createTestInstance());
}
assertEquals(0, result.getTookTimeNanos());
assertNull(result.getTookTimeNanos());
return result;
}

public void testSerialization() throws Exception {
QuerySearchResult querySearchResult = createTestInstance();
QuerySearchResult deserialized = copyWriteable(querySearchResult, namedWriteableRegistry, QuerySearchResult::new);
assertEquals(querySearchResult.getContextId().getId(), deserialized.getContextId().getId());
assertNull(deserialized.getSearchShardTarget());
assertEquals(querySearchResult.topDocs().maxScore, deserialized.topDocs().maxScore, 0f);
assertEquals(querySearchResult.topDocs().topDocs.totalHits, deserialized.topDocs().topDocs.totalHits);
assertEquals(querySearchResult.from(), deserialized.from());
assertEquals(querySearchResult.size(), deserialized.size());
assertEquals(querySearchResult.hasAggs(), deserialized.hasAggs());
if (deserialized.hasAggs()) {
Aggregations aggs = querySearchResult.consumeAggs().expand();
Aggregations deserializedAggs = deserialized.consumeAggs().expand();
assertEquals(aggs.asList(), deserializedAggs.asList());
for (int i = 0; i < 2; i++) {
QuerySearchResult querySearchResult = createTestInstance();
if (i == 0) {
querySearchResult.setTookTimeNanos(1000L); // test both an initialized and an uninitialized null value
}
QuerySearchResult deserialized = copyWriteable(querySearchResult, namedWriteableRegistry, QuerySearchResult::new);
assertEquals(querySearchResult.getContextId().getId(), deserialized.getContextId().getId());
assertNull(deserialized.getSearchShardTarget());
assertEquals(querySearchResult.topDocs().maxScore, deserialized.topDocs().maxScore, 0f);
assertEquals(querySearchResult.topDocs().topDocs.totalHits, deserialized.topDocs().topDocs.totalHits);
assertEquals(querySearchResult.from(), deserialized.from());
assertEquals(querySearchResult.size(), deserialized.size());
assertEquals(querySearchResult.hasAggs(), deserialized.hasAggs());
if (deserialized.hasAggs()) {
Aggregations aggs = querySearchResult.consumeAggs().expand();
Aggregations deserializedAggs = deserialized.consumeAggs().expand();
assertEquals(aggs.asList(), deserializedAggs.asList());
}
assertEquals(querySearchResult.terminatedEarly(), deserialized.terminatedEarly());
assertEquals(querySearchResult.getTookTimeNanos(), deserialized.getTookTimeNanos());
if (i == 1) {
assertNull(deserialized.getTookTimeNanos());
}
}
assertEquals(querySearchResult.terminatedEarly(), deserialized.terminatedEarly());
assertEquals(querySearchResult.getTookTimeNanos(), deserialized.getTookTimeNanos());
}

public void testNullResponse() throws Exception {
Expand Down

0 comments on commit a68f44e

Please sign in to comment.