[
https://issues.apache.org/jira/browse/UNOMI-745?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Jonathan Sinovassin-Naïk reassigned UNOMI-745:
----------------------------------------------
Assignee: Jonathan Sinovassin-Naïk
> Issue with rule optimization based on event types on unomi 1_x versions
> -----------------------------------------------------------------------
>
> Key: UNOMI-745
> URL: https://issues.apache.org/jira/browse/UNOMI-745
> Project: Apache Unomi
> Issue Type: Bug
> Affects Versions: unomi-1.6.0, unomi-1.6.1, unomi-1.7.0, unomi-1.8.0,
> unomi-1.7.1
> Reporter: Kevan Jahanshahi
> Assignee: Jonathan Sinovassin-Naïk
> Priority: Major
>
> If for any reason you deploy a rule containing a wrong conditionType, the
> refreshing system is broken:
> {code:java}
> 4851 2023-03-08T11:22:10,378 | ERROR | pool-16-thread-1 | RulesServiceImpl
> | 234 - org.apache.unomi.services - 1.6.1 | Error loading
> rules from persistence back-end
> 4852 java.lang.NullPointerException: null
> 4853 at
> org.apache.unomi.services.impl.ParserHelper$EventTypeConditionVisitor.visit(ParserHelper.java:193)
> ~[!/:?]
> 4854 at
> org.apache.unomi.services.impl.ParserHelper.visitConditions(ParserHelper.java:90)
> ~[!/:?]
> 4855 at
> org.apache.unomi.services.impl.ParserHelper.visitConditions(ParserHelper.java:102)
> ~[!/:?]
> 4856 at
> org.apache.unomi.services.impl.ParserHelper.resolveConditionEventTypes(ParserHelper.java:169)
> ~[!/:?]
> 4857 at
> org.apache.unomi.services.impl.rules.RulesServiceImpl.updateRulesByEventType(RulesServiceImpl.java:599)
> ~[!/:?]
> 4858 at
> org.apache.unomi.services.impl.rules.RulesServiceImpl.getRulesByEventType(RulesServiceImpl.java:304)
> ~[!/:?]
> 4859 at
> org.apache.unomi.services.impl.rules.RulesServiceImpl.refreshRules(RulesServiceImpl.java:277)
> [!/:?]
> 4860 at
> org.apache.unomi.services.impl.rules.RulesServiceImpl$1.run(RulesServiceImpl.java:480)
> [!/:?]
> 4861 at
> java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:515) [?:?]
> 4862 at
> java.util.concurrent.FutureTask.runAndReset(FutureTask.java:305) [?:?]
> 4863 at
> java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:305)
> [?:?]
> 4864 at
> java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1128)
> [?:?]
> 4865 at
> java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:628)
> [?:?]
> 4866 at java.lang.Thread.run(Thread.java:829) [?:?]{code}
> The issue is in the ParserHelper:
> [https://github.com/apache/unomi/blob/unomi-root-1.6.1/services/src/main/java/org/apache/unomi/services/impl/ParserHelper.java#L193]
> Introduce by: https://issues.apache.org/jira/browse/UNOMI-188
> ([https://github.com/apache/unomi/pull/321])
>
> code on 1.x:
> {code:java}
> if (condition.getConditionType().getParentCondition() != null) {
> visitConditions(condition.getConditionType().getParentCondition(), this);
> } {code}
> Sad story, it have been fixed in master without any ticket and explanation
> for something completely unrelated
> (https://issues.apache.org/jira/browse/UNOMI-486,
> [https://github.com/apache/unomi/pull/387]):
> {code:java}
> if (condition.getConditionType() != null &&
> condition.getConditionType().getParentCondition() != null) {
> visitConditions(condition.getConditionType().getParentCondition(), this);
> } {code}
--
This message was sent by Atlassian Jira
(v8.20.10#820010)