From caf2d32393f6179673a615e9f0db5ef06956654e Mon Sep 17 00:00:00 2001 From: Dominik Stadler Date: Sat, 30 Jan 2021 18:42:14 +0000 Subject: Bug 65099: Fix incorrect handling of styles in XWPFStyle.getUsedStyleList Closes github #216 git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1886063 13f79535-47bb-0310-9956-ffa450edef68 --- .../org/apache/poi/xwpf/usermodel/XWPFStyles.java | 4 +-- .../apache/poi/xwpf/usermodel/TestXWPFBugs.java | 31 +++++++++++++++++++++ .../apache/poi/xwpf/usermodel/TestXWPFStyles.java | 6 ++-- test-data/document/65099.docx | Bin 0 -> 17126 bytes 4 files changed, 36 insertions(+), 5 deletions(-) create mode 100644 test-data/document/65099.docx diff --git a/src/ooxml/java/org/apache/poi/xwpf/usermodel/XWPFStyles.java b/src/ooxml/java/org/apache/poi/xwpf/usermodel/XWPFStyles.java index 3d4b1b7268..93b05ab901 100644 --- a/src/ooxml/java/org/apache/poi/xwpf/usermodel/XWPFStyles.java +++ b/src/ooxml/java/org/apache/poi/xwpf/usermodel/XWPFStyles.java @@ -228,8 +228,8 @@ public class XWPFStyles extends POIXMLDocumentPart { String nextStyleID = style.getNextStyleID(); XWPFStyle nextStyle = getStyle(nextStyleID); if ((nextStyle != null) && (!usedStyleList.contains(nextStyle))) { - usedStyleList.add(linkStyle); - getUsedStyleList(linkStyle, usedStyleList); + usedStyleList.add(nextStyle); + getUsedStyleList(nextStyle, usedStyleList); } return usedStyleList; } diff --git a/src/ooxml/testcases/org/apache/poi/xwpf/usermodel/TestXWPFBugs.java b/src/ooxml/testcases/org/apache/poi/xwpf/usermodel/TestXWPFBugs.java index 4ad0d80a8c..2974c879dc 100644 --- a/src/ooxml/testcases/org/apache/poi/xwpf/usermodel/TestXWPFBugs.java +++ b/src/ooxml/testcases/org/apache/poi/xwpf/usermodel/TestXWPFBugs.java @@ -20,12 +20,14 @@ import static org.junit.jupiter.api.Assertions.assertEquals; import static org.junit.jupiter.api.Assertions.assertFalse; import static org.junit.jupiter.api.Assertions.assertNotNull; import static org.junit.jupiter.api.Assertions.assertNull; +import static org.junit.jupiter.api.Assertions.assertThrows; import static org.junit.jupiter.api.Assertions.assertTrue; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.math.BigInteger; +import java.util.List; import org.apache.poi.util.Units; import org.apache.poi.xwpf.XWPFTestDataSamples; @@ -230,4 +232,33 @@ class TestXWPFBugs { documentNumbering.addNum(abstractNumID); } + + @Test + public void test65099() throws IOException { + try (XWPFDocument doc = XWPFTestDataSamples.openSampleDocument("65099.docx")) { + XWPFStyles styles = doc.getStyles(); + assertNotNull(styles); + + XWPFStyle normal = styles.getStyle("Normal"); + assertNotNull(normal); + + XWPFStyle style1 = styles.getStyle("EdfTitre3Car"); + assertNotNull(style1); + + List list = styles.getUsedStyleList(normal); + assertNotNull(list); + assertEquals(1, list.size()); + + list = styles.getUsedStyleList(style1); + assertNotNull(list); + assertEquals(7, list.size()); + + assertThrows(NullPointerException.class, + () -> styles.getUsedStyleList(null), + "Pasisng in 'null' triggers an exception"); + + XWPFStyle style = doc.getStyles().getStyle("TableauGrille41"); + doc.getStyles().getUsedStyleList(style); + } + } } diff --git a/src/ooxml/testcases/org/apache/poi/xwpf/usermodel/TestXWPFStyles.java b/src/ooxml/testcases/org/apache/poi/xwpf/usermodel/TestXWPFStyles.java index fcabe249dd..6c517f4c95 100644 --- a/src/ooxml/testcases/org/apache/poi/xwpf/usermodel/TestXWPFStyles.java +++ b/src/ooxml/testcases/org/apache/poi/xwpf/usermodel/TestXWPFStyles.java @@ -170,7 +170,7 @@ public final class TestXWPFStyles { assertNull(r.getColor()); assertNull(r.getFontFamily()); assertNull(r.getFontName()); - assertEquals(-1, r.getFontSize()); + assertNull(r.getFontSizeAsDouble()); } // On page two, has explicit styles, but on runs not on @@ -184,7 +184,7 @@ public final class TestXWPFStyles { XWPFRun r = p.getRuns().get(0); assertEquals("Arial Black", r.getFontFamily()); assertEquals("Arial Black", r.getFontName()); - assertEquals(16, r.getFontSize()); + assertEquals(16.0, r.getFontSizeAsDouble(), 0.01); assertEquals("548DD4", r.getColor()); } @@ -203,7 +203,7 @@ public final class TestXWPFStyles { assertNotNull(styles.getDefaultRunStyle()); assertNotNull(styles.getDefaultParagraphStyle()); - assertEquals(11, styles.getDefaultRunStyle().getFontSize()); + assertEquals(11.0, styles.getDefaultRunStyle().getFontSizeAsDouble(), 0.01); assertEquals(11.0, styles.getDefaultRunStyle().getFontSizeAsDouble(), 0.01); assertEquals(200, styles.getDefaultParagraphStyle().getSpacingAfter()); } diff --git a/test-data/document/65099.docx b/test-data/document/65099.docx new file mode 100644 index 0000000000..a0b57db943 Binary files /dev/null and b/test-data/document/65099.docx differ -- cgit v1.2.3