TestInternCellShapes.java

/**
 * Copyright (c) 2020, 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.sld.raw;

import com.powsybl.sld.builders.VoltageLevelRawBuilder;
import com.powsybl.sld.model.graphs.VoltageLevelGraph;
import com.powsybl.sld.model.nodes.BusNode;
import com.powsybl.sld.model.nodes.ConnectivityNode;
import com.powsybl.sld.model.nodes.SwitchNode;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;

import static org.junit.jupiter.api.Assertions.assertEquals;

/**
 * @author Benoit Jeanson {@literal <benoit.jeanson at rte-france.com>}
 */

class TestInternCellShapes extends AbstractTestCaseRaw {
    @BeforeEach
    public void setUp() {
        VoltageLevelRawBuilder vlBuilder = rawGraphBuilder.createVoltageLevelBuilder("vl", 380);
        BusNode bbs11 = vlBuilder.createBusBarSection("bbs11", 1, 1);
        BusNode bbs21 = vlBuilder.createBusBarSection("bbs21", 2, 1);
        BusNode bbs12 = vlBuilder.createBusBarSection("bbs12", 1, 2);
        BusNode bbs22 = vlBuilder.createBusBarSection("bbs22", 2, 2);

        // InternCell.Shape.FLAT with one disconnector only on busbar 1
        SwitchNode flatDisconector = vlBuilder.createSwitchNode(SwitchNode.SwitchKind.DISCONNECTOR, "flatDisconector", false, false);
        vlBuilder.connectNode(bbs11, flatDisconector);
        vlBuilder.connectNode(flatDisconector, bbs12);

        // InternCell.Shape.FLAT with a breaker and disconnectors only on busbar 2
        SwitchNode flatBreaker = vlBuilder.createSwitchNode(SwitchNode.SwitchKind.BREAKER, "flatBreaker", false, false);
        SwitchNode dFlatBk1 = vlBuilder.createSwitchNode(SwitchNode.SwitchKind.DISCONNECTOR, "dFlatBk1", false, false);
        SwitchNode dFlatBk2 = vlBuilder.createSwitchNode(SwitchNode.SwitchKind.DISCONNECTOR, "dFlatBk2", false, false);
        vlBuilder.connectNode(dFlatBk1, bbs21);
        vlBuilder.connectNode(dFlatBk1, flatBreaker);
        vlBuilder.connectNode(dFlatBk2, flatBreaker);
        vlBuilder.connectNode(dFlatBk2, bbs22);

        // InternCell.Shape.VERTICAL on section 1
        SwitchNode verticalBreaker = vlBuilder.createSwitchNode(SwitchNode.SwitchKind.BREAKER, "verticalBreaker", false, false);
        SwitchNode dVerticalBk1 = vlBuilder.createSwitchNode(SwitchNode.SwitchKind.DISCONNECTOR, "dVerticalBk1", false, false);
        SwitchNode dVerticalBk2 = vlBuilder.createSwitchNode(SwitchNode.SwitchKind.DISCONNECTOR, "dVerticalBk2", false, false);
        vlBuilder.connectNode(dVerticalBk1, bbs11);
        vlBuilder.connectNode(dVerticalBk1, verticalBreaker);
        vlBuilder.connectNode(dVerticalBk2, verticalBreaker);
        vlBuilder.connectNode(dVerticalBk2, bbs21);

        // InternCell.Shape.CROSSOVER
        SwitchNode crossOverBreaker = vlBuilder.createSwitchNode(SwitchNode.SwitchKind.BREAKER, "crossOverBreaker", false, false);
        SwitchNode dCrossOverBk1 = vlBuilder.createSwitchNode(SwitchNode.SwitchKind.DISCONNECTOR, "dCrossOverBk1", false, false);
        SwitchNode dCrossOverBk2 = vlBuilder.createSwitchNode(SwitchNode.SwitchKind.DISCONNECTOR, "dCrossOverBk2", false, false);
        vlBuilder.connectNode(dCrossOverBk1, bbs11);
        vlBuilder.connectNode(dCrossOverBk1, crossOverBreaker);
        vlBuilder.connectNode(dCrossOverBk2, crossOverBreaker);
        vlBuilder.connectNode(dCrossOverBk2, bbs22);

        //Shape.UNILEG on section 2
        ConnectivityNode fNode = vlBuilder.createConnectivityNode("Fictitious_unileg");
        SwitchNode unilegDc1 = vlBuilder.createSwitchNode(SwitchNode.SwitchKind.DISCONNECTOR, "dF1", false, false);
        SwitchNode unilegDc2 = vlBuilder.createSwitchNode(SwitchNode.SwitchKind.DISCONNECTOR, "dF2", false, false);
        vlBuilder.connectNode(bbs12, unilegDc1);
        vlBuilder.connectNode(bbs22, unilegDc2);
        vlBuilder.connectNode(unilegDc1, fNode);
        vlBuilder.connectNode(unilegDc2, fNode);
    }

    @Test
    void test() {
        VoltageLevelGraph g = rawGraphBuilder.buildVoltageLevelGraph("vl");
        voltageLevelGraphLayout(g);
        assertEquals(toString("/TestInternCellShapes.json"), toJson(g, "/TestInternCellShapes.json"));
    }
}