From 5804ec20e35b4187ad957493c7f8ab282c5be25b Mon Sep 17 00:00:00 2001 From: Aliou DIAITE Date: Fri, 1 Dec 2023 17:20:02 +0100 Subject: [PATCH] feat(#359): use a POJO for allowed FCDA list in CB Report for HMI creation Signed-off-by: Aliou DIAITE --- sct-commons/pom.xml | 19 +++++ .../compas/sct/commons/HmiService.java | 8 +- .../compas/sct/commons/api/HmiEditor.java | 8 +- .../commons/scl/ldevice/LDeviceAdapter.java | 31 +++++-- .../sct/commons/util/FcdaCsvHelper.java | 51 +----------- .../xsd/CB_REPORT_SUPERVISION_Config_file.xsd | 72 ++++++++++++++++ .../compas/sct/commons/HmiServiceTest.java | 83 ++++++++++++++----- .../sct/commons/util/FcdaCsvHelperTest.java | 28 +------ 8 files changed, 188 insertions(+), 112 deletions(-) create mode 100644 sct-commons/src/main/resources/xsd/CB_REPORT_SUPERVISION_Config_file.xsd diff --git a/sct-commons/pom.xml b/sct-commons/pom.xml index 3b9236fa4..c807d1237 100644 --- a/sct-commons/pom.xml +++ b/sct-commons/pom.xml @@ -195,6 +195,25 @@ false + + cb_po + + xjc + + + + + ${project.basedir}/src/main/resources/xsd/CB_REPORT_SUPERVISION_Config_file.xsd + + + + ${project.basedir}/src/main/resources/binding_configuration.xjb + + org.lfenergy.compas.sct.commons.model.cb_po + true + false + + diff --git a/sct-commons/src/main/java/org/lfenergy/compas/sct/commons/HmiService.java b/sct-commons/src/main/java/org/lfenergy/compas/sct/commons/HmiService.java index ef9477aa8..8969e7ad3 100644 --- a/sct-commons/src/main/java/org/lfenergy/compas/sct/commons/HmiService.java +++ b/sct-commons/src/main/java/org/lfenergy/compas/sct/commons/HmiService.java @@ -5,21 +5,19 @@ package org.lfenergy.compas.sct.commons; import org.lfenergy.compas.scl2007b4.model.SCL; -import org.lfenergy.compas.scl2007b4.model.TFCDA; import org.lfenergy.compas.sct.commons.api.HmiEditor; +import org.lfenergy.compas.sct.commons.model.cb_po.PO; import org.lfenergy.compas.sct.commons.scl.SclRootAdapter; import org.lfenergy.compas.sct.commons.scl.ied.IEDAdapter; -import java.util.List; - public class HmiService implements HmiEditor { @Override - public void createAllHmiReportControlBlocks(SCL scd, List fcdas) { + public void createAllHmiReportControlBlocks(SCL scd, PO po) { SclRootAdapter sclRootAdapter = new SclRootAdapter(scd); sclRootAdapter.streamIEDAdapters() .flatMap(IEDAdapter::streamLDeviceAdapters) - .forEach(lDeviceAdapter -> lDeviceAdapter.createHmiReportControlBlocks(fcdas)); + .forEach(lDeviceAdapter -> lDeviceAdapter.createHmiReportControlBlocks(po)); } } diff --git a/sct-commons/src/main/java/org/lfenergy/compas/sct/commons/api/HmiEditor.java b/sct-commons/src/main/java/org/lfenergy/compas/sct/commons/api/HmiEditor.java index 548cac764..d90a55626 100644 --- a/sct-commons/src/main/java/org/lfenergy/compas/sct/commons/api/HmiEditor.java +++ b/sct-commons/src/main/java/org/lfenergy/compas/sct/commons/api/HmiEditor.java @@ -5,10 +5,8 @@ package org.lfenergy.compas.sct.commons.api; import org.lfenergy.compas.scl2007b4.model.SCL; -import org.lfenergy.compas.scl2007b4.model.TFCDA; import org.lfenergy.compas.scl2007b4.model.TReportControl; - -import java.util.List; +import org.lfenergy.compas.sct.commons.model.cb_po.PO; /** * Service class that will be used to manage elements related to the HMI {@link TReportControl Report Control Blocks}. @@ -20,7 +18,7 @@ public interface HmiEditor { /** * Create the DataSet and ReportControl Blocks for the HMI with the given FCDAs. * - * @param fcdas List of FCDA for which we must create the DataSet and ReportControl Blocks + * @param po object containing list of FCDA for which we must create the DataSet and ReportControl Blocks */ - void createAllHmiReportControlBlocks(SCL scd, List fcdas); + void createAllHmiReportControlBlocks(SCL scd, PO po); } diff --git a/sct-commons/src/main/java/org/lfenergy/compas/sct/commons/scl/ldevice/LDeviceAdapter.java b/sct-commons/src/main/java/org/lfenergy/compas/sct/commons/scl/ldevice/LDeviceAdapter.java index 06d037c1f..15d8ae935 100644 --- a/sct-commons/src/main/java/org/lfenergy/compas/sct/commons/scl/ldevice/LDeviceAdapter.java +++ b/sct-commons/src/main/java/org/lfenergy/compas/sct/commons/scl/ldevice/LDeviceAdapter.java @@ -10,6 +10,8 @@ import org.lfenergy.compas.scl2007b4.model.*; import org.lfenergy.compas.sct.commons.dto.*; import org.lfenergy.compas.sct.commons.exception.ScdException; +import org.lfenergy.compas.sct.commons.model.cb_po.PO; +import org.lfenergy.compas.sct.commons.model.cb_po.TFCDAFilter; import org.lfenergy.compas.sct.commons.scl.SclElementAdapter; import org.lfenergy.compas.sct.commons.scl.dtt.DataTypeTemplateAdapter; import org.lfenergy.compas.sct.commons.scl.ied.ControlBlockAdapter; @@ -81,20 +83,20 @@ public LDeviceAdapter(IEDAdapter parentAdapter, TLDevice currentElem) { * Create DataSet and ReportControl Blocks for the HMI with the given FCDAs. * DataSet and ReportControl are created in LN0, even if FCDA refers to another LN. * - * @param fcdas List of FCDA for which we must create the DataSet and ReportControl + * @param po object containing list of FCDA for which we must create the DataSet and ReportControl */ - public void createHmiReportControlBlocks(List fcdas) { + public void createHmiReportControlBlocks(PO po) { LN0Adapter ln0 = getLN0Adapter(); if (!ln0.getDaiModStValValue().map(ActiveStatus::fromValue).map(ActiveStatus.ON::equals).orElse(false)) return; - fcdas.stream() - .filter(fcda -> getInst().equals(fcda.getLdInst()) && fcda.isSetLnClass()) - .forEach(fcda -> (fcda.getLnClass().get(0).equals(TLLN0Enum.LLN_0.value()) ? + po.getFCDAs().getFCDA().stream() + .filter(tfcdaFilter -> getInst().equals(tfcdaFilter.getLdInst()) && tfcdaFilter.isSetLnClass()) + .forEach(tfcdaFilter -> (tfcdaFilter.getLnClass().equals(TLLN0Enum.LLN_0.value()) ? Optional.of(ln0) // ln0 Mod stVal "ON" has already been checked, no need to check it again : - findLnAdapter(fcda.getLnClass().get(0), fcda.getLnInst(), fcda.getPrefix()).filter(lnAdapter -> lnAdapter.getDaiModStValValue().map(ActiveStatus::fromValue).map(ActiveStatus.ON::equals).orElse(true))) - .map(sourceLn -> sourceLn.getDAI(new DataAttributeRef(fcda), false)) - .filter(das -> das.stream().anyMatch(da -> fcda.getFc() == da.getFc())) // getDAI does not filter on DA. - .ifPresent(dataAttributeRefs -> createHmiReportCB(ln0, fcda))); + findLnAdapter(tfcdaFilter.getLnClass(), tfcdaFilter.getLnInst(), tfcdaFilter.getPrefix()).filter(lnAdapter -> lnAdapter.getDaiModStValValue().map(ActiveStatus::fromValue).map(ActiveStatus.ON::equals).orElse(true))) + .map(sourceLn -> sourceLn.getDAI(new DataAttributeRef(toFCDA(tfcdaFilter)), false)) + .filter(das -> das.stream().anyMatch(da -> TFCEnum.fromValue(tfcdaFilter.getFc().value()) == da.getFc())) // getDAI does not filter on DA. + .ifPresent(dataAttributeRefs -> createHmiReportCB(ln0, toFCDA(tfcdaFilter)))); } private void createHmiReportCB(LN0Adapter ln0, TFCDA fcda) { @@ -514,4 +516,15 @@ public List getExtRefBayReferenceForActifLDEPF(fi return extRefBayReferenceList; } + private TFCDA toFCDA(TFCDAFilter tfcdaFilter) { + TFCDA tfcda = new TFCDA(); + tfcda.setLdInst(tfcdaFilter.getLdInst()); + tfcda.getLnClass().add(tfcdaFilter.getLnClass()); + tfcda.setPrefix(tfcdaFilter.getPrefix()); + tfcda.setLnInst(tfcdaFilter.getLnInst()); + tfcda.setDoName(tfcdaFilter.getDoName()); + tfcda.setFc(TFCEnum.fromValue(tfcdaFilter.getFc().value())); + return tfcda; + } + } diff --git a/sct-commons/src/main/java/org/lfenergy/compas/sct/commons/util/FcdaCsvHelper.java b/sct-commons/src/main/java/org/lfenergy/compas/sct/commons/util/FcdaCsvHelper.java index 659e11fb4..d4a20ad51 100644 --- a/sct-commons/src/main/java/org/lfenergy/compas/sct/commons/util/FcdaCsvHelper.java +++ b/sct-commons/src/main/java/org/lfenergy/compas/sct/commons/util/FcdaCsvHelper.java @@ -4,33 +4,25 @@ package org.lfenergy.compas.sct.commons.util; -import com.opencsv.bean.CsvBindByPosition; import lombok.Getter; import org.lfenergy.compas.scl2007b4.model.SCL; -import org.lfenergy.compas.scl2007b4.model.TFCDA; -import org.lfenergy.compas.scl2007b4.model.TFCEnum; import org.lfenergy.compas.sct.commons.dto.FcdaForDataSetsCreation; import java.io.Reader; import java.util.HashSet; -import java.util.List; import java.util.Set; /** * This class is a helper method to load FCDA from a CSV files for use with - * {@link org.lfenergy.compas.sct.commons.HmiService#createAllHmiReportControlBlocks(SCL, List)} - * {@link org.lfenergy.compas.sct.commons.ExtRefService#createDataSetAndControlBlocks(SCL, Set)} - * {@link org.lfenergy.compas.sct.commons.ExtRefService#createDataSetAndControlBlocks(SCL, String, Set)} - * {@link org.lfenergy.compas.sct.commons.ExtRefService#createDataSetAndControlBlocks(SCL, String, String, Set)} + * {@link org.lfenergy.compas.sct.commons.ControlBlockService#createDataSetAndControlBlocks(SCL, Set)} + * {@link org.lfenergy.compas.sct.commons.ControlBlockService#createDataSetAndControlBlocks(SCL, String, Set)} + * {@link org.lfenergy.compas.sct.commons.ControlBlockService#createDataSetAndControlBlocks(SCL, String, String, Set)} * Use the getter to access the list of parsed FCDA. * * @see CsvUtils */ public class FcdaCsvHelper { - @Getter - private final List fcdaForHmiReportControls; - @Getter private final Set fcdaForDataSets; @@ -39,46 +31,11 @@ public class FcdaCsvHelper { * Provide the CSV files as a Reader. For example, you can create a reader like this : * new InputStreamReader(getClass().getClassLoader().getResourceAsStream(fileName), StandardCharsets.UTF_8); * - * @param csvSourceForHmiReportControl a reader that provides the FCDA datas for HMI ReportControl Blocks as CSV * @param csvSourceForDataSetAndControlBlocks a reader that provides the FCDA datas for DataSets and Control Blocks creation as CSV */ - public FcdaCsvHelper(Reader csvSourceForHmiReportControl, Reader csvSourceForDataSetAndControlBlocks) { - fcdaForHmiReportControls = CsvUtils.parseRows(csvSourceForHmiReportControl, FcdaForHmiReportControl.class).stream() - .map(fcdaForHmiReportControl -> - SclConstructorHelper.newFcda(fcdaForHmiReportControl.ldInst, fcdaForHmiReportControl.lnClass, fcdaForHmiReportControl.lnInst, fcdaForHmiReportControl.prefix, fcdaForHmiReportControl.doName, null, fcdaForHmiReportControl.fc) - ) - .toList(); + public FcdaCsvHelper(Reader csvSourceForDataSetAndControlBlocks) { fcdaForDataSets = new HashSet<>(CsvUtils.parseRows(csvSourceForDataSetAndControlBlocks, FcdaForDataSetsCreation.class)); } - public static class FcdaForHmiReportControl { - @CsvBindByPosition(position = 0) - private String ldInst; - @CsvBindByPosition(position = 1) - private String prefix; - @CsvBindByPosition(position = 2) - private String lnClass; - @CsvBindByPosition(position = 3) - private String lnInst; - @CsvBindByPosition(position = 4) - private String doName; - @CsvBindByPosition(position = 5) - private TFCEnum fc; - } - - /* @NoArgsConstructor - @AllArgsConstructor - @Getter - @EqualsAndHashCode - public static class FcdaForDataSets { - @CsvBindByPosition(position = 0) - private String lnClass; - @CsvBindByPosition(position = 1) - private String doName; - @CsvBindByPosition(position = 2) - private String daName; - @CsvBindByPosition(position = 3) - private String fc; - } */ } diff --git a/sct-commons/src/main/resources/xsd/CB_REPORT_SUPERVISION_Config_file.xsd b/sct-commons/src/main/resources/xsd/CB_REPORT_SUPERVISION_Config_file.xsd new file mode 100644 index 000000000..8f4264086 --- /dev/null +++ b/sct-commons/src/main/resources/xsd/CB_REPORT_SUPERVISION_Config_file.xsd @@ -0,0 +1,72 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/sct-commons/src/test/java/org/lfenergy/compas/sct/commons/HmiServiceTest.java b/sct-commons/src/test/java/org/lfenergy/compas/sct/commons/HmiServiceTest.java index b468c1560..1a041bcb4 100644 --- a/sct-commons/src/test/java/org/lfenergy/compas/sct/commons/HmiServiceTest.java +++ b/sct-commons/src/test/java/org/lfenergy/compas/sct/commons/HmiServiceTest.java @@ -4,23 +4,25 @@ package org.lfenergy.compas.sct.commons; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.ExtendWith; import org.lfenergy.compas.scl2007b4.model.*; +import org.lfenergy.compas.sct.commons.model.cb_po.FCDAs; +import org.lfenergy.compas.sct.commons.model.cb_po.PO; +import org.lfenergy.compas.sct.commons.model.cb_po.TFCDAFilter; +import org.lfenergy.compas.sct.commons.model.cb_po.Tfc; import org.lfenergy.compas.sct.commons.scl.ied.DataSetAdapter; import org.lfenergy.compas.sct.commons.scl.ln.LN0Adapter; import org.lfenergy.compas.sct.commons.scl.ln.LNAdapter; import org.lfenergy.compas.sct.commons.testhelpers.SclTestMarshaller; -import org.lfenergy.compas.sct.commons.util.CommonConstants; import org.lfenergy.compas.sct.commons.util.ActiveStatus; +import org.lfenergy.compas.sct.commons.util.CommonConstants; import org.mockito.InjectMocks; import org.mockito.junit.jupiter.MockitoExtension; -import java.util.List; - import static org.assertj.core.api.Assertions.assertThat; import static org.lfenergy.compas.sct.commons.testhelpers.SclHelper.*; -import static org.lfenergy.compas.sct.commons.util.SclConstructorHelper.newFcda; @ExtendWith(MockitoExtension.class) class HmiServiceTest { @@ -28,18 +30,27 @@ class HmiServiceTest { @InjectMocks HmiService hmiService; + private final PO po = new PO(); + + @BeforeEach + void setUp() { + FCDAs fcdAs = new FCDAs(); + po.setFCDAs(fcdAs); + } + @Test void createAllIhmReportControlBlocks_with_fc_ST_should_create_dataset_and_controlblock() { // Given SCL scd = SclTestMarshaller.getSCLFromFile("/scd-hmi-create-report-cb/scd_create_dataset_and_controlblocks_for_hmi.xml"); - TFCDA fcda = newFcda("LdInst11", "ANCR", "1", null, "DoName1", null, TFCEnum.ST); + TFCDAFilter tfcdaFilter = createFCDAFilter("LdInst11", "ANCR", "1", null, "DoName1", Tfc.ST); + po.getFCDAs().getFCDA().add(tfcdaFilter); // When - hmiService.createAllHmiReportControlBlocks(scd, List.of(fcda)); + hmiService.createAllHmiReportControlBlocks(scd, po); // Then // Check DataSet is created DataSetAdapter dataSet = findDataSet(scd, "IedName1", "LdInst11", "DS_LDINST11_DQPO"); assertThat(dataSet.getCurrentElem().getFCDA()).hasSize(1).first() - .usingRecursiveComparison().isEqualTo(fcda); + .usingRecursiveComparison().isEqualTo(toFCDA(tfcdaFilter)); // Check ControlBlock is created LN0Adapter ln0 = findLn0(scd, "IedName1", "LdInst11"); assertThat(ln0.getTControlsByType(TReportControl.class)).hasSize(1); @@ -58,14 +69,15 @@ void createAllIhmReportControlBlocks_with_fc_ST_should_create_dataset_and_contro void createAllIhmReportControlBlocks_with_fc_MX_should_create_dataset_and_controlblock() { // Given SCL scd = SclTestMarshaller.getSCLFromFile("/scd-hmi-create-report-cb/scd_create_dataset_and_controlblocks_for_hmi.xml"); - TFCDA fcda = newFcda("LdInst11", "PVOC", "1", null, "DoName2", null, TFCEnum.MX); + TFCDAFilter tfcdaFilter = createFCDAFilter("LdInst11", "PVOC", "1", null, "DoName2", Tfc.MX); + po.getFCDAs().getFCDA().add(tfcdaFilter); // When - hmiService.createAllHmiReportControlBlocks(scd, List.of(fcda)); + hmiService.createAllHmiReportControlBlocks(scd, po); // Then // Check DataSet is created DataSetAdapter dataSet = findDataSet(scd, "IedName1", "LdInst11", "DS_LDINST11_CYPO"); assertThat(dataSet.getCurrentElem().getFCDA()).hasSize(1).first() - .usingRecursiveComparison().isEqualTo(fcda); + .usingRecursiveComparison().isEqualTo(toFCDA(tfcdaFilter)); // Check ControlBlock is created LN0Adapter ln0 = findLn0(scd, "IedName1", "LdInst11"); assertThat(ln0.getTControlsByType(TReportControl.class)).hasSize(1); @@ -85,14 +97,15 @@ void createAllIhmReportControlBlocks_with_fc_MX_should_create_dataset_and_contro void createAllIhmReportControlBlocks_with_FCDA_on_ln0_should_create_dataset_and_controlblock() { // Given SCL scd = SclTestMarshaller.getSCLFromFile("/scd-hmi-create-report-cb/scd_create_dataset_and_controlblocks_for_hmi.xml"); - TFCDA fcda = newFcda("LdInst11", "LLN0", null, null, "DoName0", null, TFCEnum.ST); + TFCDAFilter tfcdaFilter = createFCDAFilter("LdInst11", "LLN0", null, null, "DoName0", Tfc.ST); + po.getFCDAs().getFCDA().add(tfcdaFilter); // When - hmiService.createAllHmiReportControlBlocks(scd, List.of(fcda)); + hmiService.createAllHmiReportControlBlocks(scd, po); // Then // Check DataSet is created DataSetAdapter dataSet = findDataSet(scd, "IedName1", "LdInst11", "DS_LDINST11_DQPO"); assertThat(dataSet.getCurrentElem().getFCDA()).hasSize(1).first() - .usingRecursiveComparison().isEqualTo(fcda); + .usingRecursiveComparison().isEqualTo(toFCDA(tfcdaFilter)); // Check ControlBlock is created LN0Adapter ln0 = findLn0(scd, "IedName1", "LdInst11"); assertThat(ln0.getTControlsByType(TReportControl.class)).hasSize(1); @@ -113,14 +126,15 @@ void createAllIhmReportControlBlocks_when_lDevice_ON_but_LN_Mod_StVal_missing_sh SCL scd = SclTestMarshaller.getSCLFromFile("/scd-hmi-create-report-cb/scd_create_dataset_and_controlblocks_for_hmi.xml"); LNAdapter ln = findLn(scd, "IedName1", "LdInst11", "ANCR", "1", null); ln.getCurrentElem().unsetDOI(); - TFCDA fcda = newFcda("LdInst11", "ANCR", "1", null, "DoName1", null, TFCEnum.ST); + TFCDAFilter tfcdaFilter = createFCDAFilter("LdInst11", "ANCR", "1", null, "DoName1", Tfc.ST); + po.getFCDAs().getFCDA().add(tfcdaFilter); // When - hmiService.createAllHmiReportControlBlocks(scd, List.of(fcda)); + hmiService.createAllHmiReportControlBlocks(scd, po); // Then // Check DataSet is created DataSetAdapter dataSet = findDataSet(scd, "IedName1", "LdInst11", "DS_LDINST11_DQPO"); assertThat(dataSet.getCurrentElem().getFCDA()).hasSize(1).first() - .usingRecursiveComparison().isEqualTo(fcda); + .usingRecursiveComparison().isEqualTo(toFCDA(tfcdaFilter)); // Check ControlBlock is created LN0Adapter ln0 = findLn0(scd, "IedName1", "LdInst11"); assertThat(ln0.getTControlsByType(TReportControl.class)).hasSize(1); @@ -137,9 +151,10 @@ void createAllIhmReportControlBlocks_when_lDevice_ON_but_LN_Mod_StVal_OFF_should LNAdapter ln = findLn(scd, "IedName1", "LdInst11", "ANCR", "1", null); ln.getDOIAdapterByName(CommonConstants.MOD_DO_NAME).getDataAdapterByName(CommonConstants.STVAL_DA_NAME).setVal("off"); assertThat(ln.getDaiModStValValue()).hasValue("off"); - TFCDA fcda = newFcda("LdInst11", "ANCR", "1", null, "DoName1", null, TFCEnum.ST); + TFCDAFilter tfcdaFilter = createFCDAFilter("LdInst11", "ANCR", "1", null, "DoName1", Tfc.ST); + po.getFCDAs().getFCDA().add(tfcdaFilter); // When - hmiService.createAllHmiReportControlBlocks(scd, List.of(fcda)); + hmiService.createAllHmiReportControlBlocks(scd, po); // Then assertThat(streamAllDataSets(scd)).isEmpty(); assertThat(streamAllControlBlocks(scd, TReportControl.class)).isEmpty(); @@ -152,9 +167,10 @@ void createAllIhmReportControlBlocks_when_lDevice_OFF_should_not_create_dataset( LN0Adapter ln0 = findLn0(scd, "IedName1", "LdInst11"); ln0.getDOIAdapterByName(CommonConstants.MOD_DO_NAME).getDataAdapterByName(CommonConstants.STVAL_DA_NAME).setVal("off"); assertThat(findLDevice(scd, "IedName1", "LdInst11").getLDeviceStatus()).hasValue(ActiveStatus.OFF.getValue()); - TFCDA fcda = newFcda("LdInst11", "ANCR", "1", null, "DoName1", null, TFCEnum.ST); + TFCDAFilter tfcdaFilter = createFCDAFilter("LdInst11", "ANCR", "1", null, "DoName1", Tfc.ST); + po.getFCDAs().getFCDA().add(tfcdaFilter); // When - hmiService.createAllHmiReportControlBlocks(scd, List.of(fcda)); + hmiService.createAllHmiReportControlBlocks(scd, po); // Then assertThat(streamAllDataSets(scd)).isEmpty(); assertThat(streamAllControlBlocks(scd, TReportControl.class)).isEmpty(); @@ -167,12 +183,35 @@ void createAllIhmReportControlBlocks_when_LDevice_has_no_status_should_not_creat LN0Adapter ln0 = findLn0(scd, "IedName1", "LdInst11"); ln0.getDOIAdapterByName(CommonConstants.MOD_DO_NAME).getDataAdapterByName(CommonConstants.STVAL_DA_NAME).getCurrentElem().unsetVal(); assertThat(findLDevice(scd, "IedName1", "LdInst11").getLDeviceStatus()).isEmpty(); - TFCDA fcda = newFcda("LdInst11", "ANCR", "1", null, "DoName1", null, TFCEnum.ST); + TFCDAFilter tfcdaFilter = createFCDAFilter("LdInst11", "ANCR", "1", null, "DoName1", Tfc.ST); + po.getFCDAs().getFCDA().add(tfcdaFilter); // When - hmiService.createAllHmiReportControlBlocks(scd, List.of(fcda)); + hmiService.createAllHmiReportControlBlocks(scd, po); // Then assertThat(streamAllDataSets(scd)).isEmpty(); assertThat(streamAllControlBlocks(scd, TReportControl.class)).isEmpty(); } + private static TFCDAFilter createFCDAFilter(String ldInst, String lnClass, String lnInst, String prefix, String doName, Tfc tfc) { + TFCDAFilter tfcdaFilter = new TFCDAFilter(); + tfcdaFilter.setLdInst("LdInst11"); + tfcdaFilter.setLnClass(lnClass); + tfcdaFilter.setPrefix(null); + tfcdaFilter.setDoName(doName); + tfcdaFilter.setLnInst(lnInst); + tfcdaFilter.setFc(tfc); + return tfcdaFilter; + } + + private static TFCDA toFCDA(TFCDAFilter tfcdaFilter) { + TFCDA tfcda = new TFCDA(); + tfcda.setLdInst(tfcdaFilter.getLdInst()); + tfcda.getLnClass().add(tfcdaFilter.getLnClass()); + tfcda.setPrefix(tfcdaFilter.getPrefix()); + tfcda.setLnInst(tfcdaFilter.getLnInst()); + tfcda.setDoName(tfcdaFilter.getDoName()); + tfcda.setFc(TFCEnum.fromValue(tfcdaFilter.getFc().value())); + return tfcda; + } + } diff --git a/sct-commons/src/test/java/org/lfenergy/compas/sct/commons/util/FcdaCsvHelperTest.java b/sct-commons/src/test/java/org/lfenergy/compas/sct/commons/util/FcdaCsvHelperTest.java index 9c5046080..d3b6ec399 100644 --- a/sct-commons/src/test/java/org/lfenergy/compas/sct/commons/util/FcdaCsvHelperTest.java +++ b/sct-commons/src/test/java/org/lfenergy/compas/sct/commons/util/FcdaCsvHelperTest.java @@ -6,12 +6,9 @@ import org.assertj.core.groups.Tuple; import org.junit.jupiter.api.Test; -import org.lfenergy.compas.scl2007b4.model.TFCDA; -import org.lfenergy.compas.scl2007b4.model.TFCEnum; import org.lfenergy.compas.sct.commons.dto.FcdaForDataSetsCreation; import java.io.StringReader; -import java.util.List; import java.util.Set; import static org.assertj.core.api.Assertions.assertThat; @@ -19,18 +16,12 @@ class FcdaCsvHelperTest { @Test - void constructor_should_initialize_list_of_FcdaForDataSets_and_FcdaForHmiReportControls() { + void constructor_should_initialize_list_of_FcdaForDataSets() { //Given - StringReader csvSourceForHmiReportControl = new StringReader("LDGRP1;;GAPC;12;Ind1;ST"); StringReader csvSourceForDataSetAndControlBlocks = new StringReader("GAPC;Ind1;stVal;ST"); //When - FcdaCsvHelper fcdaCsvHelper = new FcdaCsvHelper(csvSourceForHmiReportControl, csvSourceForDataSetAndControlBlocks); + FcdaCsvHelper fcdaCsvHelper = new FcdaCsvHelper(csvSourceForDataSetAndControlBlocks); //Then - List fcdaForHmiReportControls = fcdaCsvHelper.getFcdaForHmiReportControls(); - assertThat(fcdaForHmiReportControls) - .isNotNull() - .hasSize(1); - Set fcdaForDataSets = fcdaCsvHelper.getFcdaForDataSets(); assertThat(fcdaForDataSets) .isNotNull() @@ -38,27 +29,16 @@ void constructor_should_initialize_list_of_FcdaForDataSets_and_FcdaForHmiReportC } @Test - void get_return_list_of_FcdaForDataSets_and_FcdaForHmiReportControls() { + void get_return_list_of_FcdaForDataSets() { //Given - StringReader csvSourceForHmiReportControl = new StringReader(""" - LDGRP1;;GAPC;12;Ind1;ST - LDCMDSS2;;LLN0;;Health;MX - """); StringReader csvSourceForDataSetAndControlBlocks = new StringReader(""" GAPC;Ind1;stVal;ST LLN0;Health;ctVal;MX """); - FcdaCsvHelper fcdaCsvHelper = new FcdaCsvHelper(csvSourceForHmiReportControl, csvSourceForDataSetAndControlBlocks); + FcdaCsvHelper fcdaCsvHelper = new FcdaCsvHelper(csvSourceForDataSetAndControlBlocks); //When - List fcdaForHmiReportControls = fcdaCsvHelper.getFcdaForHmiReportControls(); Set fcdaForDataSets = fcdaCsvHelper.getFcdaForDataSets(); //Then - assertThat(fcdaForHmiReportControls).hasSize(2); - assertThat(fcdaForHmiReportControls.get(0)).usingRecursiveComparison().isEqualTo( - SclConstructorHelper.newFcda("LDGRP1", "GAPC", "12", null, "Ind1", null, TFCEnum.ST)); - assertThat(fcdaForHmiReportControls.get(1)).usingRecursiveComparison().isEqualTo( - SclConstructorHelper.newFcda("LDCMDSS2", "LLN0", null, null, "Health", null, TFCEnum.MX)); - assertThat(fcdaForDataSets).hasSize(2) .extracting(FcdaForDataSetsCreation::getLnClass, FcdaForDataSetsCreation::getDoName, FcdaForDataSetsCreation::getDaName, FcdaForDataSetsCreation::getFc) .containsExactly(Tuple.tuple("LLN0", "Health", "ctVal", "MX"), Tuple.tuple("GAPC", "Ind1", "stVal", "ST"));