[ https://issues.apache.org/jira/browse/IGNITE-16585 ]


    Vyacheslav Koptilin deleted comment on IGNITE-16585:
    ----------------------------------------------

was (Author: slava.koptilin):
The fix is already available under IGNITE-16010

> NPE during exception handling in DelegatingStateMachine
> -------------------------------------------------------
>
>                 Key: IGNITE-16585
>                 URL: https://issues.apache.org/jira/browse/IGNITE-16585
>             Project: Ignite
>          Issue Type: Bug
>            Reporter: Konstantin Orlov
>            Assignee: Mirza Aliev
>            Priority: Major
>              Labels: ignite-3
>
> Exception handling in 
> {{org.apache.ignite.internal.raft.server.impl.JraftServerImpl.DelegatingStateMachine#onApply}}
>  can't handle an exceptions witout a message. The problem is caused by 
> constructor method of the {{org.apache.ignite.raft.jraft.Status}} class which 
> uses a passed message as a template and tries to render it without any null 
> checking. This results in another NPE (stacktrace is shown below) that hides 
> the original one.
> {code:java}
> 2022-02-18 17:45:26:311 +0300 
> [ERROR][%ItIndexDdlTest_null_2%JRaft-FSMCaller-Disruptor-_stripe_19-0][StripedDisruptor]
>  Handle disruptor event error 
> [name=%ItIndexDdlTest_null_2%JRaft-FSMCaller-Disruptor-, 
> event=org.apache.ignite.raft.jraft.core.FSMCallerImpl$ApplyTask@72ea5694, 
> hasHandler=false]
> java.lang.NullPointerException
>       at java.base/java.util.regex.Matcher.getTextLength(Matcher.java:1770)
>       at java.base/java.util.regex.Matcher.reset(Matcher.java:416)
>       at java.base/java.util.regex.Matcher.<init>(Matcher.java:253)
>       at java.base/java.util.regex.Pattern.matcher(Pattern.java:1133)
>       at java.base/java.util.Formatter.parse(Formatter.java:2700)
>       at java.base/java.util.Formatter.format(Formatter.java:2655)
>       at java.base/java.util.Formatter.format(Formatter.java:2609)
>       at java.base/java.lang.String.format(String.java:2897)
>       at org.apache.ignite.raft.jraft.Status.<init>(Status.java:108)
>       at 
> org.apache.ignite.internal.raft.server.impl.JraftServerImpl$DelegatingStateMachine.onApply(JraftServerImpl.java:445)
>       at 
> org.apache.ignite.raft.jraft.core.FSMCallerImpl.doApplyTasks(FSMCallerImpl.java:539)
>       at 
> org.apache.ignite.raft.jraft.core.FSMCallerImpl.doCommitted(FSMCallerImpl.java:507)
>       at 
> org.apache.ignite.raft.jraft.core.FSMCallerImpl.runApplyTask(FSMCallerImpl.java:437)
>       at 
> org.apache.ignite.raft.jraft.core.FSMCallerImpl$ApplyTaskHandler.onEvent(FSMCallerImpl.java:134)
>       at 
> org.apache.ignite.raft.jraft.core.FSMCallerImpl$ApplyTaskHandler.onEvent(FSMCallerImpl.java:128)
>       at 
> org.apache.ignite.raft.jraft.disruptor.StripedDisruptor$StripeEntryHandler.onEvent(StripedDisruptor.java:215)
>       at 
> org.apache.ignite.raft.jraft.disruptor.StripedDisruptor$StripeEntryHandler.onEvent(StripedDisruptor.java:179)
>       at 
> com.lmax.disruptor.BatchEventProcessor.run(BatchEventProcessor.java:137)
>       at java.base/java.lang.Thread.run(Thread.java:834)
> {code}



--
This message was sent by Atlassian Jira
(v8.20.1#820001)

Reply via email to