From c8352b1ed7d91c5d920bec3f73fd88c7bbcac501 Mon Sep 17 00:00:00 2001 From: James Mudd Date: Fri, 13 Dec 2024 18:23:19 +0000 Subject: [PATCH] Improve tests validating file --- .../io/jhdf/writing/StringWritingTest.java | 36 ++++++++++++++++++- 1 file changed, 35 insertions(+), 1 deletion(-) diff --git a/jhdf/src/test/java/io/jhdf/writing/StringWritingTest.java b/jhdf/src/test/java/io/jhdf/writing/StringWritingTest.java index 4a297884..812a9bdd 100644 --- a/jhdf/src/test/java/io/jhdf/writing/StringWritingTest.java +++ b/jhdf/src/test/java/io/jhdf/writing/StringWritingTest.java @@ -193,9 +193,11 @@ void writeReallyLongStrings() throws Exception { } } + // https://github.com/jamesmudd/jhdf/issues/656 @Test + @Order(5) void writingNonAsciiStrings() throws Exception { - Path tempFile = Files.createTempFile(this.getClass().getSimpleName(), ".hdf5"); + tempFile = Files.createTempFile(this.getClass().getSimpleName(), ".hdf5"); WritableHdfFile writableHdfFile = HdfFile.write(tempFile); WritiableDataset dataset1 = writableHdfFile.putDataset("dataset1", "你好"); @@ -208,5 +210,37 @@ void writingNonAsciiStrings() throws Exception { dataset3.putAttribute("attr", new String[][] {{"你好"}, {"世界"}}); writableHdfFile.close(); + + // Now read it back + try (HdfFile hdfFile = new HdfFile(tempFile)) { + Dataset dataset1Readback = hdfFile.getDatasetByPath("dataset1"); + assertThat(dataset1Readback.getData()).isEqualTo("你好"); + assertThat(dataset1Readback.getAttribute("attr").getData()) + .isEqualTo("你好"); + + Dataset dataset2Readback = hdfFile.getDatasetByPath("dataset2"); + assertThat(dataset2Readback.getData()).isEqualTo(new String[] {"你好"}); + assertThat(dataset2Readback.getAttribute("attr").getData()) + .isEqualTo(new String[] {"你好"}); + + Dataset dataset3Readback = hdfFile.getDatasetByPath("dataset3"); + assertThat(dataset3Readback.getData()).isEqualTo(new String[][] {{"你好"}, {"世界"}}); + assertThat(dataset3Readback.getAttribute("attr").getData()) + .isEqualTo(new String[][] {{"你好"}, {"世界"}}); + } + } + + @Test + @Order(6) + @EnabledIfH5DumpAvailable + void readNonAsciiStringDatasetsWithH5Dump() throws Exception { + // Read with h5dump + HDF5FileXml hdf5FileXml = H5Dump.dumpAndParse(tempFile); + + // Read with jhdf + try (HdfFile hdfFile = new HdfFile(tempFile)) { + // Compare + H5Dump.assetXmlAndHdfFileMatch(hdf5FileXml, hdfFile); + } } }