From e80ae0bb07ec59e8b76f213be9392f55487f23f0 Mon Sep 17 00:00:00 2001 From: PJ Fanning Date: Tue, 17 Oct 2023 16:05:08 +0000 Subject: [PATCH] [bug-67784] add tests git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1913068 13f79535-47bb-0310-9956-ffa450edef68 --- .../TestXSSFEventBasedExcelExtractor.java | 27 ++++++++++++++++++ .../extractor/TestXSSFExcelExtractor.java | 11 +++++++ test-data/spreadsheet/bug67784.xlsx | Bin 0 -> 6211 bytes 3 files changed, 38 insertions(+) create mode 100644 test-data/spreadsheet/bug67784.xlsx diff --git a/poi-ooxml/src/test/java/org/apache/poi/xssf/extractor/TestXSSFEventBasedExcelExtractor.java b/poi-ooxml/src/test/java/org/apache/poi/xssf/extractor/TestXSSFEventBasedExcelExtractor.java index accaae3bea..fe543ef37b 100644 --- a/poi-ooxml/src/test/java/org/apache/poi/xssf/extractor/TestXSSFEventBasedExcelExtractor.java +++ b/poi-ooxml/src/test/java/org/apache/poi/xssf/extractor/TestXSSFEventBasedExcelExtractor.java @@ -362,4 +362,31 @@ class TestXSSFEventBasedExcelExtractor { assertContains(text, "Bob\tBob"); } } + + @Test + void test67784() throws Exception { + try (XSSFEventBasedExcelExtractor ex = + new XSSFEventBasedExcelExtractor( + XSSFTestDataSamples.openSamplePackage("bug67784.xlsx"))) { + String text = ex.getText().replace("\r", ""); + String[] lines = text.split("\n"); + assertEquals("FALSE", lines[2]); + assertEquals("TRUE", lines[3]); + assertEquals("ERROR:#DIV/0!", lines[4]); + } + } + + @Test + void test67784Formulas() throws Exception { + try (XSSFEventBasedExcelExtractor ex = + new XSSFEventBasedExcelExtractor( + XSSFTestDataSamples.openSamplePackage("bug67784.xlsx"))) { + ex.setFormulasNotResults(true); + String text = ex.getText().replace("\r", ""); + String[] lines = text.split("\n"); + assertEquals("(2 > 5)", lines[2]); + assertEquals("(2 < 4)", lines[3]); + assertEquals("10/0", lines[4]); + } + } } diff --git a/poi-ooxml/src/test/java/org/apache/poi/xssf/extractor/TestXSSFExcelExtractor.java b/poi-ooxml/src/test/java/org/apache/poi/xssf/extractor/TestXSSFExcelExtractor.java index 1e435753fa..40fc0602b7 100644 --- a/poi-ooxml/src/test/java/org/apache/poi/xssf/extractor/TestXSSFExcelExtractor.java +++ b/poi-ooxml/src/test/java/org/apache/poi/xssf/extractor/TestXSSFExcelExtractor.java @@ -245,6 +245,17 @@ class TestXSSFExcelExtractor { //in the extracted text assertNotContained(text, "\u30CB\u30DB\u30F3"); } + } + @Test + void test67784Formulas() throws Exception { + try (XSSFExcelExtractor extractor = getExtractor("bug67784.xlsx")) { + extractor.setFormulasNotResults(true); + String text = extractor.getText().replace("\r", ""); + String[] lines = text.split("\n"); + assertEquals("(2 > 5)", lines[2]); + assertEquals("(2 < 4)", lines[3]); + assertEquals("10/0", lines[4]); + } } } diff --git a/test-data/spreadsheet/bug67784.xlsx b/test-data/spreadsheet/bug67784.xlsx new file mode 100644 index 0000000000000000000000000000000000000000..df5c63bc56080c371367068fdbe9b5e2fda1733f GIT binary patch literal 6211 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 ATL1t6 literal 0 HcmV?d00001