Skip to content

Instantly share code, notes, and snippets.

Show Gist options
  • Save hellowdan/c7488e9d386981192af61a553b366a86 to your computer and use it in GitHub Desktop.
Save hellowdan/c7488e9d386981192af61a553b366a86 to your computer and use it in GitHub Desktop.
/*
* Copyright 2016 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.
* You may obtain a copy of the License at
*
* 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.benchmarks.turtle.runtime;
import java.io.IOException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.TimeUnit;
import org.drools.benchmarks.turtle.runtime.generator.FactsGenerator;
import org.drools.benchmarks.turtle.runtime.generator.ResourceGenerator;
import org.drools.modelcompiler.ExecutableModelProject;
import org.kie.api.KieBase;
import org.kie.api.KieBaseConfiguration;
import org.kie.api.KieServices;
import org.kie.api.builder.KieBuilder;
import org.kie.api.builder.KieFileSystem;
import org.kie.api.builder.Message;
import org.kie.api.builder.Results;
import org.kie.api.conf.KieBaseOption;
import org.kie.api.io.KieResources;
import org.kie.api.io.Resource;
import org.kie.api.runtime.KieContainer;
import org.kie.api.runtime.KieSession;
import org.kie.api.runtime.StatelessKieSession;
import org.kie.internal.utils.KieHelper;
import org.openjdk.jmh.annotations.BenchmarkMode;
import org.openjdk.jmh.annotations.Level;
import org.openjdk.jmh.annotations.Measurement;
import org.openjdk.jmh.annotations.Mode;
import org.openjdk.jmh.annotations.OutputTimeUnit;
import org.openjdk.jmh.annotations.Param;
import org.openjdk.jmh.annotations.Scope;
import org.openjdk.jmh.annotations.Setup;
import org.openjdk.jmh.annotations.State;
import org.openjdk.jmh.annotations.TearDown;
import org.openjdk.jmh.annotations.Warmup;
@BenchmarkMode(Mode.SingleShotTime)
@State(Scope.Thread)
@Warmup(iterations = 30)
@Measurement(iterations = 20)
@OutputTimeUnit(TimeUnit.MILLISECONDS)
public abstract class AbstractSimpleRuntimeBenchmark {
// @Param({"true", "false"})
@Param({"false", "true"})
protected boolean useCanonicalModel;
protected KieServices kieServices = KieServices.Factory.get();
public final KieFileSystem kfs = kieServices.newKieFileSystem();
protected KieResources kieResources = KieServices.Factory.get().getResources();
protected Set<Resource> resources;
protected List<Object> facts;
/**
* Generator to number of facts to generate mapping
*/
protected Map<ResourceGenerator, Integer> factsGenerators;
protected volatile KieBase kieBase;
protected KieSession ksession;
protected StatelessKieSession statelessKieSession;
public AbstractSimpleRuntimeBenchmark() {
resources = new HashSet<>();
facts = new ArrayList<>();
factsGenerators = new HashMap<>();
}
public KieBase build(KieBaseOption... options) {
KieContainer kieContainer = getKieContainer();
if (options == null || options.length == 0) {
return kieContainer.getKieBase();
}
KieBaseConfiguration kieBaseConf = kieServices.newKieBaseConfiguration();
for (KieBaseOption option : options) {
kieBaseConf.setOption(option);
}
return kieContainer.newKieBase(kieBaseConf);
}
public KieContainer getKieContainer() {
KieBuilder kieBuilder = buildAllWithExecutableModel();
Results results = kieBuilder.getResults();
if (results.hasMessages(Message.Level.ERROR)) {
throw new RuntimeException(results.getMessages().toString());
}
KieContainer kieContainer = kieServices.newKieContainer(kieServices.getRepository().getDefaultReleaseId(), null);
return kieContainer;
}
private KieBuilder buildAllWithExecutableModel() {
return kieServices.newKieBuilder(kfs, null).buildAll(ExecutableModelProject.class);
}
public void addResource(Resource resource) {
kfs.write(resource);
}
@Setup
public void createKBase() {
addResources();
if (useCanonicalModel) {
System.out.print("ExecutableModelProject.class - ");
for (Resource resource : resources) {
addResource(resource);
}
kieBase = build(getKieBaseOptions());
} else {
System.out.print("DrlProject.class - ");
KieHelper kieHelper = new KieHelper();
for (Resource resource : resources) {
kieHelper.addResource(resource);
}
kieBase = kieHelper.build(getKieBaseOptions());
}
}
@Setup
public void initFactsGenerators() throws IOException {
addFactsGenerators();
}
@Setup(Level.Iteration)
public void gatherFacts() {
facts.clear();
generateFactsUsingGenerators();
facts.addAll(generateFacts());
}
@TearDown(Level.Iteration)
public void disposeKSession() {
if (ksession != null) {
ksession.dispose();
}
}
protected KieBaseOption[] getKieBaseOptions() {
return new KieBaseOption[]{};
}
protected void addResources() {
// Intentionally blank.
}
protected void addFactsGenerators() {
// Intentionally blank.
}
protected List<Object> generateFacts() {
return new ArrayList<Object>();
}
protected void generateFactsUsingGenerators() {
for (Map.Entry<ResourceGenerator, Integer> entry : factsGenerators.entrySet()) {
ResourceGenerator generator = entry.getKey();
int nrOfFacts = entry.getValue();
if (generator instanceof FactsGenerator) {
facts.addAll(((FactsGenerator) generator).generateFacts(nrOfFacts));
}
}
}
protected void addClassPathResource(String path) {
resources.add(kieResources.newClassPathResource(path));
}
protected void addFactsGenerator(ResourceGenerator generator, int nrOfFacts) {
factsGenerators.put(generator, nrOfFacts);
}
public KieSession insertFactsAndFireAllRules() {
ksession = kieBase.newKieSession();
for (Object fact : facts) {
ksession.insert(fact);
}
ksession.fireAllRules();
ksession.dispose();
return ksession;
}
public StatelessKieSession insertFactsAndExecuteStateless() {
statelessKieSession = kieBase.newStatelessKieSession();
statelessKieSession.execute(facts);
return statelessKieSession;
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment