[
https://issues.apache.org/jira/browse/IGNITE-18687?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Evgeny Stanilovsky updated IGNITE-18687:
----------------------------------------
Fix Version/s: 3.2
(was: 3.1)
> Fix TableManager#dropTableLocally
> ---------------------------------
>
> Key: IGNITE-18687
> URL: https://issues.apache.org/jira/browse/IGNITE-18687
> Project: Ignite
> Issue Type: Bug
> Reporter: Kirill Tkalenko
> Priority: Major
> Labels: ignite-3
> Fix For: 3.2
>
>
> It was found that if in
> *org.apache.ignite.internal.table.distributed.TableManager#dropTableLocally*
> the destruction of tables is completed in another thread not synchronously,
> then we failed on *fireEvent* *TableEvent.DROP* with error:
> {noformat}
> java.util.concurrent.CompletionException: java.lang.AssertionError: Token
> must be greater than actual [token=9, actual=9]
> at
> java.base/java.util.concurrent.CompletableFuture.encodeThrowable(CompletableFuture.java:314)
> at
> java.base/java.util.concurrent.CompletableFuture.completeThrowable(CompletableFuture.java:319)
> at
> java.base/java.util.concurrent.CompletableFuture$UniRun.tryFire$$$capture(CompletableFuture.java:787)
> at
> java.base/java.util.concurrent.CompletableFuture$UniRun.tryFire(CompletableFuture.java)
> at
> java.base/java.util.concurrent.CompletableFuture.postComplete(CompletableFuture.java:506)
> at
> java.base/java.util.concurrent.CompletableFuture.complete(CompletableFuture.java:2073)
> at
> org.apache.ignite.internal.causality.VersionedValue.completeInternal(VersionedValue.java:335)
> at
> org.apache.ignite.internal.causality.VersionedValue.lambda$completeOnRevision$3(VersionedValue.java:493)
> at
> java.base/java.util.concurrent.CompletableFuture.uniWhenComplete(CompletableFuture.java:859)
> at
> java.base/java.util.concurrent.CompletableFuture.uniWhenCompleteStage(CompletableFuture.java:883)
> at
> java.base/java.util.concurrent.CompletableFuture.whenComplete(CompletableFuture.java:2251)
> at
> org.apache.ignite.internal.causality.VersionedValue.completeOnRevision(VersionedValue.java:493)
> at
> org.apache.ignite.internal.causality.VersionedValue.complete(VersionedValue.java:268)
> at
> org.apache.ignite.internal.table.distributed.TableManager.lambda$new$1(TableManager.java:396)
> at
> java.base/java.util.concurrent.CompletableFuture.uniWhenComplete(CompletableFuture.java:859)
> at
> java.base/java.util.concurrent.CompletableFuture$UniWhenComplete.tryFire(CompletableFuture.java:837)
> at
> java.base/java.util.concurrent.CompletableFuture.postComplete(CompletableFuture.java:506)
> at
> java.base/java.util.concurrent.CompletableFuture$AsyncRun.run$$$capture(CompletableFuture.java:1742)
> at
> java.base/java.util.concurrent.CompletableFuture$AsyncRun.run(CompletableFuture.java)
> at
> java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1128)
> at
> java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:628)
> at java.base/java.lang.Thread.run(Thread.java:834)
> Caused by: java.lang.AssertionError: Token must be greater than actual
> [token=9, actual=9]
> at
> org.apache.ignite.internal.causality.VersionedValue.checkToken(VersionedValue.java:597)
> at
> org.apache.ignite.internal.causality.VersionedValue.update(VersionedValue.java:403)
> at
> org.apache.ignite.internal.sql.engine.schema.SqlSchemaManagerImpl.onIndexDropped(SqlSchemaManagerImpl.java:466)
> at
> org.apache.ignite.internal.sql.engine.SqlQueryProcessor$IndexDroppedListener.notify(SqlQueryProcessor.java:637)
> at
> org.apache.ignite.internal.sql.engine.SqlQueryProcessor$IndexDroppedListener.notify(SqlQueryProcessor.java:629)
> at
> org.apache.ignite.internal.manager.Producer.fireEvent(Producer.java:108)
> at
> org.apache.ignite.internal.index.IndexManager.lambda$onIndexDrop$8(IndexManager.java:340)
> at
> java.base/java.util.concurrent.CompletableFuture$UniRun.tryFire$$$capture(CompletableFuture.java:783)
> ... 19 more
> {noformat}
--
This message was sent by Atlassian Jira
(v8.20.10#820010)