diff options
author | Mark Murphy <jmarkmurphy@apache.org> | 2016-12-01 02:21:56 +0000 |
---|---|---|
committer | Mark Murphy <jmarkmurphy@apache.org> | 2016-12-01 02:21:56 +0000 |
commit | 36b7f4413016469dc6292d630b3b5445f2bdcc26 (patch) | |
tree | e767ce3e0b59a73b4727c7ad7e4ca68b7c4be284 /src | |
parent | 6406553f517c03a5bdc5b055e179615dcab66e21 (diff) | |
download | poi-36b7f4413016469dc6292d630b3b5445f2bdcc26.tar.gz poi-36b7f4413016469dc6292d630b3b5445f2bdcc26.zip |
60329: Avoid NPE when styleid is null
Task-Url: https://bz.apache.org/bugzilla/show_bug.cgi?id=60329
git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1772138 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'src')
-rw-r--r-- | src/ooxml/java/org/apache/poi/xwpf/usermodel/XWPFStyles.java | 10 | ||||
-rw-r--r-- | src/ooxml/testcases/org/apache/poi/xwpf/usermodel/TestXWPFStyles.java | 37 |
2 files changed, 41 insertions, 6 deletions
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 55e1ca4755..5f961ea9dd 100644 --- a/src/ooxml/java/org/apache/poi/xwpf/usermodel/XWPFStyles.java +++ b/src/ooxml/java/org/apache/poi/xwpf/usermodel/XWPFStyles.java @@ -194,9 +194,13 @@ public class XWPFStyles extends POIXMLDocumentPart { * @return style
*/
public XWPFStyle getStyle(String styleID) {
- for (XWPFStyle style : listStyle) {
- if (style.getStyleId().equals(styleID))
- return style;
+ for (XWPFStyle style : listStyle) { + try { + if (style.getStyleId().equals(styleID)) + return style; + } catch (NullPointerException e) { + // Ignore NPE + } }
return null;
}
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 3773b2998d..6210d11781 100644 --- a/src/ooxml/testcases/org/apache/poi/xwpf/usermodel/TestXWPFStyles.java +++ b/src/ooxml/testcases/org/apache/poi/xwpf/usermodel/TestXWPFStyles.java @@ -17,13 +17,18 @@ package org.apache.poi.xwpf.usermodel; +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.assertNotNull; +import static org.junit.Assert.assertNull; +import static org.junit.Assert.assertTrue; +import static org.junit.Assert.fail; + import java.io.IOException; import java.util.ArrayList; import java.util.List; -import junit.framework.TestCase; - import org.apache.poi.xwpf.XWPFTestDataSamples; +import org.junit.Test; import org.openxmlformats.schemas.wordprocessingml.x2006.main.CTFonts; import org.openxmlformats.schemas.wordprocessingml.x2006.main.CTLatentStyles; import org.openxmlformats.schemas.wordprocessingml.x2006.main.CTLsdException; @@ -31,7 +36,8 @@ import org.openxmlformats.schemas.wordprocessingml.x2006.main.CTStyle; import org.openxmlformats.schemas.wordprocessingml.x2006.main.CTStyles; import org.openxmlformats.schemas.wordprocessingml.x2006.main.STStyleType; -public class TestXWPFStyles extends TestCase { +public final class TestXWPFStyles { + @Test public void testGetUsedStyles() throws IOException { XWPFDocument sampleDoc = XWPFTestDataSamples.openSampleDocument("Styles.docx"); List<XWPFStyle> testUsedStyleList = new ArrayList<XWPFStyle>(); @@ -47,6 +53,7 @@ public class TestXWPFStyles extends TestCase { assertEquals(usedStyleList, testUsedStyleList); } + @Test public void testAddStylesToDocument() throws IOException { XWPFDocument docOut = new XWPFDocument(); XWPFStyles styles = docOut.createStyles(); @@ -70,6 +77,7 @@ public class TestXWPFStyles extends TestCase { * Bug #52449 - We should be able to write a file containing * both regular and glossary styles without error */ + @Test public void test52449() throws Exception { XWPFDocument doc = XWPFTestDataSamples.openSampleDocument("52449.docx"); XWPFStyles styles = doc.getStyles(); @@ -86,6 +94,7 @@ public class TestXWPFStyles extends TestCase { * they exist only to copy xml beans to pi-ooxml-schemas.jar */ @SuppressWarnings("resource") + @Test public void testLanguages() { XWPFDocument docOut = new XWPFDocument(); XWPFStyles styles = docOut.createStyles(); @@ -97,6 +106,7 @@ public class TestXWPFStyles extends TestCase { styles.setDefaultFonts(def); } + @Test public void testType() { CTStyle ctStyle = CTStyle.Factory.newInstance(); XWPFStyle style = new XWPFStyle(ctStyle); @@ -105,6 +115,7 @@ public class TestXWPFStyles extends TestCase { assertEquals(STStyleType.PARAGRAPH, style.getType()); } + @Test public void testLatentStyles() { CTLatentStyles latentStyles = CTLatentStyles.Factory.newInstance(); CTLsdException ex = latentStyles.addNewLsdException(); @@ -114,6 +125,7 @@ public class TestXWPFStyles extends TestCase { assertEquals(false, ls.isLatentStyle("notex1")); } + @Test public void testSetStyles_Bug57254() throws IOException { XWPFDocument docOut = new XWPFDocument(); XWPFStyles styles = docOut.createStyles(); @@ -133,6 +145,7 @@ public class TestXWPFStyles extends TestCase { assertTrue(styles.styleExist(strStyleId)); } + @Test public void testEasyAccessToStyles() throws IOException { XWPFDocument doc = XWPFTestDataSamples.openSampleDocument("SampleDoc.docx"); XWPFStyles styles = doc.getStyles(); @@ -188,4 +201,22 @@ public class TestXWPFStyles extends TestCase { assertEquals(11, styles.getDefaultRunStyle().getFontSize()); assertEquals(200, styles.getDefaultParagraphStyle().getSpacingAfter()); } + + // Bug 60329: style with missing StyleID throws NPE + @Test + public void testMissingStyleId() throws IOException { + XWPFDocument doc = XWPFTestDataSamples.openSampleDocument("60329.docx"); + XWPFStyles styles = doc.getStyles(); + // Styles exist in the test document in this order, EmptyCellLayoutStyle + // is missing a StyleId + try { + assertNotNull(styles.getStyle("NoList")); + assertNull(styles.getStyle("EmptyCellLayoutStyle")); + assertNotNull(styles.getStyle("BalloonText")); + } catch (NullPointerException e) { + fail(e.toString()); + } + + doc.close(); + } } |