package org.openlmis.rnr.repository.mapper; import org.junit.Test; import org.junit.experimental.categories.Category; import org.junit.runner.RunWith; import org.openlmis.core.builder.FacilityBuilder; import org.openlmis.core.builder.ProcessingPeriodBuilder; import org.openlmis.core.builder.ProcessingScheduleBuilder; import org.openlmis.core.domain.Facility; import org.openlmis.core.domain.ProcessingPeriod; import org.openlmis.core.domain.ProcessingSchedule; import org.openlmis.core.domain.Program; import org.openlmis.core.query.QueryExecutor; import org.openlmis.core.repository.mapper.FacilityMapper; import org.openlmis.core.repository.mapper.ProcessingPeriodMapper; import org.openlmis.core.repository.mapper.ProcessingScheduleMapper; import org.openlmis.db.categories.IntegrationTests; import org.openlmis.rnr.domain.PatientQuantificationLineItem; import org.openlmis.rnr.domain.Rnr; import org.openlmis.rnr.domain.RnrStatus; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.test.context.ContextConfiguration; import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; import org.springframework.test.context.transaction.TransactionConfiguration; import org.springframework.transaction.annotation.Transactional; import java.sql.SQLException; import java.util.List; import static com.natpryce.makeiteasy.MakeItEasy.*; import static org.hamcrest.core.Is.is; import static org.junit.Assert.assertThat; import static org.openlmis.core.builder.ProcessingPeriodBuilder.defaultProcessingPeriod; import static org.openlmis.core.builder.ProcessingPeriodBuilder.scheduleId; @Category(IntegrationTests.class) @RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(locations = "classpath:test-applicationContext-requisition.xml") @Transactional @TransactionConfiguration(defaultRollback = true, transactionManager = "openLmisTransactionManager") public class PatientQuantificationLineItemMapperIT { @Autowired private PatientQuantificationLineItemMapper mapper; @Autowired private QueryExecutor queryExecutor; @Autowired private RequisitionMapper requisitionMapper; @Autowired private FacilityMapper facilityMapper; @Autowired private ProcessingScheduleMapper processingScheduleMapper; @Autowired private ProcessingPeriodMapper processingPeriodMapper; private Rnr rnr; @Test public void shouldInsertPatientQuantificationLineItemToDB() throws SQLException { setUpRequisitionData(); PatientQuantificationLineItem patientQuantificationLineItem = new PatientQuantificationLineItem("adult", 25); patientQuantificationLineItem.setRnrId(rnr.getId()); mapper.insert(patientQuantificationLineItem); List<PatientQuantificationLineItem> lineItemList = mapper.getPatientQuantificationLineItemsByRnrId(rnr.getId()); assertThat(lineItemList.get(0).getCategory(), is("adult")); assertThat(lineItemList.get(0).getTotal(), is(25)); } private void setUpRequisitionData() { Facility facility = make(a(FacilityBuilder.defaultFacility)); facilityMapper.insert(facility); ProcessingSchedule processingSchedule = make(a(ProcessingScheduleBuilder.defaultProcessingSchedule)); processingScheduleMapper.insert(processingSchedule); ProcessingPeriod processingPeriod = make(a(defaultProcessingPeriod, with(scheduleId, processingSchedule.getId()), with(ProcessingPeriodBuilder.name, "Period1"))); processingPeriodMapper.insert(processingPeriod); rnr = new Rnr(facility, new Program(2L), processingPeriod, false, 1L, 1L); rnr.setStatus(RnrStatus.INITIATED); requisitionMapper.insert(rnr); } }