Skip to content

Commit

Permalink
merge: #932
Browse files Browse the repository at this point in the history
932: Backport 876 stable/8.3 r=nicpuppa a=remcowesterhoud

#876 

Co-authored-by: Remco Westerhoud <[email protected]>
  • Loading branch information
zeebe-bors-camunda[bot] and remcowesterhoud authored Oct 11, 2023
2 parents 87f461a + 5dc9f5f commit bde06f3
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -100,6 +100,7 @@ public InMemoryDbIterator newIterator() {
final TreeMap<Bytes, Bytes> snapshot = new TreeMap<>();
snapshot.putAll(database);
snapshot.putAll(transactionCache);
deletedKeys.forEach(snapshot::remove);

return new InMemoryDbIterator(snapshot);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
package io.camunda.zeebe.process.test.engine.db;

import static org.assertj.core.api.Assertions.assertThat;
import static org.assertj.core.api.Assertions.fail;

import io.camunda.zeebe.db.ColumnFamily;
import io.camunda.zeebe.db.TransactionContext;
Expand Down Expand Up @@ -492,6 +493,25 @@ void shouldWriteKeyAfterDeletion() {
assertThat(oneColumnFamily.get(oneKey).getValue()).isEqualTo(-2);
}

@Test
void shouldNotIterateOverDeletionsInTransaction() throws Exception {
// given
oneKey.wrapLong(1);
oneValue.wrapLong(-1L);
oneColumnFamily.insert(oneKey, oneValue);
transactionContext.getCurrentTransaction().commit();

// when - then
transactionContext.runInTransaction(
() -> {
oneColumnFamily.deleteExisting(oneKey);
oneColumnFamily.forEach(
(key, value) -> {
fail("Should not iterate over deleted keys");
});
});
}

private enum ColumnFamilies {
DEFAULT, // rocksDB needs a default column family
ONE,
Expand Down

0 comments on commit bde06f3

Please sign in to comment.