From b39dd3d1d7ece9aff111035c2a0f9e8d0580a8d0 Mon Sep 17 00:00:00 2001 From: David Kleiven Date: Fri, 29 Sep 2023 15:55:54 +0200 Subject: [PATCH] Add test for loading rawx --- src/main/Solver.kt | 18 ++++++++++++++++-- src/test/AppTest.kt | 43 +++++++++++++++++++++++++++++++++++++++++-- 2 files changed, 57 insertions(+), 4 deletions(-) diff --git a/src/main/Solver.kt b/src/main/Solver.kt index c42f375..e8477b8 100644 --- a/src/main/Solver.kt +++ b/src/main/Solver.kt @@ -1,18 +1,32 @@ package com.github.statnett.loadflowservice +import com.powsybl.cgmes.conversion.CgmesImport +import com.powsybl.ieeecdf.converter.IeeeCdfImporter +import com.powsybl.iidm.network.ImportersLoader +import com.powsybl.iidm.network.ImportersLoaderList import com.powsybl.iidm.network.Network +import com.powsybl.iidm.xml.XMLImporter import com.powsybl.loadflow.LoadFlow import com.powsybl.loadflow.LoadFlowParameters import com.powsybl.loadflow.json.JsonLoadFlowParameters +import com.powsybl.matpower.converter.MatpowerImporter +import com.powsybl.powerfactory.converter.PowerFactoryImporter +import com.powsybl.psse.converter.PsseImporter +import com.powsybl.ucte.converter.UcteImporter import java.io.ByteArrayInputStream import java.io.ByteArrayOutputStream import java.io.InputStream fun networkFromStream( - fname: String, + filename: String, content: InputStream, ): Network { - return Network.read(fname, content) + val importerLoader = ImportersLoaderList( + PsseImporter(), XMLImporter(), CgmesImport(), + IeeeCdfImporter(), UcteImporter(), + MatpowerImporter(), PowerFactoryImporter() + ) + return Network.read(filename, content) } fun networkFromFileContent(content: FileContent): Network { diff --git a/src/test/AppTest.kt b/src/test/AppTest.kt index e941cf1..496a467 100644 --- a/src/test/AppTest.kt +++ b/src/test/AppTest.kt @@ -59,7 +59,7 @@ class ApplicationTest { } @TestFactory - fun `test internal server error when file parsing fails`() = listOf( + fun `test internal server error when file parsing fails`() = listOf( "/buses", "/run-load-flow", "/substation-names", @@ -208,6 +208,19 @@ class ApplicationTest { assertTrue(isPlausibleSvg(body)) assertEquals(response.headers["Content-Type"].toString(), "image/svg+xml") } + + @Test + fun `test read rawx`() = + testApplication { + val response = client.submitFormWithBinaryData( + url = "/buses", + formData = formDataMinimalNetworkRawx() + ) + assertEquals(HttpStatusCode.OK, response.status) + val body = response.bodyAsText() + val num = body.split("},{").size + assertEquals(2, num) + } } fun formDataFromFile(file: File): List { @@ -247,4 +260,30 @@ fun ieeeCdfNetwork14File(): File { // is a valid svg image fun isPlausibleSvg(body: String): Boolean { return body.contains(" { + return formData { + append( + "network", + minimalRawx(), + Headers.build { + append(HttpHeaders.ContentDisposition, "filename=network.rawx") + } + ) + } +} + +fun minimalRawx(): ByteArray { + return ("{\"network\":{\"caseid\":{" + + "\"fields\":[\"ic\",\"sbase\",\"rev\",\"xfrrat\",\"nxfrat\",\"basfrq\",\"title1\"]," + + "\"data\":[0,100.00,35,0,0,60.00,\"PSS(R)EMinimumRAWXCase\"]}," + + "\"bus\":{\"fields\":[\"ibus\",\"name\",\"baskv\",\"ide\"]," + + "\"data\":[[1,\"Slack-Bus\",138.0,3],[2,\"Load-Bus\",138.01]]}," + + "\"load\":{\"fields\":[\"ibus\",\"loadid\",\"stat\",\"pl\",\"ql\"]," + + "\"data\":[[2,\"1\",1,40.0,15.0]]}," + + "\"generator\":{\"fields\":[\"ibus\",\"machid\",\"pg\",\"qg\"]," + + "\"data\":[[1,\"1\",\"40.35\",\"10.87\"]]}," + + "\"acline\":{\"fields\":[\"ibus\",\"jbus\",\"ckt\",\"rpu\",\"xpu\",\"bpu\"]," + + "\"data\":[[1,2,\"1\",0.01938,0.05917,0.05280]]}}}").toByteArray() +}