[rules-users] Can't execute rules twice with a second classloader
Aaron Dixon
atdixon at gmail.com
Thu Jul 12 10:06:34 EDT 2007
I am trying to sequentially perform two rules executions using two
different classloaders in the same VM. I create completely new state
for each execution, yet I still fail on the second execution. I
believe this has to do with some internal static cached state that
JBossRules is maintaining. A snippet of the code and exeception are
shown in this email.
public void demo() throws Exception {
// Save original classloader
ClassLoader original = Thread.currentThread().getContextClassLoader();
// Create Classloader 1 with parent of original
FooClassLoader loader1 = new FooClassLoader(original);
Thread.currentThread().setContextClassLoader(loader1);
testRules();
// Success so far...
// Create Classloader 2 with parent of original
FooClassLoader loader2 = new FooClassLoader(original);
Thread.currentThread().setContextClassLoader(loader2);
testRules();
// Never make it to here.
// Restore
Thread.currentThread().setContextClassLoader(original);
}
private void testRules() throws Exception {
PackageBuilder builder = new PackageBuilder();
Package pkg = buildPackage(new String[] { "Foo.drl" }, builder);
RuleBase base = RuleBaseFactory.newRuleBase();
base.addPackage(pkg);
StatelessSession session = base.newStatelessSession();
final ClassLoader loader =
Thread.currentThread().getContextClassLoader();
Object inst = loader.loadClass("com.foo.Foo").newInstance();
session.execute(new Object[] { inst });
}
Exception in thread "main" java.lang.ClassCastException:
adixon.prototype.rules.classloader.demo.copy.FooShadowProxy
at org.drools.base.adixon.prototype.rules.classloader.demo.copy.Foo$getName.getValue(Unknown
Source)
at org.drools.base.ClassFieldExtractor.getValue(ClassFieldExtractor.java:94)
at org.drools.base.evaluators.StringFactory$StringEqualEvaluator.evaluate(StringFactory.java:85)
at org.drools.rule.LiteralRestriction.isAllowed(LiteralRestriction.java:61)
at org.drools.rule.LiteralConstraint.isAllowed(LiteralConstraint.java:82)
at org.drools.reteoo.AlphaNode.assertObject(AlphaNode.java:121)
at org.drools.reteoo.SingleObjectSinkAdapter.propagateAssertObject(SingleObjectSinkAdapter.java:20)
at org.drools.reteoo.ObjectTypeNode.assertObject(ObjectTypeNode.java:159)
at org.drools.reteoo.Rete.assertObject(Rete.java:175)
at org.drools.reteoo.ReteooRuleBase.assertObject(ReteooRuleBase.java:190)
at org.drools.reteoo.ReteooWorkingMemory.doInsert(ReteooWorkingMemory.java:70)
at org.drools.common.AbstractWorkingMemory.insert(AbstractWorkingMemory.java:772)
at org.drools.common.AbstractWorkingMemory.insert(AbstractWorkingMemory.java:584)
at org.drools.reteoo.ReteooStatelessSession.execute(ReteooStatelessSession.java:63)
at adixon.prototype.rules.classloader.demo.copy.Driver.testRules(Driver.java:47)
at adixon.prototype.rules.classloader.demo.copy.Driver.go(Driver.java:33)
at adixon.prototype.rules.classloader.demo.copy.Driver.main(Driver.java:17)
More information about the rules-users
mailing list