From 38774b82a807e0155926405aed9cac7a0d14fc8b Mon Sep 17 00:00:00 2001 From: Yegor Kozlov Date: Sat, 2 Mar 2013 11:38:09 +0000 Subject: [PATCH] Bugzilla 54436: Fixed metadata for GETPIVOTDATA function git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1451875 13f79535-47bb-0310-9956-ffa450edef68 --- .../poi/xssf/usermodel/TestXSSFBugs.java | 17 +++++++++++++++++ .../ss/formula/function/functionMetadata.txt | 14 +++++++------- test-data/spreadsheet/54436.xlsx | Bin 0 -> 12180 bytes 3 files changed, 24 insertions(+), 7 deletions(-) create mode 100644 test-data/spreadsheet/54436.xlsx diff --git a/src/ooxml/testcases/org/apache/poi/xssf/usermodel/TestXSSFBugs.java b/src/ooxml/testcases/org/apache/poi/xssf/usermodel/TestXSSFBugs.java index 4c55cca900..76e7a36e98 100644 --- a/src/ooxml/testcases/org/apache/poi/xssf/usermodel/TestXSSFBugs.java +++ b/src/ooxml/testcases/org/apache/poi/xssf/usermodel/TestXSSFBugs.java @@ -26,6 +26,10 @@ import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.apache.poi.openxml4j.opc.OPCPackage; import org.apache.poi.openxml4j.opc.PackagePart; import org.apache.poi.openxml4j.opc.PackagingURIHelper; +import org.apache.poi.ss.formula.WorkbookEvaluator; +import org.apache.poi.ss.formula.eval.ErrorEval; +import org.apache.poi.ss.formula.eval.ValueEval; +import org.apache.poi.ss.formula.functions.Function; import org.apache.poi.ss.usermodel.BaseTestBugzillaIssues; import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellStyle; @@ -1339,4 +1343,17 @@ public final class TestXSSFBugs extends BaseTestBugzillaIssues { assertEquals(259.0, a1Value, 0.0); } + public void test54436(){ + Workbook workbook = XSSFTestDataSamples.openSampleWorkbook("54436.xlsx"); + if(!WorkbookEvaluator.getSupportedFunctionNames().contains("GETPIVOTDATA")){ + Function func = new Function() { + public ValueEval evaluate(ValueEval[] args, int srcRowIndex, int srcColumnIndex) { + return ErrorEval.NA; + } + }; + + WorkbookEvaluator.registerFunction("GETPIVOTDATA", func); + } + workbook.getCreationHelper().createFormulaEvaluator().evaluateAll(); + } } diff --git a/src/resources/main/org/apache/poi/ss/formula/function/functionMetadata.txt b/src/resources/main/org/apache/poi/ss/formula/function/functionMetadata.txt index 277d229a82..36775c859d 100644 --- a/src/resources/main/org/apache/poi/ss/formula/function/functionMetadata.txt +++ b/src/resources/main/org/apache/poi/ss/formula/function/functionMetadata.txt @@ -271,13 +271,13 @@ 350 ISPMT 4 4 V V V V V 351 DATEDIF 3 3 V V V V 352 DATESTRING 1 1 V V -353 NUMBERSTRING 2 2 V V V -354 ROMAN 1 2 V V V -# New Built-In Sheet Functions in BIFF8 -358 GETPIVOTDATA 2 30 -359 HYPERLINK 1 2 V V V -360 PHONETIC 1 1 V R -361 AVERAGEA 1 30 V R ... +353 NUMBERSTRING 2 2 V V V +354 ROMAN 1 2 V V V +# New Built-In Sheet Functions in BIFF8 +358 GETPIVOTDATA 2 30 V V R ... +359 HYPERLINK 1 2 V V V +360 PHONETIC 1 1 V R +361 AVERAGEA 1 30 V R ... 362 MAXA 1 30 V R ... 363 MINA 1 30 V R ... 364 STDEVPA 1 30 V R ... diff --git a/test-data/spreadsheet/54436.xlsx b/test-data/spreadsheet/54436.xlsx new file mode 100644 index 0000000000000000000000000000000000000000..4f113b8b717e097d35fcb8e917081ef7a67d49e9 GIT binary patch literal 12180 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