WeccGenXmlTest.java
/**
* Copyright (c) 2023, RTE (http://www.rte-france.com/)
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
* SPDX-License-Identifier: MPL-2.0
*/
package com.powsybl.dynawo.xml;
import com.powsybl.dynawo.DynawoSimulationConstants;
import com.powsybl.dynawo.models.generators.GridFormingConverterBuilder;
import com.powsybl.dynawo.models.BlackBoxModel;
import com.powsybl.dynawo.models.generators.WeccBuilder;
import com.powsybl.iidm.network.Network;
import com.powsybl.iidm.network.test.EurostagTutorialExample1Factory;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.extension.ExtendWith;
import org.junit.jupiter.params.ParameterizedTest;
import org.junit.jupiter.params.provider.Arguments;
import org.junit.jupiter.params.provider.MethodSource;
import org.xml.sax.SAXException;
import java.io.IOException;
import java.util.function.Function;
import java.util.stream.Stream;
/**
* @author Laurent Issertial {@literal <laurent.issertial at rte-france.com>}
*/
@ExtendWith(CustomParameterResolver.class)
class WeccGenXmlTest extends AbstractParametrizedDynamicModelXmlTest {
private static final String STATIC_ID = "GEN";
@BeforeEach
void setup(String dydName, String parName, Function< Network, BlackBoxModel> loadConstructor) {
setupNetwork();
addDynamicModels(loadConstructor);
setupDynawoContext();
}
protected void setupNetwork() {
network = EurostagTutorialExample1Factory.create();
}
protected void addDynamicModels(Function< Network, BlackBoxModel> constructor) {
dynamicModels.add(constructor.apply(network));
}
@ParameterizedTest(name = "{0}")
@MethodSource("provideWecc")
void writeModel(String dydName, String parName, Function< Network, BlackBoxModel> constructor) throws SAXException, IOException {
DydXml.write(tmpDir, context.getSimulationDydData());
ParametersXml.write(tmpDir, context);
validate("dyd.xsd", dydName, tmpDir.resolve(DynawoSimulationConstants.DYD_FILENAME));
if (!parName.isEmpty()) {
validate("parameters.xsd", parName, tmpDir.resolve(context.getSimulationParFile()));
}
}
private static Stream<Arguments> provideWecc() {
return Stream.of(
Arguments.of("wecc_wt_dyd.xml", "", (Function<Network, BlackBoxModel>) n ->
WeccBuilder.of(n, "WT4AWeccCurrentSource")
.staticId(STATIC_ID)
.parameterSetId("Wind")
.build()),
Arguments.of("wecc_wt_synchro_dyd.xml", "wecc_wt_par.xml", (Function<Network, BlackBoxModel>) n ->
WeccBuilder.of(n, "WTG4BWeccCurrentSource")
.staticId(STATIC_ID)
.parameterSetId("Wind")
.build()),
Arguments.of("wecc_pv_dyd.xml", "wecc_wt_par.xml", (Function<Network, BlackBoxModel>) n ->
WeccBuilder.of(n, "PhotovoltaicsWeccCurrentSource")
.staticId(STATIC_ID)
.parameterSetId("Wind")
.build()),
Arguments.of("grid_forming_converter_dyd.xml", "grid_forming_converter_par.xml", (Function<Network, BlackBoxModel>) n ->
GridFormingConverterBuilder.of(n, "GridFormingConverterDroopControl")
.staticId(STATIC_ID)
.parameterSetId("GF")
.build())
);
}
}