diff options
author | Trygve Laugstøl <trygvis@inamo.no> | 2021-01-26 16:04:30 +0100 |
---|---|---|
committer | Trygve Laugstøl <trygvis@inamo.no> | 2021-01-26 16:04:30 +0100 |
commit | 71010ae3fefbe897227343e44573385df9cd60cc (patch) | |
tree | 16cac848741881171ba715712547aae15bba5dc2 /module/ri-engine/src | |
parent | 63e4e5fac646766d8e574e2e9a539e03f54fd87c (diff) | |
download | rules-sandbox-71010ae3fefbe897227343e44573385df9cd60cc.tar.gz rules-sandbox-71010ae3fefbe897227343e44573385df9cd60cc.tar.bz2 rules-sandbox-71010ae3fefbe897227343e44573385df9cd60cc.tar.xz rules-sandbox-71010ae3fefbe897227343e44573385df9cd60cc.zip |
Better main() support.
Diffstat (limited to 'module/ri-engine/src')
-rw-r--r-- | module/ri-engine/src/main/java/io/trygvis/rules/engine/Engine.java | 53 | ||||
-rw-r--r-- | module/ri-engine/src/test/java/io/trygvis/rules/engine/WireguardTestMain.java | 19 |
2 files changed, 46 insertions, 26 deletions
diff --git a/module/ri-engine/src/main/java/io/trygvis/rules/engine/Engine.java b/module/ri-engine/src/main/java/io/trygvis/rules/engine/Engine.java index e5b9606..f73419a 100644 --- a/module/ri-engine/src/main/java/io/trygvis/rules/engine/Engine.java +++ b/module/ri-engine/src/main/java/io/trygvis/rules/engine/Engine.java @@ -2,11 +2,10 @@ package io.trygvis.rules.engine; import org.drools.core.audit.WorkingMemoryConsoleLogger; import org.kie.api.KieServices; -import org.kie.api.builder.Message; -import org.kie.api.builder.Message.Level; -import org.kie.api.builder.ReleaseId; import org.kie.api.event.rule.AgendaEventListener; import org.kie.api.event.rule.RuleRuntimeEventListener; +import org.kie.api.io.Resource; +import org.kie.api.runtime.KieContainer; import org.kie.api.runtime.KieSession; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -14,6 +13,8 @@ import org.slf4j.LoggerFactory; import java.io.Closeable; import java.io.File; import java.io.IOException; +import java.util.ArrayList; +import java.util.List; public class Engine implements Closeable { private final Logger logger = LoggerFactory.getLogger(getClass()); @@ -28,36 +29,36 @@ public class Engine implements Closeable { logger.info("services = {}", services); - ReleaseId releaseId = null; - for (File path : (modules == null ? new File[0] : modules)) { - logger.info("New KieBuilder: {}", path); + var kieRepository = services.getRepository(); + logger.info("kieRepository.getDefaultReleaseId() = {}", kieRepository.getDefaultReleaseId()); + KieContainer container; + if (modules != null && modules.length > 0) { + List<Resource> resources = new ArrayList<>(); + for (File path : modules) { + if (!path.exists()) { + logger.warn("Module path does not exist: {}", path.getAbsolutePath()); + continue; + } -// var kieBuilder = services.newKieBuilder(fileSystem); - var kieBuilder = services.newKieBuilder(path); - logger.info("Building module"); - kieBuilder.buildAll(); + logger.info("New KieBuilder: {}, file={}, directory={}", path, path.isFile(), path.isDirectory()); - logger.info("Module built!"); - - var results = kieBuilder.getResults(); - - for (Message message : results.getMessages(Level.INFO, Level.WARNING, Level.ERROR)) { -// logger.info("{} {}", message.getLevel(), message.getText()); - logger.info(message.toString()); + var resource = services.getResources().newFileSystemResource(path); + logger.info("resource.getResourceType() = {}", resource.getResourceType()); + resources.add(resource); } - var module = kieBuilder.getKieModule(); - releaseId = module.getReleaseId(); - logger.info("module.getReleaseId() = {}", releaseId); - logger.info("module.getClass() = {}", module.getClass()); - } + var module = kieRepository.addKieModule(resources.get(0), resources.subList(1, resources.size()).toArray(new Resource[0])); + logger.info("module.getReleaseId() = {}", module.getReleaseId()); + var rId = module.getReleaseId(); - logger.info("Creating classpath container"); -// var container = services.getKieClasspathContainer(); - var container = services.newKieContainer(releaseId); + logger.info("Creating classpath container, releaseId=" + rId); + container = services.newKieContainer(rId); + } else { + container = services.getKieClasspathContainer(); + } - logger.info("Creating KieBase"); + logger.info("Creating KieBase \"{}\"", name); logger.info("Available kie base names: {}", container.getKieBaseNames()); var kieBase = container.getKieBase(name); diff --git a/module/ri-engine/src/test/java/io/trygvis/rules/engine/WireguardTestMain.java b/module/ri-engine/src/test/java/io/trygvis/rules/engine/WireguardTestMain.java new file mode 100644 index 0000000..20aeffa --- /dev/null +++ b/module/ri-engine/src/test/java/io/trygvis/rules/engine/WireguardTestMain.java @@ -0,0 +1,19 @@ +package io.trygvis.rules.engine; + +import io.trygvis.rules.engine.cli.RunCommand; + +import java.io.File; + +import static org.junit.jupiter.api.Assertions.assertEquals; + +class WireguardTestMain { + public static void main(String[] args) throws Exception { + var c = new RunCommand(); + c.name = "acme"; + c.input = new File("acme.yaml"); + c.outputState = new File("out/acme/wireguard.yaml"); + c.agendaGroups = new String[]{"init", "generate"}; + c.generatedOutput = new File("acme-wireguard"); + assertEquals(0, c.call()); + } +} |