[rules-users] Lock-on-active and ruleflow-group

Wolfgang Laun wolfgang.laun at gmail.com
Tue Aug 9 06:38:31 EDT 2011


You should use activation-group "price" or similar, not lock-on-active.
-W


On 9 August 2011 11:40, Wolfgang Laun <wolfgang.laun at gmail.com> wrote:
>
> "Whenever a ruleflow-group becomes active [...], any rule within that group that has lock-on-active set to true will not be activated any more." (Emphasis added by me.)
>
> Do you activate the ruleflow-group before you insert the Car fact?
>
> -W
>
>
> On 9 August 2011 11:05, bitter <rgorzkow at gmail.com> wrote:
>>
>> Log:
>>
>> ==>[BeforeActivationFiredEvent:  getActivation()=[Activation rule=Second
>> rule, act#=1, salience=25, tuple=[fact
>> 0:1:1428842218:1428842218:1:DEFAULT:Car{color='red', size='small',
>> price=null}]
>> ],
>> getKnowledgeRuntime()=org.drools.impl.StatefulKnowledgeSessionImpl at 72f6f1b6]
>> ==>[AfterActivationFiredEvent: getActivation()=[Activation rule=Second rule,
>> act#=1, salience=25, tuple=[fact
>> 0:1:1428842218:1428842218:2:DEFAULT:Car{color='red', size='small', price=2}]
>> ],
>> getKnowledgeRuntime()=org.drools.impl.StatefulKnowledgeSessionImpl at 72f6f1b6]
>> ==>[BeforeActivationFiredEvent:  getActivation()=[Activation rule=First
>> rule, act#=0, salience=20, tuple=[fact
>> 0:1:1428842218:1428842218:2:DEFAULT:Car{color='red', size='small', price=2}]
>> ],
>> getKnowledgeRuntime()=org.drools.impl.StatefulKnowledgeSessionImpl at 72f6f1b6]
>> ==>[AfterActivationFiredEvent: getActivation()=[Activation rule=First rule,
>> act#=0, salience=20, tuple=[fact
>> 0:1:1428842218:1428842218:3:DEFAULT:Car{color='red', size='small', price=1}]
>> ],
>> getKnowledgeRuntime()=org.drools.impl.StatefulKnowledgeSessionImpl at 72f6f1b6]
>> ==>[BeforeActivationFiredEvent:  getActivation()=[Activation rule=Second
>> step, act#=2, salience=40, tuple=[fact
>> 0:1:1428842218:1428842218:3:DEFAULT:Car{color='red', size='small', price=1}]
>> ],
>> getKnowledgeRuntime()=org.drools.impl.StatefulKnowledgeSessionImpl at 72f6f1b6]
>> ==>[AfterActivationFiredEvent: getActivation()=[Activation rule=Second step,
>> act#=2, salience=40, tuple=[fact
>> 0:1:1428842218:1428842218:3:DEFAULT:Car{color='red', size='small', price=1}]
>> ],
>> getKnowledgeRuntime()=org.drools.impl.StatefulKnowledgeSessionImpl at 72f6f1b6]
>> Car{color='red', size='small', price=1}
>>
>> java.lang.AssertionError:
>> Expected :2
>> Actual   :1
>>        at org.junit.Assert.fail(Assert.java:91)
>>        at org.junit.Assert.failNotEquals(Assert.java:645)
>>        at org.junit.Assert.assertEquals(Assert.java:126)
>>        at org.junit.Assert.assertEquals(Assert.java:145)
>>        at
>> CarKnowledgeBaseTest.shouldObtainPriceWhereSalienceIsBigger(CarKnowledgeBaseTest.java:47)
>>        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
>>        at
>> sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
>>        at
>> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
>>        at
>> org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:44)
>>        at
>> org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15)
>>        at
>> org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:41)
>>        at
>> org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:20)
>>        at
>> org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:76)
>>        at
>> org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:50)
>>        at org.junit.runners.ParentRunner$3.run(ParentRunner.java:193)
>>        at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:52)
>>        at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:191)
>>        at org.junit.runners.ParentRunner.access$000(ParentRunner.java:42)
>>        at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:184)
>>        at org.junit.runners.ParentRunner.run(ParentRunner.java:236)
>>        at org.junit.runner.JUnitCore.run(JUnitCore.java:157)
>>        at
>> com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:71)
>>        at
>> com.intellij.rt.execution.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:199)
>>        at com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:62)
>>        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
>>        at
>> sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
>>        at com.intellij.rt.execution.application.AppMain.main(AppMain.java:120)
>>
>> --
>> View this message in context: http://drools.46999.n3.nabble.com/Lock-on-active-and-ruleflow-group-tp3237089p3238338.html
>> Sent from the Drools: User forum mailing list archive at Nabble.com.
>> _______________________________________________
>> rules-users mailing list
>> rules-users at lists.jboss.org
>> https://lists.jboss.org/mailman/listinfo/rules-users
>




More information about the rules-users mailing list