001 /**
002 * Copyright 2005-2014 The Kuali Foundation
003 *
004 * Licensed under the Educational Community License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 * http://www.opensource.org/licenses/ecl2.php
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 * See the License for the specific language governing permissions and
014 * limitations under the License.
015 */
016 package org.kuali.rice.krms.framework;
017
018 import static junit.framework.Assert.assertNotNull;
019
020 import java.util.ArrayList;
021 import java.util.Arrays;
022 import java.util.Collections;
023 import java.util.HashMap;
024 import java.util.List;
025 import java.util.Map;
026 import java.util.Set;
027
028 import org.junit.Test;
029 import org.kuali.rice.krms.api.engine.EngineResults;
030 import org.kuali.rice.krms.api.engine.ExecutionOptions;
031 import org.kuali.rice.krms.api.engine.ExecutionFlag;
032 import org.kuali.rice.krms.api.engine.Facts;
033 import org.kuali.rice.krms.api.engine.SelectionCriteria;
034 import org.kuali.rice.krms.api.engine.Term;
035 import org.kuali.rice.krms.api.engine.TermResolver;
036 import org.kuali.rice.krms.api.repository.LogicalOperator;
037 import org.kuali.rice.krms.api.repository.agenda.AgendaDefinition;
038 import org.kuali.rice.krms.framework.engine.Action;
039 import org.kuali.rice.krms.framework.engine.Agenda;
040 import org.kuali.rice.krms.framework.engine.BasicAgenda;
041 import org.kuali.rice.krms.framework.engine.BasicAgendaTree;
042 import org.kuali.rice.krms.framework.engine.BasicAgendaTreeEntry;
043 import org.kuali.rice.krms.framework.engine.BasicContext;
044 import org.kuali.rice.krms.framework.engine.BasicRule;
045 import org.kuali.rice.krms.framework.engine.ComparableTermBasedProposition;
046 import org.kuali.rice.krms.framework.engine.CompoundProposition;
047 import org.kuali.rice.krms.framework.engine.Context;
048 import org.kuali.rice.krms.framework.engine.ContextProvider;
049 import org.kuali.rice.krms.framework.engine.Proposition;
050 import org.kuali.rice.krms.framework.engine.ProviderBasedEngine;
051 import org.kuali.rice.krms.framework.engine.ResultLogger;
052 import org.kuali.rice.krms.framework.engine.Rule;
053 import org.kuali.rice.krms.framework.engine.expression.ComparisonOperator;
054 import org.kuali.rice.krms.framework.engine.expression.ComparisonOperatorServiceImpl;
055
056 public class ResultLoggingTest {
057 private static final ResultLogger LOG = ResultLogger.getInstance();
058
059 @Test
060 public void integrationTest() {
061
062 // build a simple rule
063 ComparisonOperator greaterThan = ComparisonOperator.GREATER_THAN;
064 greaterThan.setComparisonOperatorService(ComparisonOperatorServiceImpl.getInstance());
065 ComparisonOperator lessThan = ComparisonOperator.LESS_THAN;
066 lessThan.setComparisonOperatorService(ComparisonOperatorServiceImpl.getInstance());
067
068 Proposition prop1 = new ComparableTermBasedProposition(greaterThan, totalCostTerm, Integer.valueOf(1));
069 Proposition prop2 = new ComparableTermBasedProposition(lessThan, totalCostTerm, Integer.valueOf(1000));
070 CompoundProposition compoundProp1 = new CompoundProposition(LogicalOperator.AND, Arrays.asList(prop1, prop2));
071
072 Action action1 = new SayHelloAction();
073 Rule rule = new BasicRule("InBetween",compoundProp1, Arrays.asList(action1));
074
075 BasicAgendaTree agendaTree = new BasicAgendaTree(new BasicAgendaTreeEntry(rule));
076 Agenda agenda = new BasicAgenda(Collections.singletonMap(AgendaDefinition.Constants.EVENT, "test"), agendaTree);
077
078 Map<String, String> contextQualifiers = new HashMap<String, String>();
079 contextQualifiers.put("docTypeName", "Proposal");
080
081 List<TermResolver<?>> testResolvers = new ArrayList<TermResolver<?>>();
082 testResolvers.add(testResolver);
083
084 Context context = new BasicContext(Arrays.asList(agenda), testResolvers);
085 ContextProvider contextProvider = new ManualContextProvider(context);
086
087 SelectionCriteria selectionCriteria = SelectionCriteria.createCriteria(null, contextQualifiers,
088 Collections.singletonMap(AgendaDefinition.Constants.EVENT, "test"));
089
090 ProviderBasedEngine engine = new ProviderBasedEngine();
091 engine.setContextProvider(contextProvider);
092
093 // Set execution options to log execution
094 ExecutionOptions executionOptions = new ExecutionOptions().setFlag(ExecutionFlag.LOG_EXECUTION, true);
095
096 EngineResults results = engine.execute(selectionCriteria, Facts.EMPTY_FACTS, executionOptions);
097 assertNotNull(results);
098
099 }
100
101 private static final Term totalCostTerm = new Term("totalCost");
102
103 private static final TermResolver<Integer> testResolver = new TermResolver<Integer>(){
104
105 @Override
106 public int getCost() { return 1; }
107
108 @Override
109 public String getOutput() { return totalCostTerm.getName(); }
110
111 @Override
112 public Set<String> getPrerequisites() { return Collections.emptySet(); }
113
114 @Override
115 public Set<String> getParameterNames() {
116 return Collections.emptySet();
117 }
118
119 @Override
120 public Integer resolve(Map<String, Object> resolvedPrereqs, Map<String, String> parameters) {
121 return 5;
122 }
123 };
124
125 }