[ 
https://issues.apache.org/jira/browse/CASSANDRA-20992?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Stefan Miklosovic updated CASSANDRA-20992:
------------------------------------------
          Fix Version/s: 5.1
                             (was: 5.x)
          Since Version: NA
    Source Control Link: 
https://github.com/apache/cassandra/commit/9142d0c8519944e02b3d449b21c3b42ab80caeb6
             Resolution: Fixed
                 Status: Resolved  (was: Ready to Commit)

> Fix ExceptionsTable when stacktrace has zero elements
> -----------------------------------------------------
>
>                 Key: CASSANDRA-20992
>                 URL: https://issues.apache.org/jira/browse/CASSANDRA-20992
>             Project: Apache Cassandra
>          Issue Type: Bug
>          Components: Feature/Virtual Tables
>            Reporter: Stefan Miklosovic
>            Assignee: Stefan Miklosovic
>            Priority: Normal
>             Fix For: 5.1
>
>          Time Spent: 20m
>  Remaining Estimate: 0h
>
> I saw this in one of pre-ci runs:
> {code}
> 02:01:57  [junit-timeout] ERROR [Reconcile:2] <main> 2025-10-30T02:01:57,672 
> ExecutionFailure.java:77 - Unexpected error while handling unexpected error
> 02:01:57  [junit-timeout] java.lang.IndexOutOfBoundsException: Index 0 out of 
> bounds for length 0
> 02:01:57  [junit-timeout]     at 
> java.base/jdk.internal.util.Preconditions.outOfBounds(Preconditions.java:64)
> 02:01:57  [junit-timeout]     at 
> java.base/jdk.internal.util.Preconditions.outOfBoundsCheckIndex(Preconditions.java:70)
> 02:01:57  [junit-timeout]     at 
> java.base/jdk.internal.util.Preconditions.checkIndex(Preconditions.java:248)
> 02:01:57  [junit-timeout]     at 
> java.base/java.util.Objects.checkIndex(Objects.java:374)
> 02:01:57  [junit-timeout]     at 
> java.base/java.util.ArrayList.get(ArrayList.java:459)
> 02:01:57  [junit-timeout]     at 
> org.apache.cassandra.db.virtual.ExceptionsTable.persist(ExceptionsTable.java:182)
> 02:01:57  [junit-timeout]     at 
> org.apache.cassandra.utils.JVMStabilityInspector.uncaughtException(JVMStabilityInspector.java:74)
> 02:01:57  [junit-timeout]     at 
> org.apache.cassandra.concurrent.ExecutionFailure.handle(ExecutionFailure.java:72)
> 02:01:57  [junit-timeout]     at 
> org.apache.cassandra.concurrent.ExecutionFailure$1.run(ExecutionFailure.java:142)
> 02:01:57  [junit-timeout]     at 
> java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1128)
> 02:01:57  [junit-timeout]     at 
> java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:628)
> 02:01:57  [junit-timeout]     at 
> io.netty.util.concurrent.FastThreadLocalRunnable.run(FastThreadLocalRunnable.java:30)
> {code}
> That is because we do "stackTrace.get(0)" in 
> ExceptionsTable.persist(Throwable) and there is wrong assumption that 
> stacktrace will always have some elements but it might be actually also empty.



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to