use of org.kie.api.event.kiescanner.KieScannerStatusChangeEvent in project drools by kiegroup.
the class KieRepositoryScannerTest method testKScannerWithRange_withListener.
@Test
public void testKScannerWithRange_withListener() throws Exception {
KieServices ks = KieServices.Factory.get();
KieMavenRepository repository = getKieMavenRepository();
String artifactId = "scanner-range-test-withlistener";
ReleaseId releaseId1 = ks.newReleaseId("org.kie", artifactId, "1.0.1");
ReleaseId releaseId2 = ks.newReleaseId("org.kie", artifactId, "1.0.2");
// Because KieScanner also check the local repo, ensure the artifact are not deployed on the local maven repo
repository.removeLocalArtifact(releaseId1);
repository.removeLocalArtifact(releaseId2);
ReleaseId releaseRange = ks.newReleaseId("org.kie", artifactId, "[1.0.0,)");
InternalKieModule kJar1 = createKieJar(ks, releaseId1, "rule1", "rule2");
KieContainer kieContainer = ks.newKieContainer(releaseRange);
List<KieScannerEvent> events = new ArrayList<>();
InternalKieScanner scanner = (KieRepositoryScannerImpl) ks.newKieScanner(kieContainer);
KieScannerEventListener listener = new KieScannerEventListener() {
public void onKieScannerStatusChangeEvent(KieScannerStatusChangeEvent statusChange) {
LOG.info("KieScanner event: {}", statusChange);
events.add(statusChange);
}
public void onKieScannerUpdateResultsEvent(KieScannerUpdateResultsEvent updtaeResults) {
LOG.info("KieScanner event: {}", updtaeResults);
events.add(updtaeResults);
}
};
scanner.addListener(listener);
scanner.scanNow();
// Because 1.0.2 does not exist, will perform a scan but will NOT update.
assertThat(events, CoreMatchers.hasItem(new KieScannerStatusChangeEventImpl(KieScanner.Status.SCANNING)));
assertThat(events, CoreMatchers.not(CoreMatchers.hasItem(new KieScannerStatusChangeEventImpl(KieScanner.Status.UPDATING))));
events.clear();
repository.installArtifact(releaseId1, kJar1, createKPom(fileManager, releaseId1));
KieSession ksession = kieContainer.newKieSession("KSession1");
checkKSession(ksession, "rule1", "rule2");
// create a new kjar
InternalKieModule kJar2 = createKieJar(ks, releaseId2, "rule2", "rule3");
// deploy it on maven
repository.installArtifact(releaseId2, kJar2, createKPom(fileManager, releaseId2));
// since I am not calling start() on the scanner it means it won't have automatic scheduled scanning
assertEquals(releaseId1, scanner.getCurrentReleaseId());
assertEquals(InternalKieScanner.Status.STOPPED, scanner.getStatus());
// scan the maven repo to get the new kjar version and deploy it on the kcontainer
scanner.scanNow();
assertEquals(releaseId2, scanner.getCurrentReleaseId());
assertEquals(InternalKieScanner.Status.STOPPED, scanner.getStatus());
// create a ksesion and check it works as expected
KieSession ksession2 = kieContainer.newKieSession("KSession1");
checkKSession(ksession2, "rule2", "rule3");
assertThat(events, CoreMatchers.hasItem(new KieScannerStatusChangeEventImpl(KieScanner.Status.SCANNING)));
assertThat(events, CoreMatchers.hasItem(new KieScannerStatusChangeEventImpl(KieScanner.Status.UPDATING)));
assertTrue(events.get(2) instanceof KieScannerUpdateResultsEventImpl);
assertFalse(((KieScannerUpdateResultsEventImpl) events.get(2)).getResults().hasMessages(Message.Level.ERROR));
events.clear();
ks.getRepository().removeKieModule(releaseId1);
ks.getRepository().removeKieModule(releaseId2);
scanner.removeListener(listener);
assertEquals(0, scanner.getListeners().size());
repository.removeLocalArtifact(releaseId1);
repository.removeLocalArtifact(releaseId2);
}
use of org.kie.api.event.kiescanner.KieScannerStatusChangeEvent in project drools by kiegroup.
the class KieRepositoryScannerTest method testKScannerWithRange_withListener_errors.
@Test
public void testKScannerWithRange_withListener_errors() throws Exception {
KieServices ks = KieServices.Factory.get();
KieMavenRepository repository = getKieMavenRepository();
String artifactId = "scanner-range-test-withlistener-errors";
ReleaseId releaseId1 = ks.newReleaseId("org.kie", artifactId, "1.0.1");
ReleaseId releaseId2 = ks.newReleaseId("org.kie", artifactId, "1.0.2");
// Because KieScanner also check the local repo, ensure the artifact are not deployed on the local maven repo
repository.removeLocalArtifact(releaseId1);
repository.removeLocalArtifact(releaseId2);
ReleaseId releaseRange = ks.newReleaseId("org.kie", artifactId, "[1.0.0,)");
InternalKieModule kJar1 = createKieJar(ks, releaseId1, "rule1", "rule2");
KieContainer kieContainer = ks.newKieContainer(releaseRange);
List<KieScannerEvent> events = new ArrayList<>();
InternalKieScanner scanner = (KieRepositoryScannerImpl) ks.newKieScanner(kieContainer);
KieScannerEventListener listener = new KieScannerEventListener() {
public void onKieScannerStatusChangeEvent(KieScannerStatusChangeEvent statusChange) {
LOG.info("KieScanner event: {}", statusChange);
events.add(statusChange);
}
public void onKieScannerUpdateResultsEvent(KieScannerUpdateResultsEvent updtaeResults) {
LOG.info("KieScanner event: {}", updtaeResults);
events.add(updtaeResults);
}
};
scanner.addListener(listener);
scanner.scanNow();
// Because 1.0.2 does not exist, will perform a scan but will NOT update.
assertThat(events, CoreMatchers.hasItem(new KieScannerStatusChangeEventImpl(KieScanner.Status.SCANNING)));
assertThat(events, CoreMatchers.not(CoreMatchers.hasItem(new KieScannerStatusChangeEventImpl(KieScanner.Status.UPDATING))));
events.clear();
repository.installArtifact(releaseId1, kJar1, createKPom(fileManager, releaseId1));
KieSession ksession = kieContainer.newKieSession("KSession1");
checkKSession(ksession, "rule1", "rule2");
// Create a wrong KJAR for releaseId2
KieFileSystem kfs = ks.newKieFileSystem();
String pomContent = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n" + "<project xmlns=\"http://maven.apache.org/POM/4.0.0\" xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"\n" + " xsi:schemaLocation=\"http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd\">\n" + " <modelVersion>4.0.0</modelVersion>\n" + "\n" + " <groupId>" + releaseId2.getGroupId() + "</groupId>\n" + " <artifactId>" + releaseId2.getArtifactId() + "</artifactId>\n" + " <version>" + releaseId2.getVersion() + "</version></project>\n";
kfs.writePomXML(pomContent);
kfs.write("rulebroken" + ".drl", "rule X when asd asd then end");
kfs.write("META-INF/kmodule.xml", "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n" + "<kmodule xmlns=\"http://www.drools.org/xsd/kmodule\">\n" + " <!-- This is a minimal kmodule.xml. Ref Drools documentation, see http://docs.jboss.org/drools/release/6.1.0.Final/drools-docs/html_single/index.html#d0e1112 -->\n" + "</kmodule>\n");
File tempJar = File.createTempFile("org.kie" + artifactId + "1.0.2", "tmp");
LOG.info("Writing to temp file: {}", tempJar);
// please notice that writeAsJar would return a new file with .jar postfixed
tempJar = ((KieFileSystemImpl) kfs).asMemoryFileSystem().writeAsJar(tempJar.getParentFile(), tempJar.getName());
File tempPom = File.createTempFile("org.kie" + artifactId + "1.0.2", "tmp.xml");
LOG.info("Writing to temp file: {}", tempPom);
FileUtils.writeStringToFile(tempPom, pomContent, "UTF-8");
repository.installArtifact(releaseId2, tempJar, tempPom);
assertEquals(releaseId1, scanner.getCurrentReleaseId());
assertEquals(InternalKieScanner.Status.STOPPED, scanner.getStatus());
// scan the maven repo to get the new kjar version and deploy it on the kcontainer
scanner.scanNow();
// Keeping at previous release
assertEquals(releaseId1, scanner.getCurrentReleaseId());
assertEquals(InternalKieScanner.Status.STOPPED, scanner.getStatus());
// there should be no update performed.
assertThat(events, CoreMatchers.hasItem(new KieScannerStatusChangeEventImpl(KieScanner.Status.SCANNING)));
assertThat(events, CoreMatchers.hasItem(new KieScannerStatusChangeEventImpl(KieScanner.Status.UPDATING)));
assertTrue(events.get(2) instanceof KieScannerUpdateResultsEventImpl);
assertTrue(((KieScannerUpdateResultsEventImpl) events.get(2)).getResults().hasMessages(Message.Level.ERROR));
events.clear();
ks.getRepository().removeKieModule(releaseId1);
ks.getRepository().removeKieModule(releaseId2);
scanner.removeListener(listener);
assertEquals(0, scanner.getListeners().size());
repository.removeLocalArtifact(releaseId1);
repository.removeLocalArtifact(releaseId2);
}
Aggregations