FourSubstationsNetworkTest.java
/**
* Copyright (c) 2022, 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/.
*/
package com.powsybl.nad.svg;
import com.powsybl.iidm.network.Battery;
import com.powsybl.iidm.network.Network;
import com.powsybl.iidm.network.ShuntCompensator;
import com.powsybl.iidm.network.VoltageLevel;
import com.powsybl.iidm.network.test.FourSubstationsNodeBreakerFactory;
import com.powsybl.nad.AbstractTest;
import com.powsybl.nad.layout.LayoutParameters;
import com.powsybl.nad.svg.iidm.DefaultLabelProvider;
import com.powsybl.nad.svg.iidm.TopologicalStyleProvider;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
/**
* @author Florian Dupuy {@literal <florian.dupuy at rte-france.com>}
*/
class FourSubstationsNetworkTest extends AbstractTest {
@BeforeEach
void setup() {
setLayoutParameters(new LayoutParameters()
.setInjectionsAdded(true));
setSvgParameters(new SvgParameters()
.setSvgWidthAndHeightAdded(true)
.setFixedScale(0.5));
}
@Override
protected StyleProvider getStyleProvider(Network network) {
return new TopologicalStyleProvider(network);
}
@Override
protected LabelProvider getLabelProvider(Network network) {
return new DefaultLabelProvider(network, getSvgParameters());
}
@Test
void test() {
Network network = FourSubstationsNodeBreakerFactory.create();
// Open the coupler to get a two-nodes voltage level
network.getSwitch("S1VL2_COUPLER").setOpen(true);
// Add shunt capacitor
VoltageLevel s1vl2 = network.getVoltageLevel("S1VL2");
s1vl2.getNodeBreakerView().newDisconnector().setId("S1VL2_BBS1_SCC_DISCONNECTOR").setOpen(true).setNode1(0).setNode2(24).add();
s1vl2.getNodeBreakerView().newBreaker().setId("S1VL2_BBS1_SCC_BREAKER").setOpen(false).setNode1(24).setNode2(25).add();
ShuntCompensator shuntCapacitor = s1vl2.newShuntCompensator()
.setId("SHUNT_CAPACITOR")
.setNode(25)
.setSectionCount(1)
.newLinearModel()
.setMaximumSectionCount(1)
.setBPerSection(0.032)
.add()
.add();
shuntCapacitor.getTerminal().setQ(1920.0).setP(0.);
// Add battery
VoltageLevel s1vl1 = network.getVoltageLevel("S1VL1");
s1vl1.getNodeBreakerView().newDisconnector().setId("S1VL1_BATTERY_DISCONNECTOR").setNode1(0).setNode2(5).add();
s1vl1.getNodeBreakerView().newBreaker().setId("S1VL1_BATTERY_BREAKER").setNode1(5).setNode2(6).add();
Battery battery = s1vl1.newBattery()
.setId("BATTERY")
.setNode(6)
.setTargetP(50.)
.setTargetQ(2.)
.setMinP(-5)
.setMaxP(60)
.add();
battery.getTerminal().setP(15.);
// Override NaN value on shunt
network.getShuntCompensator("SHUNT").getTerminal().setP(0.);
assertSvgEquals("/four_substations.svg", network);
}
}