Skip to content

Commit

Permalink
Merge pull request #959: [proxima-direct-core] fix LocalCachedPartiti…
Browse files Browse the repository at this point in the history
…onedView.scanWildcard off-by-one error
  • Loading branch information
je-ik authored Jan 30, 2025
2 parents 509954d + 2eecb3b commit 0897299
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -341,7 +341,7 @@ private void scanWildcardPrefix(
(attr, e) -> {
KeyValue<Object> kv = toKv(key, attr, e);
if (kv != null) {
if (missing.decrementAndGet() != 0) {
if (missing.getAndDecrement() != 0) {
consumer.accept(kv);
} else {
return false;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -206,6 +206,29 @@ public void testScanWildcardWithDelete() {
assertEquals(1, kvs.size());
}

@Test
public void testScanWildcardWithLimit() {
view.assign(singlePartition());
writer.write(update("key", "device.1", device, now), (succ, exc) -> {});
writer.write(update("key", "device.2", device, now + 1), (succ, exc) -> {});
List<KeyValue<?>> kvs = new ArrayList<>();
view.scanWildcard("key", device, now, kvs::add);
assertEquals(1, kvs.size());
kvs.clear();
view.scanWildcard(
"key",
device,
view.fetchOffset(Listing.ATTRIBUTE, device.toAttributePrefix()),
now + 1,
1,
kvs::add);
assertEquals(1, kvs.size());
view.scanWildcard("key", device, kvs.get(0).getOffset(), now + 1, 1, kvs::add);
assertEquals(2, kvs.size());
assertEquals("device.1", kvs.get(0).getAttribute());
assertEquals("device.2", kvs.get(1).getAttribute());
}

@Test
public void testScanWildcardAllWithDelete() {
view.assign(singlePartition());
Expand Down

0 comments on commit 0897299

Please sign in to comment.