package com.constellio.app.modules.rm.model.calculators.container;
import com.constellio.app.modules.rm.RMTestRecords;
import com.constellio.app.modules.rm.services.RMSchemasRecordsServices;
import com.constellio.app.modules.rm.wrappers.ContainerRecord;
import com.constellio.model.entities.calculators.CalculatorParameters;
import com.constellio.model.entities.records.Record;
import com.constellio.model.entities.records.wrappers.User;
import com.constellio.model.entities.schemas.Schemas;
import com.constellio.model.services.records.RecordPhysicalDeleteOptions;
import com.constellio.model.services.records.RecordServices;
import com.constellio.model.services.records.RecordServicesException;
import com.constellio.model.services.search.SearchServices;
import com.constellio.sdk.tests.ConstellioTest;
import org.junit.Before;
import org.junit.Test;
import org.mockito.Mock;
import static com.constellio.model.services.search.query.logical.LogicalSearchQueryOperators.from;
import static org.assertj.core.api.Assertions.assertThat;
import static org.mockito.Mockito.spy;
import static org.mockito.Mockito.when;
/**
* Created by Constellio on 2016-12-19.
*/
public class ContainerRecordAvailableSizeCalculatorAcceptanceTest extends ConstellioTest {
RMTestRecords records = new RMTestRecords(zeCollection);
ContainerRecordAvailableSizeCalculator calculator;
RMSchemasRecordsServices rm;
RecordServices recordServices;
SearchServices searchServices;
@Mock CalculatorParameters parameters;
@Before
public void setUp() {
givenBackgroundThreadsEnabled();
calculator = spy(new ContainerRecordAvailableSizeCalculator());
prepareSystem(
withZeCollection().withConstellioRMModule().withAllTestUsers()
.withRMTest(records).withFoldersAndContainersOfEveryStatus().withDocumentsDecommissioningList()
);
rm = new RMSchemasRecordsServices(zeCollection, getAppLayerFactory());
recordServices = getModelLayerFactory().newRecordServices();
searchServices = getModelLayerFactory().newSearchServices();
}
@Test
public void givenParametersThenCalculatorReturnsGoodValue() {
when(parameters.get(calculator.linearSizeParam)).thenReturn(new Double(6));
when(parameters.get(calculator.capacityParam)).thenReturn(new Double(10));
assertThat(calculator.calculate(parameters)).isEqualTo(4);
when(parameters.get(calculator.linearSizeParam)).thenReturn(new Double(6));
when(parameters.get(calculator.capacityParam)).thenReturn(null);
assertThat(calculator.calculate(parameters)).isEqualTo(null);
when(parameters.get(calculator.linearSizeParam)).thenReturn(null);
when(parameters.get(calculator.capacityParam)).thenReturn(new Double(10));
assertThat(calculator.calculate(parameters)).isEqualTo(10);
when(parameters.get(calculator.linearSizeParam)).thenReturn(null);
when(parameters.get(calculator.capacityParam)).thenReturn(null);
assertThat(calculator.calculate(parameters)).isEqualTo(null);
}
@Test
public void givenContainerWithCapacityAndLinearSizeThenAvailableSizeIsEqualToDifference()
throws RecordServicesException {
ContainerRecord containerRecord = buildDefaultContainer().setCapacity(new Double(10)).setLinearSizeEntered(6);
recordServices.add(containerRecord);
getModelLayerFactory().getBatchProcessesManager().waitUntilAllFinished();
Record record = searchServices.searchSingleResult(from(rm.containerRecord.schemaType()).where(Schemas.IDENTIFIER).isEqualTo("containerTest"));
assertThat(rm.wrapContainerRecord(record).getLinearSizeEntered()).isEqualTo(6);
assertThat(rm.wrapContainerRecord(record).getLinearSize()).isEqualTo(new Double(6));
assertThat(rm.wrapContainerRecord(record).getCapacity()).isEqualTo(new Double(10));
assertThat(rm.wrapContainerRecord(record).getAvailableSize()).isEqualTo(new Double(4));
}
@Test
public void givenContainerWithoutCapacityThenAvailableSizeIsNull()
throws RecordServicesException {
ContainerRecord containerRecord = buildDefaultContainer().setLinearSizeEntered(6);
recordServices.add(containerRecord);
getModelLayerFactory().getBatchProcessesManager().waitUntilAllFinished();
Record record = searchServices.searchSingleResult(from(rm.containerRecord.schemaType()).where(Schemas.IDENTIFIER).isEqualTo("containerTest"));
assertThat(rm.wrapContainerRecord(record).getLinearSizeEntered()).isEqualTo(6);
assertThat(rm.wrapContainerRecord(record).getLinearSize()).isEqualTo(new Double(6));
assertThat(rm.wrapContainerRecord(record).getCapacity()).isNull();
assertThat(rm.wrapContainerRecord(record).getAvailableSize()).isNull();
recordServices.physicallyDeleteNoMatterTheStatus(record, User.GOD, new RecordPhysicalDeleteOptions());
containerRecord = buildDefaultContainer();
recordServices.add(containerRecord);
getModelLayerFactory().getBatchProcessesManager().waitUntilAllFinished();
record = searchServices.searchSingleResult(from(rm.containerRecord.schemaType()).where(Schemas.IDENTIFIER).isEqualTo("containerTest"));
assertThat(rm.wrapContainerRecord(record).getLinearSizeEntered()).isNull();
assertThat(rm.wrapContainerRecord(record).getLinearSize()).isEqualTo(new Double(0));
assertThat(rm.wrapContainerRecord(record).getCapacity()).isNull();
assertThat(rm.wrapContainerRecord(record).getAvailableSize()).isNull();
}
@Test
public void givenContainerWithFullMetadataSetToTrueThenAvailableSizeIsZeroOrNull()
throws RecordServicesException {
ContainerRecord containerRecord = buildDefaultContainer();
containerRecord.setFull(Boolean.TRUE);
containerRecord.setCapacity(42);
recordServices.add(containerRecord);
getModelLayerFactory().getBatchProcessesManager().waitUntilAllFinished();
Record record = searchServices.searchSingleResult(from(rm.containerRecord.schemaType()).where(Schemas.IDENTIFIER).isEqualTo("containerTest"));
assertThat(rm.wrapContainerRecord(record).getLinearSizeEntered()).isNull();
assertThat(rm.wrapContainerRecord(record).getLinearSizeSum()).isEqualTo(new Double(0));
assertThat(rm.wrapContainerRecord(record).getLinearSize()).isEqualTo(new Double(42));
assertThat(rm.wrapContainerRecord(record).getAvailableSize()).isEqualTo(new Double(0));
containerRecord.setCapacity(null);
recordServices.add(containerRecord);
getModelLayerFactory().getBatchProcessesManager().waitUntilAllFinished();
record = searchServices.searchSingleResult(from(rm.containerRecord.schemaType()).where(Schemas.IDENTIFIER).isEqualTo("containerTest"));
assertThat(rm.wrapContainerRecord(record).getLinearSizeEntered()).isNull();
assertThat(rm.wrapContainerRecord(record).getLinearSizeSum()).isEqualTo(new Double(0));
assertThat(rm.wrapContainerRecord(record).getLinearSize()).isNull();
assertThat(rm.wrapContainerRecord(record).getAvailableSize()).isNull();
}
public ContainerRecord buildDefaultContainer() {
return rm.newContainerRecordWithId("containerTest").setType(records.containerTypeId_boite22x22).setTemporaryIdentifier("containerTestTemporary");
}
}