package org.openmrs.module.reporting.cohort.definition.evaluator;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.junit.Assert;
import org.junit.Before;
import org.junit.Test;
import org.openmrs.Cohort;
import org.openmrs.Patient;
import org.openmrs.api.context.Context;
import org.openmrs.module.reporting.cohort.EvaluatedCohort;
import org.openmrs.module.reporting.cohort.definition.CohortDefinition;
import org.openmrs.module.reporting.cohort.definition.CompositionCohortDefinition;
import org.openmrs.module.reporting.cohort.definition.SqlCohortDefinition;
import org.openmrs.module.reporting.cohort.definition.service.CohortDefinitionService;
import org.openmrs.module.reporting.common.DateUtil;
import org.openmrs.module.reporting.common.TestUtil;
import org.openmrs.module.reporting.dataset.DataSet;
import org.openmrs.module.reporting.dataset.DataSetRow;
import org.openmrs.module.reporting.dataset.definition.CohortIndicatorDataSetDefinition;
import org.openmrs.module.reporting.dataset.definition.service.DataSetDefinitionService;
import org.openmrs.module.reporting.evaluation.EvaluationContext;
import org.openmrs.module.reporting.evaluation.EvaluationException;
import org.openmrs.module.reporting.evaluation.parameter.Mapped;
import org.openmrs.module.reporting.evaluation.parameter.Parameter;
import org.openmrs.module.reporting.evaluation.parameter.ParameterizableUtil;
import org.openmrs.module.reporting.indicator.CohortIndicator;
import org.openmrs.test.BaseContextSensitiveTest;
import org.openmrs.test.BaseModuleContextSensitiveTest;
import org.openmrs.test.Verifies;
import org.springframework.beans.factory.annotation.Autowired;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.HashMap;
import java.util.HashSet;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import java.util.Set;
/**
* Tests the expected behavior of the CompositionCohortDefinitionEvaluator
*/
public class CompositionCohortDefinitionEvaluatorTest extends BaseModuleContextSensitiveTest {
protected final Log log = LogFactory.getLog(getClass());
protected static final String XML_DATASET_PATH = "org/openmrs/module/reporting/include/";
protected static final String XML_REPORT_TEST_DATASET = "ReportTestDataset";
@Before
public void setup() throws Exception {
executeDataSet(XML_DATASET_PATH + new TestUtil().getTestDatasetFilename(XML_REPORT_TEST_DATASET));
}
public CompositionCohortDefinition getBaseDefinition() {
CompositionCohortDefinition ccd = new CompositionCohortDefinition();
ccd.addSearch("c1", Mapped.noMappings(new SqlCohortDefinition("select patient_id from patient where patient_id in (2,6,7,8)")));
ccd.addSearch("c2", Mapped.noMappings(new SqlCohortDefinition("select patient_id from patient where patient_id in (21,22,23,24)")));
ccd.addSearch("c3", Mapped.noMappings(new SqlCohortDefinition("select patient_id from patient where patient_id in (7,8,21,22)")));
return ccd;
}
public void testComposition(String compositionString, Integer...expectedIds) throws Exception {
CompositionCohortDefinition ccd = getBaseDefinition();
ccd.setCompositionString(compositionString);
EvaluatedCohort cohort = Context.getService(CohortDefinitionService.class).evaluate(ccd, new EvaluationContext());
if (expectedIds == null) {
Assert.assertEquals(0, cohort.size());
}
else {
Assert.assertEquals(expectedIds.length, cohort.size());
for (Integer expectedId : expectedIds) {
Assert.assertTrue(cohort.contains(expectedId));
}
}
}
@Test
public void evaluate_shouldHandleAnd() throws Exception {
testComposition("c1 and c2");
testComposition("c2 and c3", 21,22);
testComposition("c1 and c3", 7,8);
}
@Test
public void evaluate_shouldHandleOr() throws Exception {
testComposition("c1 or c2", 2,6,7,8,21,22,23,24);
testComposition("c2 or c3", 7,8,21,22,23,24);
testComposition("c1 or c3", 2,6,7,8,21,22);
}
@Test
public void evaluate_shouldHandleNot() throws Exception {
testComposition("not c1", 20,21,22,23,24);
testComposition("c1 and not c3", 2,6);
}
@Test
public void evaluate_shouldHandleParenthesis() throws Exception {
testComposition("(c1 or c3) and not c2", 2,6,7,8);
testComposition("(c1 or c2) and not c3", 2,6,23,24);
}
}