use of org.kie.api.runtime.KieContainer in project drools by kiegroup.
the class ListenersTest method init.
@Before
public void init() {
ReleaseId kieModuleId = prepareKieModule();
final KieContainer kieContainer = ks.newKieContainer(kieModuleId);
this.kieSession = kieContainer.newKieSession();
this.statelessKieSession = kieContainer.newStatelessKieSession();
}
use of org.kie.api.runtime.KieContainer in project drools by kiegroup.
the class MBeansMonitoringTest method testAggregatedAndDispose.
@Test
public void testAggregatedAndDispose() throws Exception {
String drl = "package org.drools.compiler.integrationtests\n" + "rule ND\n" + "when\n" + " String() \n" + " not ( Double() ) \n" + "then\n" + " // do nothing. \n" + "end\n" + "rule ND2\n" + "salience 1\n" + "when\n" + " $s : String() \n" + " not ( Double() ) \n" + "then\n" + " try { Thread.sleep(10); } catch (Exception e) { }\n" + " insert( new Double(0) );\n" + " retract( $s );\n" + "end\n";
KieServices ks = KieServices.Factory.get();
KieModuleModel kproj = ks.newKieModuleModel();
KieBaseModel kieBaseModel1 = kproj.newKieBaseModel(KBASE1).setDefault(true).setEventProcessingMode(EventProcessingOption.STREAM);
KieSessionModel ksessionModel1 = kieBaseModel1.newKieSessionModel(KSESSION1).setDefault(true).setType(KieSessionModel.KieSessionType.STATEFUL).setClockType(ClockTypeOption.get(ClockType.PSEUDO_CLOCK.getId()));
KieBaseModel kieBaseModel2 = kproj.newKieBaseModel(KBASE2).setDefault(false);
KieSessionModel ksessionModel2 = kieBaseModel2.newKieSessionModel(KSESSION2).setDefault(true).setType(KieSessionModel.KieSessionType.STATELESS);
ReleaseId releaseId1 = ks.newReleaseId("org.kie.test", "mbeans", "1.0.0");
createKJar(ks, kproj, releaseId1, null, drl);
String containerId = "myContainerId";
KieContainer kc = ks.newKieContainer(containerId, releaseId1);
KieBase kiebase = kc.getKieBase(KBASE1);
KieSessionConfiguration sessionConf = ks.newKieSessionConfiguration();
sessionConf.setOption(ForceEagerActivationOption.YES);
KieSession ksession = kc.newKieSession(KSESSION1, sessionConf);
MBeanServer mbserver = ManagementFactory.getPlatformMBeanServer();
KieSessionMonitoringMXBean aggrMonitor = JMX.newMXBeanProxy(mbserver, DroolsManagementAgent.createObjectNameBy(containerId, KBASE1, KieSessionType.STATEFUL, KSESSION1), KieSessionMonitoringMXBean.class);
long tft = 0;
print(aggrMonitor);
checkAgendaTotals(aggrMonitor, 0, 0, 0);
checkTotalFactCount(aggrMonitor, 0);
tft = checkTotalFiringTimeGEQ(aggrMonitor, tft);
checkTotalSessions(aggrMonitor, 1);
assertNull(aggrMonitor.getStatsForRule("ND"));
assertNull(aggrMonitor.getStatsForRule("ND2"));
assertFalse(aggrMonitor.getStatsByRule().containsKey("ND"));
assertFalse(aggrMonitor.getStatsByRule().containsKey("ND2"));
ksession.insert("Ciao");
ksession.fireAllRules();
print(aggrMonitor);
checkAgendaTotals(aggrMonitor, 2, 1, 1);
checkTotalFactCount(aggrMonitor, 1);
tft = checkTotalFiringTimeGEQ(aggrMonitor, tft + 1);
checkTotalSessions(aggrMonitor, 1);
checkStatsForRule(aggrMonitor, "ND", 1, 1, 0);
checkStatsForRule(aggrMonitor, "ND2", 1, 0, 1);
checkStatsByRule(aggrMonitor, "ND", 1, 1, 0);
checkStatsByRule(aggrMonitor, "ND2", 1, 0, 1);
ksession.fireAllRules();
print(aggrMonitor);
checkAgendaTotals(aggrMonitor, 2, 1, 1);
checkTotalFactCount(aggrMonitor, 1);
tft = checkTotalFiringTimeGEQ(aggrMonitor, tft);
checkTotalSessions(aggrMonitor, 1);
checkStatsForRule(aggrMonitor, "ND", 1, 1, 0);
checkStatsForRule(aggrMonitor, "ND2", 1, 0, 1);
checkStatsByRule(aggrMonitor, "ND", 1, 1, 0);
checkStatsByRule(aggrMonitor, "ND2", 1, 0, 1);
LOG.debug("---");
KieSession ksession2 = kc.newKieSession(KSESSION1, sessionConf);
ksession2.insert("Ciao");
ksession2.fireAllRules();
print(aggrMonitor);
checkAgendaTotals(aggrMonitor, 4, 2, 2);
checkTotalFactCount(aggrMonitor, 2);
tft = checkTotalFiringTimeGEQ(aggrMonitor, tft + 1);
checkTotalSessions(aggrMonitor, 2);
checkStatsForRule(aggrMonitor, "ND", 2, 2, 0);
checkStatsForRule(aggrMonitor, "ND2", 2, 0, 2);
checkStatsByRule(aggrMonitor, "ND", 2, 2, 0);
checkStatsByRule(aggrMonitor, "ND2", 2, 0, 2);
ksession.dispose();
checkTotalSessions(aggrMonitor, 1);
checkTotalFactCount(aggrMonitor, 1);
ksession2.dispose();
checkTotalSessions(aggrMonitor, 0);
checkTotalFactCount(aggrMonitor, 0);
LOG.debug("--- NOW for the STATELESS ---");
tft = 0;
StatelessKieSession stateless = kc.newStatelessKieSession(KSESSION2, sessionConf);
StatelessKieSessionMonitoringMXBean aggrMonitor2 = JMX.newMXBeanProxy(mbserver, DroolsManagementAgent.createObjectNameBy(containerId, KBASE2, KieSessionType.STATELESS, KSESSION2), StatelessKieSessionMonitoringMXBean.class);
print(aggrMonitor2);
checkAgendaTotals(aggrMonitor2, 0, 0, 0);
checkRuleRuntimeTotals(aggrMonitor2, 0, 0);
tft = checkTotalFiringTimeGEQ(aggrMonitor2, tft);
checkTotalSessions(aggrMonitor2, 0);
assertNull(aggrMonitor2.getStatsForRule("ND"));
assertNull(aggrMonitor2.getStatsForRule("ND2"));
assertFalse(aggrMonitor2.getStatsByRule().containsKey("ND"));
assertFalse(aggrMonitor2.getStatsByRule().containsKey("ND2"));
stateless.execute("Ciao");
print(aggrMonitor2);
checkAgendaTotals(aggrMonitor2, 2, 1, 1);
checkRuleRuntimeTotals(aggrMonitor2, 2, 1);
tft = checkTotalFiringTimeGEQ(aggrMonitor2, tft + 1);
checkTotalSessions(aggrMonitor2, 1);
checkStatsForRule(aggrMonitor2, "ND", 1, 1, 0);
checkStatsForRule(aggrMonitor2, "ND2", 1, 0, 1);
checkStatsByRule(aggrMonitor2, "ND", 1, 1, 0);
checkStatsByRule(aggrMonitor2, "ND2", 1, 0, 1);
stateless.execute("Ciao");
print(aggrMonitor2);
checkAgendaTotals(aggrMonitor2, 4, 2, 2);
checkRuleRuntimeTotals(aggrMonitor2, 4, 2);
tft = checkTotalFiringTimeGEQ(aggrMonitor2, tft + 1);
checkTotalSessions(aggrMonitor2, 2);
checkStatsForRule(aggrMonitor2, "ND", 2, 2, 0);
checkStatsForRule(aggrMonitor2, "ND2", 2, 0, 2);
checkStatsByRule(aggrMonitor2, "ND", 2, 2, 0);
checkStatsByRule(aggrMonitor2, "ND2", 2, 0, 2);
StatelessKieSession stateless2 = kc.newStatelessKieSession(KSESSION2, sessionConf);
LOG.debug(stateless + " " + stateless2);
checkTotalSessions(aggrMonitor2, 2);
stateless2.execute("Ciao");
print(aggrMonitor2);
checkAgendaTotals(aggrMonitor2, 6, 3, 3);
checkRuleRuntimeTotals(aggrMonitor2, 6, 3);
tft = checkTotalFiringTimeGEQ(aggrMonitor2, tft + 1);
checkTotalSessions(aggrMonitor2, 3);
checkStatsForRule(aggrMonitor2, "ND", 3, 3, 0);
checkStatsForRule(aggrMonitor2, "ND2", 3, 0, 3);
checkStatsByRule(aggrMonitor2, "ND", 3, 3, 0);
checkStatsByRule(aggrMonitor2, "ND2", 3, 0, 3);
KieContainer kc2 = ks.newKieContainer("kc2", releaseId1);
assertEquals(5, mbserver.queryNames(new ObjectName("org.kie:kcontainerId=" + ObjectName.quote(containerId) + ",*"), null).size());
kc.dispose();
assertEquals(0, mbserver.queryNames(new ObjectName("org.kie:kcontainerId=" + ObjectName.quote(containerId) + ",*"), null).size());
assertEquals(1, mbserver.queryNames(new ObjectName("org.kie:kcontainerId=" + ObjectName.quote("kc2") + ",*"), null).size());
}
use of org.kie.api.runtime.KieContainer in project drools by kiegroup.
the class MBeansMonitoringTest method testEventOffset.
@Test
public void testEventOffset() throws Exception {
String drl = "package org.drools.compiler.test\n" + "import org.drools.compiler.StockTick\n" + "declare StockTick\n" + " @role(event)\n" + " @expires(10s)\n" + "end\n" + "rule X\n" + "when\n" + " StockTick()\n" + "then\n" + "end";
KieServices ks = KieServices.Factory.get();
KieModuleModel kproj = ks.newKieModuleModel();
KieBaseModel kieBaseModel1 = kproj.newKieBaseModel(KBASE1).setDefault(true).setEventProcessingMode(EventProcessingOption.STREAM);
KieSessionModel ksession1 = kieBaseModel1.newKieSessionModel(KSESSION1).setDefault(true).setType(KieSessionModel.KieSessionType.STATEFUL).setClockType(ClockTypeOption.get(ClockType.PSEUDO_CLOCK.getId()));
ReleaseId releaseId1 = ks.newReleaseId("org.kie.test", "mbeans", "1.0.0");
createKJar(ks, kproj, releaseId1, null, drl);
KieContainer kc = ks.newKieContainer(releaseId1);
KieBase kiebase = kc.getKieBase(KBASE1);
MBeanServer mbserver = ManagementFactory.getPlatformMBeanServer();
ObjectName kbOn = DroolsManagementAgent.createObjectNameFor((InternalKnowledgeBase) kiebase);
mbserver.invoke(kbOn, "startInternalMBeans", new Object[0], new String[0]);
Object expOffset = mbserver.getAttribute(new ObjectName(kbOn + ",group=EntryPoints,EntryPoint=DEFAULT,ObjectType=org.drools.compiler.StockTick"), "ExpirationOffset");
assertEquals(10001, ((Number) expOffset).longValue());
}
use of org.kie.api.runtime.KieContainer in project drools by kiegroup.
the class CepEspTest method testThrowsWhenCreatingKieBaseUsingWindowsInCloudMode.
@Test
public void testThrowsWhenCreatingKieBaseUsingWindowsInCloudMode() {
String drl = "declare TestEvent\n" + " @role( event )\n" + " name : String\n" + "end\n" + "\n" + "rule R when\n" + " TestEvent ( name == \"EventA\" ) over window:time( 1s ) from entry-point EventStream\n" + " then\n" + " // consequence\n" + "end\n";
KieServices ks = KieServices.Factory.get();
KieModuleModel kieModule = ks.newKieModuleModel();
KieBaseModel defaultBase = kieModule.newKieBaseModel("KBase").setDefault(true).addPackage("*").setEventProcessingMode(EventProcessingOption.CLOUD);
defaultBase.newKieSessionModel("KSession").setClockType(ClockTypeOption.get("pseudo")).setDefault(true);
KieFileSystem kfs = ks.newKieFileSystem().write("src/main/resources/r1.drl", drl);
kfs.writeKModuleXML(kieModule.toXML());
KieBuilder kieBuilder = ks.newKieBuilder(kfs).buildAll();
KieContainer kieContainer = ks.newKieContainer(ks.getRepository().getDefaultReleaseId());
try {
kieContainer.getKieBase("KBase");
fail("Should throw a RuntimeException because the CLOUD kbase is trying to use features only available in STREAM mode");
} catch (Exception e) {
}
}
use of org.kie.api.runtime.KieContainer in project drools by kiegroup.
the class ClassLoaderTest method testClassLoaderFromPojo.
@Test
public void testClassLoaderFromPojo() throws IOException {
// DROOLS-1108
final String source = "package org.drools.testdrl;\n" + "public class MyPojo {\n" + " public String getUrlPath() {" + " return getClass().getClassLoader().getResource(\"META-INF/foo.xml\").getPath();\n" + " }\n" + "}\n";
final String drl1 = "package org.drools.testdrl;\n" + "import org.drools.testdrl.MyPojo;\n" + "global java.util.List list;\n" + "rule R1 when\n" + "then\n" + " insert(new MyPojo());\n" + "end\n" + "rule R2 when\n" + " $m : MyPojo()\n" + "then\n" + " list.add($m.getUrlPath());\n" + "end\n";
final String foo = "<xyz/>\n";
final KieServices ks = KieServices.Factory.get();
final ReleaseId releaseId = ks.newReleaseId("org.kie", "test-cl", "1.0.0");
final KieFileSystem kfs = ks.newKieFileSystem();
final KieModuleModel kproj = ks.newKieModuleModel();
final KieBaseModel kieBaseModel1 = kproj.newKieBaseModel("testKbase").setDefault(true).addPackage("org.drools.testdrl");
final KieSessionModel ksession1 = kieBaseModel1.newKieSessionModel("testKsession").setDefault(true);
kfs.writeKModuleXML(kproj.toXML());
kfs.write("src/main/resources/org/drools/testdrl/rules1.drl", drl1);
kfs.write("src/main/java/org/drools/testdrl/MyPojo.java", source);
kfs.write("src/main/resources/META-INF/foo.xml", foo);
kfs.generateAndWritePomXML(releaseId);
final KieBuilder kieBuilder = ks.newKieBuilder(kfs);
assertTrue(kieBuilder.buildAll().getResults().getMessages().isEmpty());
final KieContainer kieContainer = ks.newKieContainer(releaseId);
final ClassLoader classLoader = kieContainer.getClassLoader();
final URL url = classLoader.getResource("META-INF/foo.xml");
assertNotNull(url);
final KieSession ksession = kieContainer.newKieSession("testKsession");
final List<URL> list = new ArrayList<>();
ksession.setGlobal("list", list);
ksession.fireAllRules();
assertEquals(1, list.size());
assertEquals(url.getPath(), list.get(0));
ksession.dispose();
}
Aggregations