[rules-users] NoClassDefFoundError when dynamically updating rulebase for rule using 'accumulate' CE

kunal kshah at sensorlogic.com
Wed Jun 11 09:59:51 EDT 2008


Yes, I just updated to 4.0.7 before couple of days. But I tried it out with
4.0.4 also with same results. So I don't think this is something introduced
in 4.0.7, but not sure.



Edson Tirelli-3 wrote:
> 
>       Are you using drools 4.0.7?
> 
>      []s
>      Edson
> 
> 2008/6/10 kunal <kshah at sensorlogic.com>:
> 
>>
>> I am dynamically adding/modifying rules (packages) to a loaded rule-base
>> and
>> having issues specifically when my rule contains accumulate CE. For an
>> example, following is a rule which I am trying to add to my rulebase
>> (which
>> is already loaded in memory).
>>
>> rule "7d7fa7f1-164b-45a7-8e5a-c0c260815f9a"
>>        enabled true
>>        salience 0
>>        no-loop true
>>        agenda-group "DATA_ARRIVAL"
>>        when
>>                AgentID(agentId : agentId);
>>                DeviceData()
>>
>>
>> Property(key=="threshold",classifier=="7d7fa7f1-164b-45a7-8e5a-c0c260815f9a.Condition0",$prop_threshold0
>> : value)
>>                $total0: Number( doubleValue > $prop_threshold0)   from
>> accumulate(
>> DataPoint( $value0: value ) from
>>
>> dataService.getDataPoints("5e0de623-9a25-45a1-8bc5-745254c2576e","SPEED",3),
>> average( $value0) )
>>        then
>>
>>  agent.handleAction("rules.sl.7d7fa7f1-164b-45a7-8e5a-c0c260815f9a",0);
>> end
>>
>> I am not getting any error (Rule validation or any other) when adding
>> package with my rule to rulebase, but when getting following error, when
>> rulebase is used thereafter:
>>
>> java.lang.NoClassDefFoundError:
>> rules/sl/Rule_7d7fa7f1_164b_45a7_8e5a_c0c260815f9a_0
>>        at
>>
>> rules.sl.Rule_7d7fa7f1_164b_45a7_8e5a_c0c260815f9a_0AccumulateExpression0Invoker.evaluate(Unknown
>> Source)
>>        at
>>
>> org.drools.base.accumulators.JavaAccumulatorFunctionExecutor.reverse(JavaAccumulatorFunctionExecutor.java:91)
>>        at org.drools.rule.Accumulate.reverse(Accumulate.java:151)
>>        at
>> org.drools.reteoo.AccumulateNode.modifyTuple(AccumulateNode.java:376)
>>        at
>> org.drools.reteoo.AccumulateNode.retractObject(AccumulateNode.java:292)
>>        at
>>
>> org.drools.reteoo.SingleObjectSinkAdapter.propagateRetractObject(SingleObjectSinkAdapter.java:32)
>>        at
>>
>> org.drools.reteoo.RightInputAdapterNode.retractTuple(RightInputAdapterNode.java:124)
>>        at
>>
>> org.drools.reteoo.SingleTupleSinkAdapter.propagateRetractTuple(SingleTupleSinkAdapter.java:38)
>>        at org.drools.reteoo.FromNode.retractTuple(FromNode.java:130)
>>        at
>>
>> org.drools.reteoo.CompositeTupleSinkAdapter.propagateRetractTuple(CompositeTupleSinkAdapter.java:52)
>>        at org.drools.reteoo.JoinNode.retractTuple(JoinNode.java:231)
>>        at
>>
>> org.drools.reteoo.CompositeTupleSinkAdapter.propagateRetractTuple(CompositeTupleSinkAdapter.java:52)
>>        at org.drools.reteoo.JoinNode.retractObject(JoinNode.java:191)
>>        at
>>
>> org.drools.reteoo.CompositeObjectSinkAdapter.propagateRetractObject(CompositeObjectSinkAdapter.java:375)
>>        at
>> org.drools.reteoo.ObjectTypeNode.retractObject(ObjectTypeNode.java:189)
>>        at org.drools.reteoo.Rete.retractObject(Rete.java:215)
>>        at
>> org.drools.reteoo.ReteooRuleBase.retractObject(ReteooRuleBase.java:211)
>>        at
>>
>> org.drools.reteoo.ReteooWorkingMemory.doRetract(ReteooWorkingMemory.java:79)
>>        at
>>
>> org.drools.common.AbstractWorkingMemory.retract(AbstractWorkingMemory.java:1023)
>>        at
>>
>> org.drools.common.AbstractWorkingMemory.retract(AbstractWorkingMemory.java:982)
>>        at
>> com.sensorlogic.rules.RuleAgent.retractMatchingFact(RuleAgent.java:283)
>>        at com.sensorlogic.rules.RuleAgent.processFact(RuleAgent.java:264)
>>        at com.sensorlogic.rules.RuleAgent.run(RuleAgent.java:342)
>>        at
>>
>> java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:650)
>>        at
>>
>> java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:675)
>>        at java.lang.Thread.run(Thread.java:595)
>>
>> I will appreciate any insight with this problem. My process of
>> adding/updating rules dynamically works with all other rules I am using
>> but
>> only has issues with using 'accumulate' CE. Has someone encountered this
>> before? Or just any ideas on what can cause NoClassDefFound for my added
>> rule?
>> --
>> View this message in context:
>> http://www.nabble.com/NoClassDefFoundError-when-dynamically-updating-rulebase-for-rule-using-%27accumulate%27-CE-tp17765904p17765904.html
>> Sent from the drools - user mailing list archive at Nabble.com.
>>
>> _______________________________________________
>> rules-users mailing list
>> rules-users at lists.jboss.org
>> https://lists.jboss.org/mailman/listinfo/rules-users
>>
> 
> 
> 
> -- 
> Edson Tirelli
> JBoss Drools Core Development
> Office: +55 11 3529-6000
> Mobile: +55 11 9287-5646
> JBoss, a division of Red Hat @ www.jboss.com
> 
> _______________________________________________
> rules-users mailing list
> rules-users at lists.jboss.org
> https://lists.jboss.org/mailman/listinfo/rules-users
> 
> 

-- 
View this message in context: http://www.nabble.com/NoClassDefFoundError-when-dynamically-updating-rulebase-for-rule-using-%27accumulate%27-CE-tp17765904p17778359.html
Sent from the drools - user mailing list archive at Nabble.com.




More information about the rules-users mailing list