/* * Copyright 2015 Red Hat, Inc. and/or its affiliates. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.drools.compiler.integrationtests; import java.util.concurrent.TimeUnit; import org.drools.compiler.CommonTestMethodBase; import org.kie.api.time.SessionPseudoClock; import org.junit.After; import org.junit.Before; import org.junit.Test; import org.kie.api.KieServices; import org.kie.api.builder.KieFileSystem; import org.kie.api.builder.model.KieBaseModel; import org.kie.api.builder.model.KieModuleModel; import org.kie.api.conf.EventProcessingOption; import org.kie.api.runtime.KieSession; import org.kie.api.runtime.conf.ClockTypeOption; import org.kie.api.runtime.rule.EntryPoint; import org.kie.api.runtime.rule.QueryResults; import org.kie.internal.io.ResourceFactory; /** * Tests queries using temporal operators on events from two entry points. */ public class CepQueryTest extends CommonTestMethodBase { private KieSession ksession; private SessionPseudoClock clock; private EntryPoint firstEntryPoint, secondEntryPoint; @Before public void prepare() { final String drl = "package org.drools.compiler.integrationtests\n" + "import org.drools.compiler.integrationtests.CepQueryTest.TestEvent;\n" + "declare TestEvent\n" + " @role( event )\n" + "end\n" + "query EventsAfterZeroToNineSeconds\n" + " $event : TestEvent() from entry-point FirstStream\n" + " $result : TestEvent( this after [0s, 9s] $event) from entry-point SecondStream\n" + "end\n"; final KieServices ks = KieServices.Factory.get(); KieFileSystem kfs = ks.newKieFileSystem(); KieModuleModel module = ks.newKieModuleModel(); KieBaseModel baseModel = module.newKieBaseModel("defaultKBase") .setDefault(true) .setEventProcessingMode(EventProcessingOption.STREAM); baseModel.newKieSessionModel("defaultKSession") .setDefault(true) .setClockType(ClockTypeOption.get("pseudo")); kfs.writeKModuleXML(module.toXML()); kfs.write(ResourceFactory.newByteArrayResource( drl.getBytes() ).setTargetPath("defaultPkg/query.drl") ); assertTrue(ks.newKieBuilder(kfs).buildAll().getResults().getMessages().isEmpty()); ksession = ks.newKieContainer(ks.getRepository().getDefaultReleaseId()).newKieSession(); clock = ksession.getSessionClock(); firstEntryPoint = ksession.getEntryPoint("FirstStream"); secondEntryPoint = ksession.getEntryPoint("SecondStream"); } @After public void cleanup() { if (ksession != null) { ksession.dispose(); } } private void eventsInitialization() { secondEntryPoint.insert(new TestEvent("minusOne")); clock.advanceTime(5, TimeUnit.SECONDS); firstEntryPoint.insert(new TestEvent("zero")); secondEntryPoint.insert(new TestEvent("one")); // clock.advanceTime(10, TimeUnit.SECONDS); // // secondEntryPoint.insert(new TestEvent("two")); // clock.advanceTime(10, TimeUnit.SECONDS); // // secondEntryPoint.insert(new TestEvent("three")); // ksession.fireAllRules(); } /** * Tests query using temporal operator 'after' on events from two entry points. */ @Test//(timeout=10000) public void testQueryWithAfter() { this.eventsInitialization(); QueryResults results = ksession.getQueryResults("EventsAfterZeroToNineSeconds"); assertEquals("Unexpected query result length", 1, results.size()); assertEquals("Unexpected query result content", "one", ((TestEvent) results.iterator().next().get("$result")).getName()); } /** * Simple event used in the test. */ public static class TestEvent { private final String name; public TestEvent(final String name) { this.name = name; } public String getName() { return this.name; } @Override public String toString() { return "TestEvent["+name+"]"; } } }