vamossagar12 commented on a change in pull request #11211: URL: https://github.com/apache/kafka/pull/11211#discussion_r704335821
########## File path: streams/src/main/java/org/apache/kafka/streams/state/internals/MeteredWindowStore.java ########## @@ -292,13 +408,46 @@ public V fetch(final K key, time); } + private long getActualWindowStartTime(final long timeFrom) { + return Math.max(timeFrom, ((PersistentWindowStore<Bytes, byte[]>) wrapped()).getObservedStreamTime() - retentionPeriod + 1); + } + + private KeyValueIterator<Windowed<K>, V> filterExpiredRecords(final boolean forward) { + final KeyValueIterator<Windowed<Bytes>, byte[]> allWindowedKeyValueIterator = forward ? wrapped().all() : wrapped().backwardAll(); + + final long observedStreamTime = ((PersistentWindowStore<Bytes, byte[]>) wrapped()).getObservedStreamTime(); + if (!allWindowedKeyValueIterator.hasNext() || observedStreamTime == ConsumerRecord.NO_TIMESTAMP) + return new MeteredWindowedKeyValueIterator<>(allWindowedKeyValueIterator, fetchSensor, streamsMetrics, serdes, time); + + final long windowStartBoundary = observedStreamTime - retentionPeriod + 1; + final List<KeyValue<Windowed<Bytes>, byte[]>> windowedKeyValuesInBoundary = new ArrayList<>(); + + while (allWindowedKeyValueIterator.hasNext()) { + final KeyValue<Windowed<Bytes>, byte[]> next = allWindowedKeyValueIterator.next(); + if (next.key.window().endTime().isBefore(Instant.ofEpochMilli(windowStartBoundary))) { + continue; + } + windowedKeyValuesInBoundary.add(next); + } + return new MeteredWindowedKeyValueIterator<>(new WindowedKeyValueIterator(windowedKeyValuesInBoundary.iterator()), fetchSensor, streamsMetrics, serdes, time); + } Review comment: hey.. let me know what you guys think about the above comment of mine. Based upon that, I will proceed with fixing the issue with the test case(which doesn't seem possible with the way I have implemented). -- This is an automated message from the Apache Git Service. To respond to the message, please log on to GitHub and use the URL above to go to the specific comment. To unsubscribe, e-mail: jira-unsubscr...@kafka.apache.org For queries about this service, please contact Infrastructure at: us...@infra.apache.org