diff options
author | Andreas Beeker <kiwiwings@apache.org> | 2020-12-28 14:06:24 +0000 |
---|---|---|
committer | Andreas Beeker <kiwiwings@apache.org> | 2020-12-28 14:06:24 +0000 |
commit | 77fc30c0e03afaf99d8dd25cf07c49414358a5aa (patch) | |
tree | 1d6f8a4a8130338720e979609625a4946d907991 /src/ooxml | |
parent | 0ab727bbde8ea20a9f72cc2c051bc83e0e79c7b9 (diff) | |
download | poi-77fc30c0e03afaf99d8dd25cf07c49414358a5aa.tar.gz poi-77fc30c0e03afaf99d8dd25cf07c49414358a5aa.zip |
sonar fixes
git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1884874 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'src/ooxml')
8 files changed, 373 insertions, 396 deletions
diff --git a/src/ooxml/testcases/org/apache/poi/extractor/ooxml/TestExtractorFactory.java b/src/ooxml/testcases/org/apache/poi/extractor/ooxml/TestExtractorFactory.java index 3f827c3797..9715e49e80 100644 --- a/src/ooxml/testcases/org/apache/poi/extractor/ooxml/TestExtractorFactory.java +++ b/src/ooxml/testcases/org/apache/poi/extractor/ooxml/TestExtractorFactory.java @@ -17,6 +17,7 @@ package org.apache.poi.extractor.ooxml; import static org.apache.poi.POITestCase.assertContains; +import static org.apache.poi.extractor.ExtractorFactory.createExtractor; import static org.junit.jupiter.api.Assertions.assertEquals; import static org.junit.jupiter.api.Assertions.assertFalse; import static org.junit.jupiter.api.Assertions.assertNotNull; @@ -28,6 +29,7 @@ import java.io.File; import java.io.FileInputStream; import java.io.IOException; import java.util.Locale; +import java.util.stream.Stream; import org.apache.poi.POIDataSamples; import org.apache.poi.extractor.ExtractorFactory; @@ -46,7 +48,12 @@ import org.apache.poi.poifs.filesystem.POIFSFileSystem; import org.apache.poi.xssf.extractor.XSSFEventBasedExcelExtractor; import org.apache.poi.xssf.extractor.XSSFExcelExtractor; import org.apache.xmlbeans.XmlException; +import org.junit.jupiter.api.Assumptions; import org.junit.jupiter.api.Test; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.Arguments; +import org.junit.jupiter.params.provider.MethodSource; +import org.junit.jupiter.params.provider.ValueSource; /** * Test that the extractor factory plays nicely @@ -100,91 +107,101 @@ public class TestExtractorFactory { return file; } - private static final Object[] TEST_SET = { - "Excel", xls, "ExcelExtractor", 200, - "Excel - xlsx", xlsx, "XSSFExcelExtractor", 200, - "Excel - xltx", xltx, "XSSFExcelExtractor", -1, - "Excel - xlsb", xlsb, "XSSFBEventBasedExcelExtractor", -1, - "Word", doc, "WordExtractor", 120, - "Word - docx", docx, "XWPFWordExtractor", 120, - "Word - dotx", dotx, "XWPFWordExtractor", -1, - "Word 6", doc6, "Word6Extractor", 20, - "Word 95", doc95, "Word6Extractor", 120, - "PowerPoint", ppt, "SlideShowExtractor", 120, - "PowerPoint - pptx", pptx, "XSLFExtractor", 120, - "Visio", vsd, "VisioTextExtractor", 50, - "Visio - vsdx", vsdx, "XDGFVisioExtractor", 20, - "Publisher", pub, "PublisherTextExtractor", 50, - "Outlook msg", msg, "OutlookTextExtractor", 50, - - // TODO Support OOXML-Strict, see bug #57699 - // xlsxStrict + public static Stream<Arguments> testOOXMLData() { + return Stream.of( + Arguments.of("Excel - xlsx", xlsx, "XSSFExcelExtractor", 200), + Arguments.of("Excel - xltx", xltx, "XSSFExcelExtractor", -1), + Arguments.of("Excel - xlsb", xlsb, "XSSFBEventBasedExcelExtractor", -1), + Arguments.of("Word - docx", docx, "XWPFWordExtractor", 120), + Arguments.of("Word - dotx", dotx, "XWPFWordExtractor", -1), + Arguments.of("PowerPoint - pptx", pptx, "XSLFExtractor", 120), + Arguments.of("Visio - vsdx", vsdx, "XDGFVisioExtractor", 20) + ); + }; + + public static Stream<Arguments> testScratchData() { + return Stream.of( + Arguments.of("Excel", xls, "ExcelExtractor", 200), + Arguments.of("Word", doc, "WordExtractor", 120), + Arguments.of("Word 6", doc6, "Word6Extractor", 20), + Arguments.of("Word 95", doc95, "Word6Extractor", 120), + Arguments.of("PowerPoint", ppt, "SlideShowExtractor", 120), + Arguments.of("Visio", vsd, "VisioTextExtractor", 50), + Arguments.of("Publisher", pub, "PublisherTextExtractor", 50), + Arguments.of("Outlook msg", msg, "OutlookTextExtractor", 50) + ); }; - @FunctionalInterface - interface FunctionEx<T, R> { - R apply(T t) throws IOException, OpenXML4JException, XmlException; + public static Stream<Arguments> testFileData() { + return Stream.concat(testOOXMLData(), testScratchData()); + // TODO Support OOXML-Strict / xlsxStrict, see bug #57699 + }; + + + @ParameterizedTest + @MethodSource("testFileData") + public void testFile(String testcase, File file, String extractor, int count) throws Exception { + try (POITextExtractor ext = createExtractor(file)) { + assertNotNull(ext); + testExtractor(ext, testcase, extractor, count); + } } - @SuppressWarnings("ConstantConditions") - @Test - public void testFile() throws Exception { - for (int i = 0; i < TEST_SET.length; i += 4) { - try (POITextExtractor ext = ExtractorFactory.createExtractor((File) TEST_SET[i + 1])) { - testExtractor(ext, (String) TEST_SET[i], (String) TEST_SET[i + 2], (Integer) TEST_SET[i + 3]); - } + @ParameterizedTest + @MethodSource("testScratchData") + public void testPOIFS(String testcase, File testFile, String extractor, int count) throws Exception { + // test processing of InputStream + try (FileInputStream fis = new FileInputStream(testFile); + POIFSFileSystem poifs = new POIFSFileSystem(fis); + POITextExtractor ext = createExtractor(poifs)) { + assertNotNull(ext); + testExtractor(ext, testcase, extractor, count); } } - @Test - public void testFileInvalid() { - IOException ex = assertThrows( - IOException.class, - () -> ExtractorFactory.createExtractor(txt) - ); - assertEquals("Can't create extractor - unsupported file type: UNKNOWN", ex.getMessage()); + @ParameterizedTest + @MethodSource("testFileData") + public void testOOXML(String testcase, File testFile, String extractor, int count) throws Exception { + // test processing of InputStream + try (FileInputStream fis = new FileInputStream(testFile); + POITextExtractor ext = createExtractor(fis)) { + assertNotNull(ext); + testExtractor(ext, testcase, extractor, count); + } + } + + @ParameterizedTest + @MethodSource("testOOXMLData") + public void testPackage(String testcase, File testFile, String extractor, int count) throws Exception { + try (final OPCPackage pkg = OPCPackage.open(testFile, PackageAccess.READ); + final POITextExtractor ext = xmlFactory.create(pkg)) { + assertNotNull(ext); + testExtractor(ext, testcase, extractor, count); + pkg.revert(); + } } @Test - public void testInputStream() throws Exception { - testStream(ExtractorFactory::createExtractor, true); + public void testFileInvalid() { + IOException ex = assertThrows(IOException.class, () -> createExtractor(txt)); + assertEquals("Can't create extractor - unsupported file type: UNKNOWN", ex.getMessage()); } @Test public void testInputStreamInvalid() throws IOException { try (FileInputStream fis = new FileInputStream(txt)) { - IOException ex = assertThrows(IOException.class, () -> ExtractorFactory.createExtractor(fis)); + IOException ex = assertThrows(IOException.class, () -> createExtractor(fis)); assertTrue(ex.getMessage().contains(FileMagic.UNKNOWN.name())); } } @Test - public void testPOIFS() throws Exception { - testStream((f) -> ExtractorFactory.createExtractor(new POIFSFileSystem(f)), false); - } - - @Test public void testPOIFSInvalid() { // Not really an Extractor test, but we'll leave it to test POIFS reaction anyway ... IOException ex = assertThrows(IOException.class, () -> new POIFSFileSystem(txt)); assertTrue(ex.getMessage().contains("Invalid header signature; read 0x3D20726F68747541, expected 0xE11AB1A1E011CFD0")); } - @SuppressWarnings("ConstantConditions") - private void testStream(final FunctionEx<FileInputStream, POITextExtractor> poifsIS, final boolean loadOOXML) - throws IOException, OpenXML4JException, XmlException { - for (int i = 0; i < TEST_SET.length; i += 4) { - File testFile = (File) TEST_SET[i + 1]; - if (!loadOOXML && (testFile.getName().endsWith("x") || testFile.getName().endsWith("xlsb"))) { - continue; - } - try (FileInputStream fis = new FileInputStream(testFile); - POITextExtractor ext = poifsIS.apply(fis)) { - testExtractor(ext, (String) TEST_SET[i], (String) TEST_SET[i + 2], (Integer) TEST_SET[i + 3]); - } - } - } - private void testExtractor(final POITextExtractor ext, final String testcase, final String extrClass, final Integer minLength) { assertEquals(extrClass, ext.getClass().getSimpleName(), "invalid extractor for " + testcase); final String actual = ext.getText(); @@ -194,25 +211,6 @@ public class TestExtractorFactory { assertTrue(actual.length() > minLength, "extracted content too short for " + testcase); } } - - @SuppressWarnings("ConstantConditions") - @Test - public void testPackage() throws Exception { - for (int i = 0; i < TEST_SET.length; i += 4) { - final File testFile = (File) TEST_SET[i + 1]; - if (!testFile.getName().endsWith("x")) { - continue; - } - - try (final OPCPackage pkg = OPCPackage.open(testFile, PackageAccess.READ); - final POITextExtractor ext = xmlFactory.create(pkg)) { - assertNotNull(ext); - testExtractor(ext, (String) TEST_SET[i], (String) TEST_SET[i + 2], (Integer) TEST_SET[i + 3]); - pkg.revert(); - } - } - } - @Test public void testPackageInvalid() { // Text @@ -245,19 +243,13 @@ public class TestExtractorFactory { try { // Check we get the right extractors now - try (POITextExtractor extractor = ExtractorFactory.createExtractor(new POIFSFileSystem(new FileInputStream(xls)))) { + try (POITextExtractor extractor = createExtractor(new POIFSFileSystem(new FileInputStream(xls)))) { assertTrue(extractor instanceof EventBasedExcelExtractor); - } - try (POITextExtractor extractor = ExtractorFactory.createExtractor(new POIFSFileSystem(new FileInputStream(xls)))) { assertTrue(extractor.getText().length() > 200); } - - try (POITextExtractor extractor = xmlFactory.create(OPCPackage.open(xlsx.toString(), PackageAccess.READ))) { - assertTrue(extractor instanceof XSSFEventBasedExcelExtractor); - } - try (POITextExtractor extractor = xmlFactory.create(OPCPackage.open(xlsx.toString(), PackageAccess.READ))) { assertNotNull(extractor); + assertTrue(extractor instanceof XSSFEventBasedExcelExtractor); assertTrue(extractor.getText().length() > 200); } } finally { @@ -270,76 +262,78 @@ public class TestExtractorFactory { assertNull(ExtractorFactory.getAllThreadsPreferEventExtractors()); // And back - try (POITextExtractor extractor = ExtractorFactory.createExtractor(new POIFSFileSystem(new FileInputStream(xls)))) { + try (POITextExtractor extractor = createExtractor(new POIFSFileSystem(new FileInputStream(xls)))) { assertTrue(extractor instanceof ExcelExtractor); - } - try (POITextExtractor extractor = ExtractorFactory.createExtractor(new POIFSFileSystem(new FileInputStream(xls)))) { assertTrue(extractor.getText().length() > 200); } try (POITextExtractor extractor = xmlFactory.create(OPCPackage.open(xlsx.toString(), PackageAccess.READ))) { assertTrue(extractor instanceof XSSFExcelExtractor); } + try (POITextExtractor extractor = xmlFactory.create(OPCPackage.open(xlsx.toString()))) { assertNotNull(extractor); assertTrue(extractor.getText().length() > 200); } } + public static Stream<Arguments> testEmbeddedData() { + return Stream.of( + Arguments.of("No embeddings", xls, "0-0-0-0-0-0"), + Arguments.of("Excel", xlsEmb, "6-2-2-2-0-0"), + Arguments.of("Word", docEmb, "4-1-2-1-0-0"), + Arguments.of("Word which contains an OOXML file", docEmbOOXML, "3-0-1-1-0-1"), + Arguments.of("Outlook", msgEmb, "1-1-0-0-0-0"), + Arguments.of("Outlook with another outlook file in it", msgEmbMsg, "1-0-0-0-1-0") + // TODO - PowerPoint + // TODO - Publisher + // TODO - Visio + ); + } + /** * Test embedded docs text extraction. For now, only * does poifs embedded, but will do ooxml ones * at some point. */ - @Test - public void testEmbedded() throws Exception { - final Object[] testObj = { - "No embeddings", xls, "0-0-0-0-0-0", - "Excel", xlsEmb, "6-2-2-2-0-0", - "Word", docEmb, "4-1-2-1-0-0", - "Word which contains an OOXML file", docEmbOOXML, "3-0-1-1-0-1", - "Outlook", msgEmb, "1-1-0-0-0-0", - "Outlook with another outlook file in it", msgEmbMsg, "1-0-0-0-1-0", - }; - - for (int i=0; i<testObj.length; i+=3) { - try (final POIOLE2TextExtractor ext = (POIOLE2TextExtractor)ExtractorFactory.createExtractor((File)testObj[i+1])) { - final POITextExtractor[] embeds = ExtractorFactory.getEmbeddedDocsTextExtractors(ext); - - int numWord = 0, numXls = 0, numPpt = 0, numMsg = 0, numWordX = 0; - for (POITextExtractor embed : embeds) { - assertTrue(embed.getText().length() > 20); - switch (embed.getClass().getSimpleName()) { - case "SlideShowExtractor": - numPpt++; - break; - case "ExcelExtractor": - numXls++; - break; - case "WordExtractor": - numWord++; - break; - case "OutlookTextExtractor": - numMsg++; - break; - case "XWPFWordExtractor": - numWordX++; - break; - } + @ParameterizedTest + @MethodSource("testEmbeddedData") + public void testEmbedded(String format, File file, String expected) throws Exception { + int numWord = 0, numXls = 0, numPpt = 0, numMsg = 0, numWordX = 0; + + try (final POIOLE2TextExtractor ext = (POIOLE2TextExtractor) createExtractor(file)) { + final POITextExtractor[] embeds = ExtractorFactory.getEmbeddedDocsTextExtractors(ext); + + for (POITextExtractor embed : embeds) { + assertTrue(embed.getText().length() > 20); + switch (embed.getClass().getSimpleName()) { + case "SlideShowExtractor": + numPpt++; + break; + case "ExcelExtractor": + numXls++; + break; + case "WordExtractor": + numWord++; + break; + case "OutlookTextExtractor": + numMsg++; + break; + case "XWPFWordExtractor": + numWordX++; + break; } - - final String actual = embeds.length+"-"+numWord+"-"+numXls+"-"+numPpt+"-"+numMsg+"-"+numWordX; - final String expected = (String)testObj[i+2]; - assertEquals(expected, actual, "invalid number of embeddings - "+testObj[i]); } + + final String actual = embeds.length+"-"+numWord+"-"+numXls+"-"+numPpt+"-"+numMsg+"-"+numWordX; + assertEquals(expected, actual, "invalid number of embeddings - "+format); } - // TODO - PowerPoint - // TODO - Publisher - // TODO - Visio + } - private static final String[] EXPECTED_FAILURES = { + @ParameterizedTest + @ValueSource(strings = { // password protected files "spreadsheet/password.xls", "spreadsheet/protected_passtika.xlsx", @@ -419,22 +413,13 @@ public class TestExtractorFactory { "spreadsheet/57231_MixedGasReport.xls", "spreadsheet/OddStyleRecord.xls", "spreadsheet/WithChartSheet.xlsx", - "spreadsheet/chart_sheet.xlsx", - }; - - @Test - public void testFileLeak() { + "spreadsheet/chart_sheet.xlsx" + }) + public void testFileLeak(String file) { // run a number of files that might fail in order to catch // leaked file resources when using file-leak-detector while // running the test - - for(String file : EXPECTED_FAILURES) { - try { - ExtractorFactory.createExtractor(POIDataSamples.getSpreadSheetInstance().getFile(file)); - } catch (Exception e) { - // catch all exceptions here as we are only interested in file-handle leaks - } - } + assertThrows(Exception.class, () -> ex(file)); } /** @@ -443,7 +428,7 @@ public class TestExtractorFactory { */ @Test public void bug59074() throws Exception { - try (POITextExtractor extractor = ExtractorFactory.createExtractor(POIDataSamples.getSpreadSheetInstance().getFile("59074.xls"))) { + try (POITextExtractor extractor = ex("59074.xls")) { String text = extractor.getText(); assertContains(text, "Exotic warrant"); } @@ -460,7 +445,7 @@ public class TestExtractorFactory { // bug 45565: text within TextBoxes is extracted by ExcelExtractor and WordExtractor @Test public void test45565() throws Exception { - try (POITextExtractor extractor = ExtractorFactory.createExtractor(HSSFTestDataSamples.getSampleFile("45565.xls"))) { + try (POITextExtractor extractor = ex("45565.xls")) { String text = extractor.getText(); assertThrows(AssertionError.class, () -> { assertContains(text, "testdoc"); @@ -468,4 +453,8 @@ public class TestExtractorFactory { }); } } + + private static POITextExtractor ex(String filename) throws IOException { + return createExtractor(ssTests.getFile(filename)); + } } diff --git a/src/ooxml/testcases/org/apache/poi/xslf/TestXSLFBugs.java b/src/ooxml/testcases/org/apache/poi/xslf/TestXSLFBugs.java index af0eb8581c..c95d074b3f 100644 --- a/src/ooxml/testcases/org/apache/poi/xslf/TestXSLFBugs.java +++ b/src/ooxml/testcases/org/apache/poi/xslf/TestXSLFBugs.java @@ -21,6 +21,7 @@ import static org.apache.poi.sl.draw.DrawTextParagraph.HYPERLINK_HREF; import static org.apache.poi.sl.draw.DrawTextParagraph.HYPERLINK_LABEL; import static org.apache.poi.xslf.XSLFTestDataSamples.openSampleDocument; import static org.junit.jupiter.api.Assertions.assertArrayEquals; +import static org.junit.jupiter.api.Assertions.assertDoesNotThrow; import static org.junit.jupiter.api.Assertions.assertEquals; import static org.junit.jupiter.api.Assertions.assertFalse; import static org.junit.jupiter.api.Assertions.assertNotNull; @@ -107,6 +108,7 @@ import org.apache.poi.xslf.util.DummyGraphics2d; import org.junit.jupiter.api.BeforeAll; import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Test; +import org.junit.jupiter.api.function.ThrowingSupplier; import org.openxmlformats.schemas.drawingml.x2006.main.CTOuterShadowEffect; import org.openxmlformats.schemas.presentationml.x2006.main.CTShape; @@ -513,35 +515,6 @@ public class TestXSLFBugs { ppt.close(); } - @Test - @Disabled("Similar to TestFontRendering it doesn't make sense to compare images because of tiny rendering differences in windows/unix") - public void bug54542() throws Exception { - XMLSlideShow ss = openSampleDocument("54542_cropped_bitmap.pptx"); - - Dimension pgsize = ss.getPageSize(); - - XSLFSlide slide = ss.getSlides().get(0); - - // render it - double zoom = 1; - AffineTransform at = new AffineTransform(); - at.setToScale(zoom, zoom); - - BufferedImage imgActual = new BufferedImage((int) Math.ceil(pgsize.width * zoom), (int) Math.ceil(pgsize.height * zoom), BufferedImage.TYPE_3BYTE_BGR); - Graphics2D graphics = imgActual.createGraphics(); - graphics.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON); - graphics.setRenderingHint(RenderingHints.KEY_RENDERING, RenderingHints.VALUE_RENDER_QUALITY); - graphics.setRenderingHint(RenderingHints.KEY_INTERPOLATION, RenderingHints.VALUE_INTERPOLATION_BICUBIC); - graphics.setRenderingHint(RenderingHints.KEY_FRACTIONALMETRICS, RenderingHints.VALUE_FRACTIONALMETRICS_ON); - graphics.setTransform(at); - graphics.setPaint(Color.white); - graphics.fill(new Rectangle2D.Float(0, 0, pgsize.width, pgsize.height)); - slide.draw(graphics); - - ImageIO.write(imgActual, "PNG", new File("bug54542.png")); - ss.close(); - } - private String getSlideText(XMLSlideShow ppt, XSLFSlide slide) throws IOException { try (SlideShowExtractor<XSLFShape, XSLFTextParagraph> extr = new SlideShowExtractor<>(ppt)) { // do not auto-close the slideshow @@ -880,9 +853,9 @@ public class TestXSLFBugs { @Test public void bug60715() throws IOException { - XMLSlideShow ppt = openSampleDocument("bug60715.pptx"); - ppt.createSlide(); - ppt.close(); + try (XMLSlideShow ppt = openSampleDocument("bug60715.pptx")) { + assertDoesNotThrow((ThrowingSupplier<XSLFSlide>) ppt::createSlide); + } } @Test @@ -927,10 +900,11 @@ public class TestXSLFBugs { @Test public void test60042() throws IOException { - XMLSlideShow ppt = openSampleDocument("60042.pptx"); - ppt.removeSlide(0); - ppt.createSlide(); - ppt.close(); + try (XMLSlideShow ppt = openSampleDocument("60042.pptx")) { + ppt.removeSlide(0); + ppt.createSlide(); + assertEquals(2, ppt.getSlides().size()); + } } @Test diff --git a/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestPPTX2PNG.java b/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestPPTX2PNG.java index 586a528634..39534d5b1a 100644 --- a/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestPPTX2PNG.java +++ b/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestPPTX2PNG.java @@ -50,7 +50,7 @@ public class TestPPTX2PNG { "bug64693.pptx, 53446.ppt, alterman_security.ppt, alterman_security.pptx, KEY02.pptx, themes.pptx, " + "backgrounds.pptx, layouts.pptx, sample.pptx, shapes.pptx, 54880_chinese.ppt, keyframes.pptx," + "customGeo.pptx, customGeo.ppt, wrench.emf, santa.wmf, missing-moveto.ppt, " + - "64716_image1.wmf, 64716_image2.wmf, 64716_image3.wmf"; + "64716_image1.wmf, 64716_image2.wmf, 64716_image3.wmf, 54542_cropped_bitmap.pptx"; private static final String svgFiles = "bug64693.pptx"; diff --git a/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestXSLFConnectorShape.java b/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestXSLFConnectorShape.java index 623ab833ef..19c620bc3b 100644 --- a/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestXSLFConnectorShape.java +++ b/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestXSLFConnectorShape.java @@ -23,10 +23,12 @@ import static org.apache.poi.xslf.usermodel.TestXSLFSimpleShape.getSpPr; import java.awt.Color; import java.awt.geom.Rectangle2D; import java.io.IOException; +import java.util.List; import org.apache.poi.sl.usermodel.LineDecoration.DecorationShape; import org.apache.poi.sl.usermodel.LineDecoration.DecorationSize; import org.apache.poi.sl.usermodel.ShapeType; +import org.apache.poi.xslf.XSLFTestDataSamples; import org.junit.jupiter.api.Test; import org.openxmlformats.schemas.drawingml.x2006.main.CTConnection; import org.openxmlformats.schemas.drawingml.x2006.main.CTNonVisualConnectorProperties; @@ -40,120 +42,125 @@ public class TestXSLFConnectorShape { @Test public void testLineDecorations() throws IOException { - XMLSlideShow ppt = new XMLSlideShow(); - XSLFSlide slide = ppt.createSlide(); - - XSLFConnectorShape shape = slide.createConnector(); - assertEquals(1, slide.getShapes().size()); - - assertFalse(getSpPr(shape).getLn().isSetHeadEnd()); - assertFalse(getSpPr(shape).getLn().isSetTailEnd()); - - // line decorations - assertEquals(DecorationShape.NONE, shape.getLineHeadDecoration()); - assertEquals(DecorationShape.NONE, shape.getLineTailDecoration()); - shape.setLineHeadDecoration(null); - shape.setLineTailDecoration(null); - assertEquals(DecorationShape.NONE, shape.getLineHeadDecoration()); - assertEquals(DecorationShape.NONE, shape.getLineTailDecoration()); - assertFalse(getSpPr(shape).getLn().getHeadEnd().isSetType()); - assertFalse(getSpPr(shape).getLn().getTailEnd().isSetType()); - - shape.setLineHeadDecoration(DecorationShape.ARROW); - shape.setLineTailDecoration(DecorationShape.DIAMOND); - assertEquals(DecorationShape.ARROW, shape.getLineHeadDecoration()); - assertEquals(DecorationShape.DIAMOND, shape.getLineTailDecoration()); - assertEquals(STLineEndType.ARROW, getSpPr(shape).getLn().getHeadEnd().getType()); - assertEquals(STLineEndType.DIAMOND, getSpPr(shape).getLn().getTailEnd().getType()); - - shape.setLineHeadDecoration(DecorationShape.DIAMOND); - shape.setLineTailDecoration(DecorationShape.ARROW); - assertEquals(DecorationShape.DIAMOND, shape.getLineHeadDecoration()); - assertEquals(DecorationShape.ARROW, shape.getLineTailDecoration()); - assertEquals(STLineEndType.DIAMOND, getSpPr(shape).getLn().getHeadEnd().getType()); - assertEquals(STLineEndType.ARROW, getSpPr(shape).getLn().getTailEnd().getType()); - - // line end width - assertEquals(DecorationSize.MEDIUM, shape.getLineHeadWidth()); - assertEquals(DecorationSize.MEDIUM, shape.getLineTailWidth()); - shape.setLineHeadWidth(null); - shape.setLineHeadWidth(null); - assertEquals(DecorationSize.MEDIUM, shape.getLineHeadWidth()); - assertEquals(DecorationSize.MEDIUM, shape.getLineTailWidth()); - assertFalse(getSpPr(shape).getLn().getHeadEnd().isSetW()); - assertFalse(getSpPr(shape).getLn().getTailEnd().isSetW()); - shape.setLineHeadWidth(DecorationSize.LARGE); - shape.setLineTailWidth(DecorationSize.MEDIUM); - assertEquals(DecorationSize.LARGE, shape.getLineHeadWidth()); - assertEquals(DecorationSize.MEDIUM, shape.getLineTailWidth()); - assertEquals(STLineEndWidth.LG, getSpPr(shape).getLn().getHeadEnd().getW()); - assertEquals(STLineEndWidth.MED, getSpPr(shape).getLn().getTailEnd().getW()); - shape.setLineHeadWidth(DecorationSize.MEDIUM); - shape.setLineTailWidth(DecorationSize.LARGE); - assertEquals(DecorationSize.MEDIUM, shape.getLineHeadWidth()); - assertEquals(DecorationSize.LARGE, shape.getLineTailWidth()); - assertEquals(STLineEndWidth.MED, getSpPr(shape).getLn().getHeadEnd().getW()); - assertEquals(STLineEndWidth.LG, getSpPr(shape).getLn().getTailEnd().getW()); - - // line end length - assertEquals(DecorationSize.MEDIUM, shape.getLineHeadLength()); - assertEquals(DecorationSize.MEDIUM, shape.getLineTailLength()); - shape.setLineHeadLength(null); - shape.setLineTailLength(null); - assertEquals(DecorationSize.MEDIUM, shape.getLineHeadLength()); - assertEquals(DecorationSize.MEDIUM, shape.getLineTailLength()); - assertFalse(getSpPr(shape).getLn().getHeadEnd().isSetLen()); - assertFalse(getSpPr(shape).getLn().getTailEnd().isSetLen()); - shape.setLineHeadLength(DecorationSize.LARGE); - shape.setLineTailLength(DecorationSize.MEDIUM); - assertEquals(DecorationSize.LARGE, shape.getLineHeadLength()); - assertEquals(DecorationSize.MEDIUM, shape.getLineTailLength()); - assertEquals(STLineEndLength.LG, getSpPr(shape).getLn().getHeadEnd().getLen()); - assertEquals(STLineEndLength.MED, getSpPr(shape).getLn().getTailEnd().getLen()); - shape.setLineHeadLength(DecorationSize.MEDIUM); - shape.setLineTailLength(DecorationSize.LARGE); - assertEquals(DecorationSize.MEDIUM, shape.getLineHeadLength()); - assertEquals(DecorationSize.LARGE, shape.getLineTailLength()); - assertEquals(STLineEndLength.MED, getSpPr(shape).getLn().getHeadEnd().getLen()); - assertEquals(STLineEndLength.LG, getSpPr(shape).getLn().getTailEnd().getLen()); - - ppt.close(); + try (XMLSlideShow ppt = new XMLSlideShow()) { + XSLFSlide slide = ppt.createSlide(); + + XSLFConnectorShape shape = slide.createConnector(); + assertEquals(1, slide.getShapes().size()); + + assertFalse(getSpPr(shape).getLn().isSetHeadEnd()); + assertFalse(getSpPr(shape).getLn().isSetTailEnd()); + + // line decorations + assertEquals(DecorationShape.NONE, shape.getLineHeadDecoration()); + assertEquals(DecorationShape.NONE, shape.getLineTailDecoration()); + shape.setLineHeadDecoration(null); + shape.setLineTailDecoration(null); + assertEquals(DecorationShape.NONE, shape.getLineHeadDecoration()); + assertEquals(DecorationShape.NONE, shape.getLineTailDecoration()); + assertFalse(getSpPr(shape).getLn().getHeadEnd().isSetType()); + assertFalse(getSpPr(shape).getLn().getTailEnd().isSetType()); + + shape.setLineHeadDecoration(DecorationShape.ARROW); + shape.setLineTailDecoration(DecorationShape.DIAMOND); + assertEquals(DecorationShape.ARROW, shape.getLineHeadDecoration()); + assertEquals(DecorationShape.DIAMOND, shape.getLineTailDecoration()); + assertEquals(STLineEndType.ARROW, getSpPr(shape).getLn().getHeadEnd().getType()); + assertEquals(STLineEndType.DIAMOND, getSpPr(shape).getLn().getTailEnd().getType()); + + shape.setLineHeadDecoration(DecorationShape.DIAMOND); + shape.setLineTailDecoration(DecorationShape.ARROW); + assertEquals(DecorationShape.DIAMOND, shape.getLineHeadDecoration()); + assertEquals(DecorationShape.ARROW, shape.getLineTailDecoration()); + assertEquals(STLineEndType.DIAMOND, getSpPr(shape).getLn().getHeadEnd().getType()); + assertEquals(STLineEndType.ARROW, getSpPr(shape).getLn().getTailEnd().getType()); + + // line end width + assertEquals(DecorationSize.MEDIUM, shape.getLineHeadWidth()); + assertEquals(DecorationSize.MEDIUM, shape.getLineTailWidth()); + shape.setLineHeadWidth(null); + shape.setLineHeadWidth(null); + assertEquals(DecorationSize.MEDIUM, shape.getLineHeadWidth()); + assertEquals(DecorationSize.MEDIUM, shape.getLineTailWidth()); + assertFalse(getSpPr(shape).getLn().getHeadEnd().isSetW()); + assertFalse(getSpPr(shape).getLn().getTailEnd().isSetW()); + shape.setLineHeadWidth(DecorationSize.LARGE); + shape.setLineTailWidth(DecorationSize.MEDIUM); + assertEquals(DecorationSize.LARGE, shape.getLineHeadWidth()); + assertEquals(DecorationSize.MEDIUM, shape.getLineTailWidth()); + assertEquals(STLineEndWidth.LG, getSpPr(shape).getLn().getHeadEnd().getW()); + assertEquals(STLineEndWidth.MED, getSpPr(shape).getLn().getTailEnd().getW()); + shape.setLineHeadWidth(DecorationSize.MEDIUM); + shape.setLineTailWidth(DecorationSize.LARGE); + assertEquals(DecorationSize.MEDIUM, shape.getLineHeadWidth()); + assertEquals(DecorationSize.LARGE, shape.getLineTailWidth()); + assertEquals(STLineEndWidth.MED, getSpPr(shape).getLn().getHeadEnd().getW()); + assertEquals(STLineEndWidth.LG, getSpPr(shape).getLn().getTailEnd().getW()); + + // line end length + assertEquals(DecorationSize.MEDIUM, shape.getLineHeadLength()); + assertEquals(DecorationSize.MEDIUM, shape.getLineTailLength()); + shape.setLineHeadLength(null); + shape.setLineTailLength(null); + assertEquals(DecorationSize.MEDIUM, shape.getLineHeadLength()); + assertEquals(DecorationSize.MEDIUM, shape.getLineTailLength()); + assertFalse(getSpPr(shape).getLn().getHeadEnd().isSetLen()); + assertFalse(getSpPr(shape).getLn().getTailEnd().isSetLen()); + shape.setLineHeadLength(DecorationSize.LARGE); + shape.setLineTailLength(DecorationSize.MEDIUM); + assertEquals(DecorationSize.LARGE, shape.getLineHeadLength()); + assertEquals(DecorationSize.MEDIUM, shape.getLineTailLength()); + assertEquals(STLineEndLength.LG, getSpPr(shape).getLn().getHeadEnd().getLen()); + assertEquals(STLineEndLength.MED, getSpPr(shape).getLn().getTailEnd().getLen()); + shape.setLineHeadLength(DecorationSize.MEDIUM); + shape.setLineTailLength(DecorationSize.LARGE); + assertEquals(DecorationSize.MEDIUM, shape.getLineHeadLength()); + assertEquals(DecorationSize.LARGE, shape.getLineTailLength()); + assertEquals(STLineEndLength.MED, getSpPr(shape).getLn().getHeadEnd().getLen()); + assertEquals(STLineEndLength.LG, getSpPr(shape).getLn().getTailEnd().getLen()); + } } @Test public void testAddConnector() throws IOException { - XMLSlideShow pptx = new XMLSlideShow(); - XSLFSlide slide = pptx.createSlide(); - - XSLFAutoShape rect1 = slide.createAutoShape(); - rect1.setShapeType(ShapeType.RECT); - rect1.setAnchor(new Rectangle2D.Double(100, 100, 100, 100)); - rect1.setFillColor(Color.blue); - - XSLFAutoShape rect2 = slide.createAutoShape(); - rect2.setShapeType(ShapeType.RECT); - rect2.setAnchor(new Rectangle2D.Double(300, 300, 100, 100)); - rect2.setFillColor(Color.red); - - - XSLFConnectorShape connector1 = slide.createConnector(); - connector1.setAnchor(new Rectangle2D.Double(200, 150, 100, 200)); - - CTConnector ctConnector = (CTConnector)connector1.getXmlObject(); - ctConnector.getSpPr().getPrstGeom().setPrst(STShapeType.BENT_CONNECTOR_3); - CTNonVisualConnectorProperties cx = ctConnector.getNvCxnSpPr().getCNvCxnSpPr(); - // connection start - CTConnection stCxn = cx.addNewStCxn(); - stCxn.setId(rect1.getShapeId()); - // side of the rectangle to attach the connector: left=1, bottom=2,right=3, top=4 - stCxn.setIdx(2); - - CTConnection end = cx.addNewEndCxn(); - end.setId(rect2.getShapeId()); - // side of the rectangle to attach the connector: left=1, bottom=2,right=3, top=4 - end.setIdx(3); - - pptx.close(); + try (XMLSlideShow pptx = new XMLSlideShow()) { + XSLFSlide slide = pptx.createSlide(); + + XSLFAutoShape rect1 = slide.createAutoShape(); + rect1.setShapeType(ShapeType.RECT); + rect1.setAnchor(new Rectangle2D.Double(100, 100, 100, 100)); + rect1.setFillColor(Color.blue); + + XSLFAutoShape rect2 = slide.createAutoShape(); + rect2.setShapeType(ShapeType.RECT); + rect2.setAnchor(new Rectangle2D.Double(300, 300, 100, 100)); + rect2.setFillColor(Color.red); + + + XSLFConnectorShape connector1 = slide.createConnector(); + Rectangle2D r1 = new Rectangle2D.Double(200, 150, 100, 200); + connector1.setAnchor(r1); + + CTConnector ctConnector = (CTConnector) connector1.getXmlObject(); + ctConnector.getSpPr().getPrstGeom().setPrst(STShapeType.BENT_CONNECTOR_3); + CTNonVisualConnectorProperties cx = ctConnector.getNvCxnSpPr().getCNvCxnSpPr(); + // connection start + CTConnection stCxn = cx.addNewStCxn(); + stCxn.setId(rect1.getShapeId()); + // side of the rectangle to attach the connector: left=1, bottom=2,right=3, top=4 + stCxn.setIdx(2); + + CTConnection end = cx.addNewEndCxn(); + end.setId(rect2.getShapeId()); + // side of the rectangle to attach the connector: left=1, bottom=2,right=3, top=4 + end.setIdx(3); + + try (XMLSlideShow ppt2 = XSLFTestDataSamples.writeOutAndReadBack(pptx)) { + XSLFSlide s1 = ppt2.getSlides().get(0); + List<XSLFShape> shapes = s1.getShapes(); + XSLFConnectorShape c1 = (XSLFConnectorShape)shapes.get(2); + assertEquals(r1, c1.getAnchor()); + } + } } - }
\ No newline at end of file diff --git a/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestXSLFExamples.java b/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestXSLFExamples.java index aded0ad6df..2bac551f18 100644 --- a/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestXSLFExamples.java +++ b/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestXSLFExamples.java @@ -18,6 +18,7 @@ package org.apache.poi.xslf.usermodel; import static org.apache.poi.openxml4j.opc.PackageRelationshipTypes.CORE_PROPERTIES_ECMA376_NS; +import static org.junit.jupiter.api.Assertions.assertTrue; import java.awt.Rectangle; import java.io.ByteArrayOutputStream; @@ -25,6 +26,7 @@ import java.io.File; import java.io.IOException; import java.net.URI; import java.net.URISyntaxException; +import java.util.List; import javax.xml.namespace.QName; @@ -33,6 +35,7 @@ import org.apache.poi.openxml4j.opc.PackagePart; import org.apache.poi.openxml4j.opc.PackageRelationship; import org.apache.poi.openxml4j.opc.TargetMode; import org.apache.poi.sl.usermodel.PictureData; +import org.apache.poi.xslf.XSLFTestDataSamples; import org.apache.xmlbeans.XmlCursor; import org.junit.jupiter.api.Test; import org.openxmlformats.schemas.drawingml.x2006.main.CTHyperlink; @@ -55,15 +58,14 @@ import org.openxmlformats.schemas.presentationml.x2006.main.STTLTimeNodeType; public class TestXSLFExamples { @Test public void LinkVideoToPptx() throws IOException, URISyntaxException { - String videoFileName = "file_example_MP4_640_3MG.mp4"; - File previewJpg = POIDataSamples.getDocumentInstance().getFile("abstract1.jpg"); - - XMLSlideShow pptx = new XMLSlideShow(); + String videoFileName = "file_example_MP4_640_3MG.mp4"; + File previewJpg = POIDataSamples.getDocumentInstance().getFile("abstract1.jpg"); + try (XMLSlideShow pptx = new XMLSlideShow()) { XSLFSlide slide1 = pptx.createSlide(); PackagePart pp = slide1.getPackagePart(); - URI mp4uri = new URI("./"+videoFileName); + URI mp4uri = new URI("./" + videoFileName); PackageRelationship prsEmbed1 = pp.addRelationship(mp4uri, TargetMode.EXTERNAL, "http://schemas.microsoft.com/office/2007/relationships/media"); PackageRelationship prsExec1 = pp.addRelationship(mp4uri, TargetMode.EXTERNAL, "http://schemas.openxmlformats.org/officeDocument/2006/relationships/video"); @@ -72,7 +74,7 @@ public class TestXSLFExamples { XSLFPictureShape pic1 = slide1.createPicture(snap); pic1.setAnchor(new Rectangle(100, 100, 500, 400)); - CTPicture xpic1 = (CTPicture)pic1.getXmlObject(); + CTPicture xpic1 = (CTPicture) pic1.getXmlObject(); CTHyperlink link1 = xpic1.getNvPicPr().getCNvPr().addNewHlinkClick(); link1.setId(""); link1.setAction("ppaction://media"); @@ -111,10 +113,10 @@ public class TestXSLFExamples { ctn.addNewStCondLst().addNewCond().setDelay(STTLTimeIndefinite.INDEFINITE); cmedia.addNewTgtEl().addNewSpTgt().setSpid(pic1.getShapeId()); - - // write to file - use FileOutputStream instead - try (ByteArrayOutputStream bos = new ByteArrayOutputStream()) { - pptx.write(bos); + try (XMLSlideShow ppt2 = XSLFTestDataSamples.writeOutAndReadBack(pptx)) { + XSLFShape sh = ppt2.getSlides().get(0).getShapes().get(0); + assertTrue(sh instanceof XSLFPictureShape); } + } } } diff --git a/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestXSLFGroupShape.java b/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestXSLFGroupShape.java index a1b28dd189..7ebf9c2960 100644 --- a/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestXSLFGroupShape.java +++ b/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestXSLFGroupShape.java @@ -23,86 +23,86 @@ import static org.junit.jupiter.api.Assertions.assertTrue; import java.awt.Dimension; import java.awt.geom.Rectangle2D; +import org.apache.poi.xslf.XSLFTestDataSamples; import org.junit.jupiter.api.Test; -/** - * @author Yegor Kozlov - */ public class TestXSLFGroupShape { @Test public void testCreateShapes() throws Exception { - XMLSlideShow ppt = new XMLSlideShow(); - XSLFSlide slide = ppt.createSlide(); - - ppt.setPageSize(new Dimension(792, 612)); - - XSLFGroupShape group = slide.createGroup(); - assertEquals(1, slide.getShapes().size()); - - Rectangle2D interior = new Rectangle2D.Double(-10, -10, 20, 20); - group.setInteriorAnchor(interior); - assertEquals(interior, group.getInteriorAnchor()); - - Rectangle2D anchor = new Rectangle2D.Double(0, 0, 792, 612); - group.setAnchor(anchor); - assertEquals(anchor, group.getAnchor()); - - assertTrue(group.getShapes().isEmpty()); - - XSLFTextBox shape1 = group.createTextBox(); - assertEquals(1, group.getShapes().size()); - assertSame(shape1, group.getShapes().get(0)); - assertEquals(3, shape1.getShapeId()); - - XSLFAutoShape shape2 = group.createAutoShape(); - assertEquals(2, group.getShapes().size()); - assertSame(shape1, group.getShapes().get(0)); - assertSame(shape2, group.getShapes().get(1)); - assertEquals(4, shape2.getShapeId()); - - XSLFConnectorShape shape3 = group.createConnector(); - assertEquals(3, group.getShapes().size()); - assertSame(shape3, group.getShapes().get(2)); - assertEquals(5, shape3.getShapeId()); - - XSLFGroupShape shape4 = group.createGroup(); - assertEquals(4, group.getShapes().size()); - assertSame(shape4, group.getShapes().get(3)); - assertEquals(6, shape4.getShapeId()); - - group.removeShape(shape2); - assertEquals(3, group.getShapes().size()); - assertSame(shape1, group.getShapes().get(0)); - assertSame(shape3, group.getShapes().get(1)); - assertSame(shape4, group.getShapes().get(2)); - - group.removeShape(shape3); - assertEquals(2, group.getShapes().size()); - assertSame(shape1, group.getShapes().get(0)); - assertSame(shape4, group.getShapes().get(1)); - - group.removeShape(shape1); - group.removeShape(shape4); - assertTrue(group.getShapes().isEmpty()); - - ppt.close(); + try (XMLSlideShow ppt = new XMLSlideShow()) { + XSLFSlide slide = ppt.createSlide(); + + ppt.setPageSize(new Dimension(792, 612)); + + XSLFGroupShape group = slide.createGroup(); + assertEquals(1, slide.getShapes().size()); + + Rectangle2D interior = new Rectangle2D.Double(-10, -10, 20, 20); + group.setInteriorAnchor(interior); + assertEquals(interior, group.getInteriorAnchor()); + + Rectangle2D anchor = new Rectangle2D.Double(0, 0, 792, 612); + group.setAnchor(anchor); + assertEquals(anchor, group.getAnchor()); + + assertTrue(group.getShapes().isEmpty()); + + XSLFTextBox shape1 = group.createTextBox(); + assertEquals(1, group.getShapes().size()); + assertSame(shape1, group.getShapes().get(0)); + assertEquals(3, shape1.getShapeId()); + + XSLFAutoShape shape2 = group.createAutoShape(); + assertEquals(2, group.getShapes().size()); + assertSame(shape1, group.getShapes().get(0)); + assertSame(shape2, group.getShapes().get(1)); + assertEquals(4, shape2.getShapeId()); + + XSLFConnectorShape shape3 = group.createConnector(); + assertEquals(3, group.getShapes().size()); + assertSame(shape3, group.getShapes().get(2)); + assertEquals(5, shape3.getShapeId()); + + XSLFGroupShape shape4 = group.createGroup(); + assertEquals(4, group.getShapes().size()); + assertSame(shape4, group.getShapes().get(3)); + assertEquals(6, shape4.getShapeId()); + + group.removeShape(shape2); + assertEquals(3, group.getShapes().size()); + assertSame(shape1, group.getShapes().get(0)); + assertSame(shape3, group.getShapes().get(1)); + assertSame(shape4, group.getShapes().get(2)); + + group.removeShape(shape3); + assertEquals(2, group.getShapes().size()); + assertSame(shape1, group.getShapes().get(0)); + assertSame(shape4, group.getShapes().get(1)); + + group.removeShape(shape1); + group.removeShape(shape4); + assertTrue(group.getShapes().isEmpty()); + } } @Test public void testRemoveShapes() throws Exception { - XMLSlideShow ppt = new XMLSlideShow(); - XSLFSlide slide = ppt.createSlide(); - - XSLFGroupShape group1 = slide.createGroup(); - group1.createTextBox(); - XSLFGroupShape group2 = slide.createGroup(); - group2.createTextBox(); - XSLFGroupShape group3 = slide.createGroup(); - slide.removeShape(group1); - slide.removeShape(group2); - slide.removeShape(group3); - - ppt.close(); + try (XMLSlideShow ppt = new XMLSlideShow()) { + XSLFSlide slide = ppt.createSlide(); + + XSLFGroupShape group1 = slide.createGroup(); + group1.createTextBox(); + XSLFGroupShape group2 = slide.createGroup(); + group2.createTextBox(); + XSLFGroupShape group3 = slide.createGroup(); + slide.removeShape(group1); + slide.removeShape(group2); + slide.removeShape(group3); + + try (XMLSlideShow ppt2 = XSLFTestDataSamples.writeOutAndReadBack(ppt)) { + assertEquals(0, ppt2.getSlides().get(0).getShapes().size()); + } + } } }
\ No newline at end of file diff --git a/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestXSLFTable.java b/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestXSLFTable.java index abefbaa17a..5b9ceedf1c 100644 --- a/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestXSLFTable.java +++ b/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestXSLFTable.java @@ -16,6 +16,7 @@ ==================================================================== */ package org.apache.poi.xslf.usermodel; +import static org.junit.jupiter.api.Assertions.assertDoesNotThrow; import static org.junit.jupiter.api.Assertions.assertEquals; import static org.junit.jupiter.api.Assertions.assertFalse; import static org.junit.jupiter.api.Assertions.assertNotNull; @@ -316,18 +317,20 @@ public class TestXSLFTable { } @Test - public void checkNullPointerException() { - XMLSlideShow ss = XSLFTestDataSamples.openSampleDocument("au.asn.aes.www_conferences_2011_presentations_Fri_20Room4Level4_20930_20Maloney.pptx"); - Dimension pgsize = ss.getPageSize(); - for (Slide<?, ?> s : ss.getSlides()) { - BufferedImage img = new BufferedImage(pgsize.width, pgsize.height, BufferedImage.TYPE_INT_ARGB); - Graphics2D graphics = img.createGraphics(); - - // draw stuff - s.draw(graphics); - - graphics.dispose(); - img.flush(); + public void checkNullPointerException() throws IOException { + String file = "au.asn.aes.www_conferences_2011_presentations_Fri_20Room4Level4_20930_20Maloney.pptx"; + try (XMLSlideShow ss = XSLFTestDataSamples.openSampleDocument(file)) { + Dimension pgsize = ss.getPageSize(); + for (Slide<?, ?> s : ss.getSlides()) { + BufferedImage img = new BufferedImage(pgsize.width, pgsize.height, BufferedImage.TYPE_INT_ARGB); + Graphics2D graphics = img.createGraphics(); + + // draw stuff + assertDoesNotThrow(() -> s.draw(graphics)); + + graphics.dispose(); + img.flush(); + } } } }
\ No newline at end of file diff --git a/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestXSLFTextRun.java b/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestXSLFTextRun.java index 298f8b078d..e1558eb427 100644 --- a/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestXSLFTextRun.java +++ b/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestXSLFTextRun.java @@ -19,6 +19,7 @@ package org.apache.poi.xslf.usermodel; import static org.apache.poi.sl.usermodel.BaseTestSlideShow.getColor; +import static org.junit.jupiter.api.Assertions.assertDoesNotThrow; import static org.junit.jupiter.api.Assertions.assertEquals; import static org.junit.jupiter.api.Assertions.assertFalse; import static org.junit.jupiter.api.Assertions.assertNotEquals; @@ -108,18 +109,19 @@ public class TestXSLFTextRun { } @Test - public void testCopyNullFontSize() { - XMLSlideShow ppt = new XMLSlideShow(); - XSLFSlide slide = ppt.createSlide(); - XSLFTextShape sh = slide.createAutoShape(); + public void testCopyNullFontSize() throws IOException { + try (XMLSlideShow ppt = new XMLSlideShow()) { + XSLFSlide slide = ppt.createSlide(); + XSLFTextShape sh = slide.createAutoShape(); - XSLFTextRun r = sh.addNewTextParagraph().addNewTextRun(); + XSLFTextRun r = sh.addNewTextParagraph().addNewTextRun(); - XSLFTextRun s = new XSLFTextRun(CTTextLineBreak.Factory.newInstance(), + XSLFTextRun s = new XSLFTextRun(CTTextLineBreak.Factory.newInstance(), new XSLFTextParagraph(CTTextParagraph.Factory.newInstance(), - new XSLFTextBox(CTShape.Factory.newInstance(), slide))); + new XSLFTextBox(CTShape.Factory.newInstance(), slide))); - r.copy(s); + assertDoesNotThrow(() -> r.copy(s)); + } } @Test |