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 93d906f5e3..423220c66e 100644 --- a/src/ooxml/testcases/org/apache/poi/xssf/usermodel/TestXSSFBugs.java +++ b/src/ooxml/testcases/org/apache/poi/xssf/usermodel/TestXSSFBugs.java @@ -1653,6 +1653,45 @@ public final class TestXSSFBugs extends BaseTestBugzillaIssues { assertEquals("0", formatter.formatCellValue(cell)); } + /** + * Formulas which reference named ranges, either in other + * sheets, or workbook scoped but in other workbooks. + * Currently failing with errors like + * org.apache.poi.ss.formula.FormulaParseException: Cell reference expected after sheet name at index 9 + * org.apache.poi.ss.formula.FormulaParseException: Parse error near char 0 '[' in specified formula '[0]!NR_Global_B2'. Expected number, string, or defined name + */ + @Ignore + @Test + public void bug56737() throws IOException { + Workbook wb = XSSFTestDataSamples.openSampleWorkbook("56737.xlsx"); + + // Check the named range definitions + Name nSheetScope = wb.getName("NR_To_A1"); + Name nWBScope = wb.getName("NR_Global_B2"); + + assertNotNull(nSheetScope); + assertNotNull(nWBScope); + + assertEquals("Defines!$A$1", nSheetScope.getRefersToFormula()); + assertEquals("Defines!$B$2", nWBScope.getRefersToFormula()); + + // Check the different kinds of formulas + Sheet s = wb.getSheetAt(0); + Cell cRefSName = s.getRow(1).getCell(3); + Cell cRefWName = s.getRow(2).getCell(3); + + assertEquals("Defines!NR_To_A1", cRefSName.getCellFormula()); + assertEquals("[0]!NR_Global_B2", cRefWName.getCellFormula()); + + // Try to evaluate them + FormulaEvaluator eval = wb.getCreationHelper().createFormulaEvaluator(); + assertEquals("Test A1", eval.evaluate(cRefSName).getStringValue()); + assertEquals(142, (int)eval.evaluate(cRefWName).getNumberValue()); + + // Try to evaluate everything + eval.evaluateAll(); + } + private void saveAndReloadReport(Workbook wb, File outFile) throws IOException { // run some method on the font to verify if it is "disconnected" already //for(short i = 0;i < 256;i++) diff --git a/src/testcases/org/apache/poi/hssf/usermodel/TestBugs.java b/src/testcases/org/apache/poi/hssf/usermodel/TestBugs.java index 141a8e4483..5d03b45d3f 100644 --- a/src/testcases/org/apache/poi/hssf/usermodel/TestBugs.java +++ b/src/testcases/org/apache/poi/hssf/usermodel/TestBugs.java @@ -67,6 +67,7 @@ import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellStyle; import org.apache.poi.ss.usermodel.DataFormat; import org.apache.poi.ss.usermodel.DataFormatter; +import org.apache.poi.ss.usermodel.FormulaEvaluator; import org.apache.poi.ss.usermodel.Name; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet; @@ -2611,4 +2612,42 @@ public final class TestBugs extends BaseTestBugzillaIssues { wb = HSSFTestDataSamples.writeOutAndReadBack(wb); assertEquals(0, wb.getNumberOfSheets()); } + + /** + * Formulas which reference named ranges, either in other + * sheets, or workbook scoped but in other workbooks. + * Currently failing with + * java.lang.RuntimeException: Unexpected eval class (org.apache.poi.ss.formula.eval.NameXEval) + */ + @Ignore + @Test + public void bug56737() throws IOException { + Workbook wb = openSample("56737.xls"); + + // Check the named range definitions + Name nSheetScope = wb.getName("NR_To_A1"); + Name nWBScope = wb.getName("NR_Global_B2"); + + assertNotNull(nSheetScope); + assertNotNull(nWBScope); + + assertEquals("Defines!$A$1", nSheetScope.getRefersToFormula()); + assertEquals("Defines!$B$2", nWBScope.getRefersToFormula()); + + // Check the different kinds of formulas + Sheet s = wb.getSheetAt(0); + Cell cRefSName = s.getRow(1).getCell(3); + Cell cRefWName = s.getRow(2).getCell(3); + + assertEquals("Defines!NR_To_A1", cRefSName.getCellFormula()); + assertEquals("'56737.xls'!NR_Global_B2", cRefWName.getCellFormula()); + + // Try to evaluate them + FormulaEvaluator eval = wb.getCreationHelper().createFormulaEvaluator(); + assertEquals("Test A1", eval.evaluate(cRefSName).getStringValue()); + assertEquals(142, (int)eval.evaluate(cRefWName).getNumberValue()); + + // Try to evaluate everything + eval.evaluateAll(); + } } diff --git a/test-data/spreadsheet/56737.xls b/test-data/spreadsheet/56737.xls new file mode 100644 index 0000000000..59ab233a08 Binary files /dev/null and b/test-data/spreadsheet/56737.xls differ diff --git a/test-data/spreadsheet/56737.xlsx b/test-data/spreadsheet/56737.xlsx new file mode 100644 index 0000000000..3783483ef4 Binary files /dev/null and b/test-data/spreadsheet/56737.xlsx differ