|  | @@ -50,6 +50,10 @@ public class AggregationOperator implements Operator {
 | 
											
												
													
														|  |       * Nanoseconds this operator has spent running the aggregations.
 |  |       * Nanoseconds this operator has spent running the aggregations.
 | 
											
												
													
														|  |       */
 |  |       */
 | 
											
												
													
														|  |      private long aggregationNanos;
 |  |      private long aggregationNanos;
 | 
											
												
													
														|  | 
 |  | +    /**
 | 
											
												
													
														|  | 
 |  | +     * Nanoseconds this operator has spent running the aggregations final evaluation.
 | 
											
												
													
														|  | 
 |  | +     */
 | 
											
												
													
														|  | 
 |  | +    private long aggregationFinishNanos;
 | 
											
												
													
														|  |      /**
 |  |      /**
 | 
											
												
													
														|  |       * Count of pages this operator has processed.
 |  |       * Count of pages this operator has processed.
 | 
											
												
													
														|  |       */
 |  |       */
 | 
											
										
											
												
													
														|  | @@ -117,6 +121,7 @@ public class AggregationOperator implements Operator {
 | 
											
												
													
														|  |          if (finished) {
 |  |          if (finished) {
 | 
											
												
													
														|  |              return;
 |  |              return;
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  | 
 |  | +        long start = System.nanoTime();
 | 
											
												
													
														|  |          finished = true;
 |  |          finished = true;
 | 
											
												
													
														|  |          Block[] blocks = null;
 |  |          Block[] blocks = null;
 | 
											
												
													
														|  |          boolean success = false;
 |  |          boolean success = false;
 | 
											
										
											
												
													
														|  | @@ -136,6 +141,7 @@ public class AggregationOperator implements Operator {
 | 
											
												
													
														|  |              if (success == false && blocks != null) {
 |  |              if (success == false && blocks != null) {
 | 
											
												
													
														|  |                  Releasables.closeExpectNoException(blocks);
 |  |                  Releasables.closeExpectNoException(blocks);
 | 
											
												
													
														|  |              }
 |  |              }
 | 
											
												
													
														|  | 
 |  | +            aggregationFinishNanos += System.nanoTime() - start;
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -175,7 +181,7 @@ public class AggregationOperator implements Operator {
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      @Override
 |  |      @Override
 | 
											
												
													
														|  |      public Operator.Status status() {
 |  |      public Operator.Status status() {
 | 
											
												
													
														|  | -        return new Status(aggregationNanos, pagesProcessed);
 |  | 
 | 
											
												
													
														|  | 
 |  | +        return new Status(aggregationNanos, aggregationFinishNanos, pagesProcessed);
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      public static class Status implements Operator.Status {
 |  |      public static class Status implements Operator.Status {
 | 
											
										
											
												
													
														|  | @@ -189,6 +195,11 @@ public class AggregationOperator implements Operator {
 | 
											
												
													
														|  |           * Nanoseconds this operator has spent running the aggregations.
 |  |           * Nanoseconds this operator has spent running the aggregations.
 | 
											
												
													
														|  |           */
 |  |           */
 | 
											
												
													
														|  |          private final long aggregationNanos;
 |  |          private final long aggregationNanos;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +        /**
 | 
											
												
													
														|  | 
 |  | +         * Nanoseconds this operator has spent running the aggregations final evaluation.
 | 
											
												
													
														|  | 
 |  | +         */
 | 
											
												
													
														|  | 
 |  | +        private final Long aggregationFinishNanos;
 | 
											
												
													
														|  |          /**
 |  |          /**
 | 
											
												
													
														|  |           * Count of pages this operator has processed.
 |  |           * Count of pages this operator has processed.
 | 
											
												
													
														|  |           */
 |  |           */
 | 
											
										
											
												
													
														|  | @@ -197,21 +208,31 @@ public class AggregationOperator implements Operator {
 | 
											
												
													
														|  |          /**
 |  |          /**
 | 
											
												
													
														|  |           * Build.
 |  |           * Build.
 | 
											
												
													
														|  |           * @param aggregationNanos Nanoseconds this operator has spent running the aggregations.
 |  |           * @param aggregationNanos Nanoseconds this operator has spent running the aggregations.
 | 
											
												
													
														|  | 
 |  | +         * @param aggregationFinishNanos Nanoseconds this operator has spent running the aggregations.
 | 
											
												
													
														|  |           * @param pagesProcessed Count of pages this operator has processed.
 |  |           * @param pagesProcessed Count of pages this operator has processed.
 | 
											
												
													
														|  |           */
 |  |           */
 | 
											
												
													
														|  | -        public Status(long aggregationNanos, int pagesProcessed) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +        public Status(long aggregationNanos, long aggregationFinishNanos, int pagesProcessed) {
 | 
											
												
													
														|  |              this.aggregationNanos = aggregationNanos;
 |  |              this.aggregationNanos = aggregationNanos;
 | 
											
												
													
														|  | 
 |  | +            this.aggregationFinishNanos = aggregationFinishNanos;
 | 
											
												
													
														|  |              this.pagesProcessed = pagesProcessed;
 |  |              this.pagesProcessed = pagesProcessed;
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          protected Status(StreamInput in) throws IOException {
 |  |          protected Status(StreamInput in) throws IOException {
 | 
											
												
													
														|  |              aggregationNanos = in.readVLong();
 |  |              aggregationNanos = in.readVLong();
 | 
											
												
													
														|  | 
 |  | +            if (in.getTransportVersion().onOrAfter(TransportVersions.ESQL_AGGREGATION_OPERATOR_STATUS_FINISH_NANOS)) {
 | 
											
												
													
														|  | 
 |  | +                aggregationFinishNanos = in.readOptionalVLong();
 | 
											
												
													
														|  | 
 |  | +            } else {
 | 
											
												
													
														|  | 
 |  | +                aggregationFinishNanos = null;
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  |              pagesProcessed = in.readVInt();
 |  |              pagesProcessed = in.readVInt();
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          @Override
 |  |          @Override
 | 
											
												
													
														|  |          public void writeTo(StreamOutput out) throws IOException {
 |  |          public void writeTo(StreamOutput out) throws IOException {
 | 
											
												
													
														|  |              out.writeVLong(aggregationNanos);
 |  |              out.writeVLong(aggregationNanos);
 | 
											
												
													
														|  | 
 |  | +            if (out.getTransportVersion().onOrAfter(TransportVersions.ESQL_AGGREGATION_OPERATOR_STATUS_FINISH_NANOS)) {
 | 
											
												
													
														|  | 
 |  | +                out.writeOptionalVLong(aggregationFinishNanos);
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  |              out.writeVInt(pagesProcessed);
 |  |              out.writeVInt(pagesProcessed);
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -227,6 +248,13 @@ public class AggregationOperator implements Operator {
 | 
											
												
													
														|  |              return aggregationNanos;
 |  |              return aggregationNanos;
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +        /**
 | 
											
												
													
														|  | 
 |  | +         * Nanoseconds this operator has spent running the aggregations final evaluation.
 | 
											
												
													
														|  | 
 |  | +         */
 | 
											
												
													
														|  | 
 |  | +        public long aggregationFinishNanos() {
 | 
											
												
													
														|  | 
 |  | +            return aggregationFinishNanos;
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |          /**
 |  |          /**
 | 
											
												
													
														|  |           * Count of pages this operator has processed.
 |  |           * Count of pages this operator has processed.
 | 
											
												
													
														|  |           */
 |  |           */
 | 
											
										
											
												
													
														|  | @@ -241,6 +269,13 @@ public class AggregationOperator implements Operator {
 | 
											
												
													
														|  |              if (builder.humanReadable()) {
 |  |              if (builder.humanReadable()) {
 | 
											
												
													
														|  |                  builder.field("aggregation_time", TimeValue.timeValueNanos(aggregationNanos));
 |  |                  builder.field("aggregation_time", TimeValue.timeValueNanos(aggregationNanos));
 | 
											
												
													
														|  |              }
 |  |              }
 | 
											
												
													
														|  | 
 |  | +            builder.field("aggregation_finish_nanos", aggregationFinishNanos);
 | 
											
												
													
														|  | 
 |  | +            if (builder.humanReadable()) {
 | 
											
												
													
														|  | 
 |  | +                builder.field(
 | 
											
												
													
														|  | 
 |  | +                    "aggregation_finish_time",
 | 
											
												
													
														|  | 
 |  | +                    aggregationFinishNanos == null ? null : TimeValue.timeValueNanos(aggregationFinishNanos)
 | 
											
												
													
														|  | 
 |  | +                );
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  |              builder.field("pages_processed", pagesProcessed);
 |  |              builder.field("pages_processed", pagesProcessed);
 | 
											
												
													
														|  |              return builder.endObject();
 |  |              return builder.endObject();
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -251,12 +286,14 @@ public class AggregationOperator implements Operator {
 | 
											
												
													
														|  |              if (this == o) return true;
 |  |              if (this == o) return true;
 | 
											
												
													
														|  |              if (o == null || getClass() != o.getClass()) return false;
 |  |              if (o == null || getClass() != o.getClass()) return false;
 | 
											
												
													
														|  |              Status status = (Status) o;
 |  |              Status status = (Status) o;
 | 
											
												
													
														|  | -            return aggregationNanos == status.aggregationNanos && pagesProcessed == status.pagesProcessed;
 |  | 
 | 
											
												
													
														|  | 
 |  | +            return aggregationNanos == status.aggregationNanos
 | 
											
												
													
														|  | 
 |  | +                && pagesProcessed == status.pagesProcessed
 | 
											
												
													
														|  | 
 |  | +                && Objects.equals(aggregationFinishNanos, status.aggregationFinishNanos);
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          @Override
 |  |          @Override
 | 
											
												
													
														|  |          public int hashCode() {
 |  |          public int hashCode() {
 | 
											
												
													
														|  | -            return Objects.hash(aggregationNanos, pagesProcessed);
 |  | 
 | 
											
												
													
														|  | 
 |  | +            return Objects.hash(aggregationNanos, aggregationFinishNanos, pagesProcessed);
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          @Override
 |  |          @Override
 |