gov.nih.nci.cabig.caaers.rules.deploy.MedicalInfoBusinessRulesTest.java Source code

Java tutorial

Introduction

Here is the source code for gov.nih.nci.cabig.caaers.rules.deploy.MedicalInfoBusinessRulesTest.java

Source

/*******************************************************************************
 * Copyright SemanticBits, Northwestern University and Akaza Research
 * 
 * Distributed under the OSI-approved BSD 3-Clause License.
 * See http://ncip.github.com/caaers/LICENSE.txt for details.
 ******************************************************************************/
package gov.nih.nci.cabig.caaers.rules.deploy;

import gov.nih.nci.cabig.caaers.domain.AnatomicSite;
import gov.nih.nci.cabig.caaers.domain.DiseaseTerm;
import gov.nih.nci.cabig.caaers.domain.ExpeditedAdverseEventReport;
import gov.nih.nci.cabig.caaers.domain.MetastaticDiseaseSite;
import gov.nih.nci.cabig.caaers.validation.ValidationErrors;

import org.apache.commons.lang.StringUtils;

import com.semanticbits.rules.objectgraph.NullSafeFieldExtractor;

public class MedicalInfoBusinessRulesTest extends AbstractBusinessRulesExecutionTestCase {

    String bindUri = "gov.nih.nci.cabig.caaers.rules.reporting_medical_info_section";

    public String getBindUri() {
        return bindUri;
    }

    @Override
    public String getRuleFile() {
        return "rules_reporting_medical_info.xml";
    }

    /**
      * RuleName : PAT_BR2A_CHK Rule : Disease Name Not Listed must not be null if Disease Name is
      * 'Solid tumor, NOS' or 'Hematopoietic malignancy, NOS'. Error Code : PAT_BR2A_ERR Error
      * Message : DISEASE_NAME_NOT_LISTED must be provided if DISEASE_NAME is "Solid tumor, NOS" or
      * "Hematopoietic malignancy, NOS".
      *
      * @throws Exception
      */
    public void testOtherDiseaseName_WhenDiseaseTermIsSolidTumorNOS() throws Exception {
        ExpeditedAdverseEventReport aeReport = createAEReport();
        aeReport.getSaeReportPreExistingConditions().clear();

        ValidationErrors errors = fireRules(aeReport);

        assertEquals("No errors when OtherDiseaseName is present", 0, errors.getErrorCount());
    }

    /**
     * RuleName : PAT_BR2A_CHK Rule : Disease Name Not Listed must not be null if Disease Name is
     * 'Solid tumor, NOS' or 'Hematopoietic malignancy, NOS'. Error Code : PAT_BR2A_ERR Error
     * Message : DISEASE_NAME_NOT_LISTED must be provided if DISEASE_NAME is "Solid tumor, NOS" or
     * "Hematopoietic malignancy, NOS".
     *
     * @throws Exception
     */
    public void testOtherDiseaseName_WhenDiseaseTermIsHematopoieticmalignancyNOS() throws Exception {
        ExpeditedAdverseEventReport aeReport = createAEReport();
        aeReport.getSaeReportPreExistingConditions().clear();

        DiseaseTerm diseaseTerm = new DiseaseTerm();
        diseaseTerm.setTerm("Hematopoietic malignancy, NOS");
        aeReport.getDiseaseHistory().getAbstractStudyDisease().setTerm(diseaseTerm);
        ValidationErrors errors = fireRules(aeReport);

        assertEquals("No errors when OtherDiseaseName is present", 0, errors.getErrorCount());
    }

    /**
     * RuleName : PAT_BR3_CHK
     * Rule : "'Other Primary Site of Disease'  must not be provided if 'Primary Site of Disease' is provided and vice-versa.
     * Error Code : PAT_BR3B_ERR
     * Error Message :  Either and only PRIMARY_SITE_OF_DISEASE or OTHER_PRIMARY_SITE_OF_DISEASE must be provided.
     */
    public void testOtherPrimarySiteOfDisease_NullCodedPrimaryDisease() throws Exception {
        ExpeditedAdverseEventReport aeReport = createAEReport();
        aeReport.getSaeReportPreExistingConditions().clear();

        aeReport.getDiseaseHistory().setCodedPrimaryDiseaseSite(null);
        aeReport.getDiseaseHistory().setOtherPrimaryDiseaseSite("OtherSite");

        System.out.println("b0: "
                + NullSafeFieldExtractor.extractField(aeReport, "diseaseHistory.codedPrimaryDiseaseSite.name"));
        System.out.println("b1" + StringUtils.equalsIgnoreCase(
                NullSafeFieldExtractor.extractStringField(aeReport, "diseaseHistory.codedPrimaryDiseaseSite.name"),
                "Other, specify"));

        System.out.println("a1 :" + "null"
                .equals(NullSafeFieldExtractor.extractField(aeReport, "diseaseHistory.codedPrimaryDiseaseSite")));
        System.out.println("a2 :" + StringUtils.equalsIgnoreCase(
                NullSafeFieldExtractor.extractStringField(aeReport, "diseaseHistory.codedPrimaryDiseaseSite.name"),
                "Other, specify"));

        System.out.println("Condition 2 :"
                + NullSafeFieldExtractor.extractField(aeReport, "diseaseHistory.otherPrimaryDiseaseSite") != null);

        ValidationErrors errors = fireRules(aeReport);

        assertEquals("No Errors when OtherPrimarySiteOfDisease is only present", 0, errors.getErrorCount());
    }

    /**
     * RuleName : PAT_BR3_CHK
     * Rule : "'Other Primary Site of Disease'  must not be provided if 'Primary Site of Disease' is provided and vice-versa.
     * Error Code : PAT_BR3B_ERR
     * Error Message :  Either and only PRIMARY_SITE_OF_DISEASE or OTHER_PRIMARY_SITE_OF_DISEASE must be provided.
     */
    public void testOtherPrimarySiteOfDisease_OtherCodedPrimaryDiseaseSite() throws Exception {
        ExpeditedAdverseEventReport aeReport = createAEReport();
        aeReport.getSaeReportPreExistingConditions().clear();

        AnatomicSite site = new AnatomicSite();
        site.setName("Other, specify");
        aeReport.getDiseaseHistory().setCodedPrimaryDiseaseSite(site);
        aeReport.getDiseaseHistory().setOtherPrimaryDiseaseSite("OtherSite");
        ValidationErrors errors = fireRules(aeReport);

        assertEquals("No Errors when OtherPrimarySiteOfDisease is only present", 0, errors.getErrorCount());
    }

    /**
     * RuleName : PAT_BR3_CHK
     * Rule : "'Other Primary Site of Disease'  must not be provided if 'Primary Site of Disease' is provided and vice-versa.
     * Error Code : PAT_BR3B_ERR
     * Error Message :  Either and only PRIMARY_SITE_OF_DISEASE or OTHER_PRIMARY_SITE_OF_DISEASE must be provided.
     */
    public void testPrimarySiteOfDiseaseOnly() throws Exception {
        ExpeditedAdverseEventReport aeReport = createAEReport();
        aeReport.getSaeReportPreExistingConditions().clear();

        aeReport.getDiseaseHistory().setOtherPrimaryDiseaseSite(null);
        AnatomicSite diseaseSite = new AnatomicSite();
        diseaseSite.setName("orignal disease site");
        aeReport.getDiseaseHistory().setCodedPrimaryDiseaseSite(diseaseSite);
        ValidationErrors errors = fireRules(aeReport);

        assertEquals("No Errors when CodedPrimaryDiseaseSite is only present", 0, errors.getErrorCount());

    }

    /**
     * RuleName : PAT_BR2A_CHK Rule : Disease Name Not Listed must not be null if Disease Name is
     * 'Solid tumor, NOS' or 'Hematopoietic malignancy, NOS'. Error Code : PAT_BR2A_ERR Error
     * Message : DISEASE_NAME_NOT_LISTED must be provided if DISEASE_NAME is "Solid tumor, NOS" or
     * "Hematopoietic malignancy, NOS".
     *
     * @throws Exception
     */
    public void testNoOtherDiseaseName_WhenDiseaseTermIsNotHematopoieticmalignancyNOS() throws Exception {
        ExpeditedAdverseEventReport aeReport = createAEReport();
        aeReport.getSaeReportPreExistingConditions().clear();

        aeReport.getDiseaseHistory().setOtherPrimaryDisease(null);
        DiseaseTerm diseaseTerm = new DiseaseTerm();
        diseaseTerm.setTerm("xxxHematopoietic malignancy, NOS");
        aeReport.getDiseaseHistory().getAbstractStudyDisease().setTerm(diseaseTerm);
        ValidationErrors errors = fireRules(aeReport);

        assertEquals("No Errors when OtherDiseaseName is not present and diseaseTerm is not Hemtopoietc.....", 0,
                errors.getErrorCount());
    }

    /**
     * RuleName : PAT_BR2B_CHK Rule : Disease Name Not Listed must not be provided where Disease
     * Name is not 'Solid tumor, NOS' or 'Hematopoietic malignancy, NOS'. Error Code : PAT_BR2B_ERR
     * Error Message : DISEASE_NAME_NOT_LISTED must not be provided if DISEASE_NAME is not " Solid
     * tumor, NOS" or " Hematopoietic malignancy, NOS".
     *
     * @throws Exception
     */
    public void testOtherDiseaseName_WhenDiseaseTermIsNotHematopoieticmalignancyNOS() throws Exception {
        ExpeditedAdverseEventReport aeReport = createAEReport();
        aeReport.getSaeReportPreExistingConditions().clear();
        aeReport.getDiseaseHistory().setOtherPrimaryDisease("Some diesase");
        DiseaseTerm diseaseTerm = new DiseaseTerm();
        diseaseTerm.setTerm("abc NOS");
        aeReport.getDiseaseHistory().getAbstractStudyDisease().setTerm(diseaseTerm);
        ValidationErrors errors = fireRules(aeReport);
        assertEquals("Errors when OtherDiseaseName is present and disease is not Hematopoietic...", 1,
                errors.getErrorCount());
        assertEquals("Error code must be same", "PAT_BR2B_ERR", errors.getErrorAt(0).getCode());
        System.out.println(errors.getErrorAt(0).getFieldNames());
    }

    /**
     * RuleName : PAT_BR3_CHK Rule : "'Other Primary Site of Disease' must not be provided if
     * 'Primary Site of Disease' is provided and vice-versa. Error Code : PAT_BR3B_ERR Error Message :
     * Either and only PRIMARY_SITE_OF_DISEASE or OTHER_PRIMARY_SITE_OF_DISEASE must be provided.
     */
    public void testOtherPrimarySiteOfDiseaseOnly() throws Exception {
        ExpeditedAdverseEventReport aeReport = createAEReport();
        aeReport.getSaeReportPreExistingConditions().clear();
        aeReport.getDiseaseHistory().setOtherPrimaryDiseaseSite("OtherSite");
        ValidationErrors errors = fireRules(aeReport);
        assertEquals("No Errors when OtherPrimarySiteOfDisease is only present", 0, errors.getErrorCount());
    }

    /**
     * RuleName : PAT_BR3_CHK Rule : "'Other Primary Site of Disease' must not be provided if
     * 'Primary Site of Disease' is provided and vice-versa. Error Code : PAT_BR3B_ERR Error Message :
     * Either and only PRIMARY_SITE_OF_DISEASE or OTHER_PRIMARY_SITE_OF_DISEASE must be provided.
     */
    public void testNoPrimaryOrOtherDiseaseSite() throws Exception {
        ExpeditedAdverseEventReport aeReport = createAEReport();
        aeReport.getSaeReportPreExistingConditions().clear();

        aeReport.getDiseaseHistory().setOtherPrimaryDiseaseSite(null);
        aeReport.getDiseaseHistory().setCodedPrimaryDiseaseSite(null);
        ValidationErrors errors = fireRules(aeReport);

        assertEquals("No Errors when both other and coded disease site is not present", 0, errors.getErrorCount());
    }

    /**
     * RuleName : PAT_BR3_CHK Rule : "'Other Primary Site of Disease' must not be provided if
     * 'Primary Site of Disease' is provided and vice-versa. Error Code : PAT_BR3B_ERR Error Message :
     * Either and only PRIMARY_SITE_OF_DISEASE or OTHER_PRIMARY_SITE_OF_DISEASE must be provided.
     */
    public void testOtherPrimarySiteOfDisease_AndCodedSiteOfDisease() throws Exception {
        ExpeditedAdverseEventReport aeReport = createAEReport();
        aeReport.getSaeReportPreExistingConditions().clear();

        AnatomicSite diseaseSite = new AnatomicSite();
        diseaseSite.setName("orignal disease site");
        aeReport.getDiseaseHistory().setCodedPrimaryDiseaseSite(diseaseSite);
        aeReport.getDiseaseHistory().setOtherPrimaryDiseaseSite("some site");
        ValidationErrors errors = fireRules(aeReport);

        assertEquals("Errors when OtherDiseaseSite and CodedDiseaseSite is present ", 1, errors.getErrorCount());
        assertEquals("Error code must be same", "PAT_BR3B_ERR", errors.getErrorAt(0).getCode());

    }

    /**
     * RuleName : SMD_BR1_CHK Logic : 'Sites of Metastatic Disease' must not be provided if 'Other
     * Sites of Metastatic Disease' is provided and vice-versa. Error Code : SMD_BR1_ERR Error
     * Message : Either and only SITE_OF_METASTATIC_DISEASE or OTHER_SITE_OF_METASTATIC_DISEASE must
     * be provided.
     */
    public void testNoMetastaticDisease() throws Exception {
        ExpeditedAdverseEventReport aeReport = createAEReport();
        aeReport.getSaeReportPreExistingConditions().clear();

        ValidationErrors errors = fireRules(aeReport);
        assertNoErrors(errors, "No errors should be there when there are no metastatic diseases");
    }

    /**
     * RuleName : SMD_BR1_CHK Logic : 'Sites of Metastatic Disease' must not be provided if 'Other
     * Sites of Metastatic Disease' is provided and vice-versa. Error Code : SMD_BR1_ERR Error
     * Message : Either and only SITE_OF_METASTATIC_DISEASE or OTHER_SITE_OF_METASTATIC_DISEASE must
     * be provided.
     */
    public void testMetastaticDiseaseWithOnlySiteName() throws Exception {
        ExpeditedAdverseEventReport aeReport = createAEReport();
        aeReport.getSaeReportPreExistingConditions().clear();

        AnatomicSite diseaseSite = new AnatomicSite();
        diseaseSite.setName("orignal disease site");
        MetastaticDiseaseSite site = new MetastaticDiseaseSite();
        site.setCodedSite(diseaseSite);
        aeReport.getDiseaseHistory().addMetastaticDiseaseSite(site);
        ValidationErrors errors = fireRules(aeReport);
        assertNoErrors(errors, "No errors should be there when there only site name in metastatic disease");
    }

    /**
     * RuleName : SMD_BR1_CHK Logic : 'Sites of Metastatic Disease' must not be provided if 'Other
     * Sites of Metastatic Disease' is provided and vice-versa. Error Code : SMD_BR1_ERR Error
     * Message : Either and only SITE_OF_METASTATIC_DISEASE or OTHER_SITE_OF_METASTATIC_DISEASE must
     * be provided.
     */
    public void testMetastaticDiseaseWithOnlyOtherSiteName() throws Exception {
        ExpeditedAdverseEventReport aeReport = createAEReport();
        aeReport.getSaeReportPreExistingConditions().clear();

        MetastaticDiseaseSite site = new MetastaticDiseaseSite();
        site.setOtherSite("test");
        aeReport.getDiseaseHistory().addMetastaticDiseaseSite(site);
        ValidationErrors errors = fireRules(aeReport);
        assertNoErrors(errors, "No errors should be there when there only other site name in metastatic disease");
    }

    /**
     * RuleName : SMD_BR1_CHK Logic : 'Sites of Metastatic Disease' must not be provided if 'Other
     * Sites of Metastatic Disease' is provided and vice-versa. Error Code : SMD_BR1_ERR Error
     * Message : Either and only SITE_OF_METASTATIC_DISEASE or OTHER_SITE_OF_METASTATIC_DISEASE must
     * be provided.
     */
    public void testMetastaticDiseaseWithBothDiseaseNameAndOtherSiteName() throws Exception {
        ExpeditedAdverseEventReport aeReport = createAEReport();
        aeReport.getSaeReportPreExistingConditions().clear();

        AnatomicSite diseaseSite = new AnatomicSite();
        diseaseSite.setName("orignal disease site");
        MetastaticDiseaseSite site = new MetastaticDiseaseSite();
        site.setCodedSite(diseaseSite);
        site.setOtherSite("test");
        aeReport.getDiseaseHistory().addMetastaticDiseaseSite(site);
        ValidationErrors errors = fireRules(aeReport);
        assertCorrectErrorCode(errors, "SMD_BR1_ERR");
        assertSameErrorCount(errors, 1);
        assertNotNull(errors.getErrorAt(0).getFieldNames());
        Object i = errors.getErrorAt(0).getReplacementVariables()[0];
        assertCorrectFieldNames(errors.getErrorAt(0),
                "aeReport.diseaseHistory.metastaticDiseaseSites[" + i + "].codedSite",
                "aeReport.diseaseHistory.metastaticDiseaseSites[" + i + "].otherSite");
    }

    /**
     * RuleName : SMD_BR1_CHK Logic : 'Sites of Metastatic Disease' must not be provided if 'Other
     * Sites of Metastatic Disease' is provided and vice-versa. Error Code : SMD_BR1_ERR Error
     * Message : Either and only SITE_OF_METASTATIC_DISEASE or OTHER_SITE_OF_METASTATIC_DISEASE must
     * be provided.
     */
    public void testOneOutOfTwoHasBothMetastaticDiseaseAndOtherSite() throws Exception {
        ExpeditedAdverseEventReport aeReport = createAEReport();
        aeReport.getSaeReportPreExistingConditions().clear();

        AnatomicSite diseaseSite = new AnatomicSite();
        diseaseSite.setName("orignal disease site");
        MetastaticDiseaseSite site = new MetastaticDiseaseSite();
        site.setCodedSite(diseaseSite);
        aeReport.getDiseaseHistory().addMetastaticDiseaseSite(site);

        diseaseSite = new AnatomicSite();
        diseaseSite.setName("orignal disease site");
        site = new MetastaticDiseaseSite();
        site.setCodedSite(diseaseSite);
        site.setOtherSite("test");
        aeReport.getDiseaseHistory().addMetastaticDiseaseSite(site);
        ValidationErrors errors = fireRules(aeReport);
        assertCorrectErrorCode(errors, "SMD_BR1_ERR");
        assertSameErrorCount(errors, 1);
        assertSame("Replacement should be correct", 1, errors.getErrorAt(0).getReplacementVariables()[0]);

    }

    /**
     * RuleName : SMD_BR1_CHK Logic : 'Sites of Metastatic Disease' must not be provided if 'Other
     * Sites of Metastatic Disease' is provided and vice-versa. Error Code : SMD_BR1_ERR Error
     * Message : Either and only SITE_OF_METASTATIC_DISEASE or OTHER_SITE_OF_METASTATIC_DISEASE must
     * be provided.
     */
    public void testMetastaticDiseaseWithOnlySiteName_Is_Other() throws Exception {
        ExpeditedAdverseEventReport aeReport = createAEReport();
        aeReport.getSaeReportPreExistingConditions().clear();

        AnatomicSite diseaseSite = new AnatomicSite();
        diseaseSite.setName("Other, specify");
        MetastaticDiseaseSite site = new MetastaticDiseaseSite();
        site.setCodedSite(diseaseSite);
        aeReport.getDiseaseHistory().addMetastaticDiseaseSite(site);
        ValidationErrors errors = fireRules(aeReport);
        assertNoErrors(errors, "No errors should be there when there only site name in metastatic disease");
    }

    /**
     * RuleName : SMD_BR1_CHK Logic : 'Sites of Metastatic Disease' must not be provided if 'Other
     * Sites of Metastatic Disease' is provided and vice-versa. Error Code : SMD_BR1_ERR Error
     * Message : Either and only SITE_OF_METASTATIC_DISEASE or OTHER_SITE_OF_METASTATIC_DISEASE must
     * be provided.
     */
    public void testMetastaticDiseaseWithOnlySiteName_Is_OtherAndOtherSite() throws Exception {
        ExpeditedAdverseEventReport aeReport = createAEReport();
        aeReport.getSaeReportPreExistingConditions().clear();

        AnatomicSite diseaseSite = new AnatomicSite();
        diseaseSite.setName("Other, specify");
        MetastaticDiseaseSite site = new MetastaticDiseaseSite();

        site.setCodedSite(diseaseSite);
        site.setOtherSite("another");
        aeReport.getDiseaseHistory().addMetastaticDiseaseSite(site);
        ValidationErrors errors = fireRules(aeReport);
        assertNoErrors(errors, "No errors should be there when there only site name in metastatic disease");
    }
}