mirror of https://github.com/apache/poi.git
convert TestWorkbookEvaluator from junit3 to junit4
git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1712908 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
15c74ce02b
commit
14b454b2da
|
@ -17,10 +17,12 @@
|
||||||
|
|
||||||
package org.apache.poi.ss.formula;
|
package org.apache.poi.ss.formula;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertEquals;
|
||||||
|
import static org.junit.Assert.fail;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
import junit.framework.AssertionFailedError;
|
import org.junit.Test;
|
||||||
import junit.framework.TestCase;
|
|
||||||
|
|
||||||
import org.apache.poi.hssf.HSSFTestDataSamples;
|
import org.apache.poi.hssf.HSSFTestDataSamples;
|
||||||
import org.apache.poi.ss.formula.ptg.AreaErrPtg;
|
import org.apache.poi.ss.formula.ptg.AreaErrPtg;
|
||||||
|
@ -54,7 +56,9 @@ import org.apache.poi.ss.usermodel.Workbook;
|
||||||
*
|
*
|
||||||
* @author Josh Micich
|
* @author Josh Micich
|
||||||
*/
|
*/
|
||||||
public class TestWorkbookEvaluator extends TestCase {
|
public class TestWorkbookEvaluator {
|
||||||
|
|
||||||
|
private static final double EPSILON = 0.0000001;
|
||||||
|
|
||||||
private static ValueEval evaluateFormula(Ptg[] ptgs) {
|
private static ValueEval evaluateFormula(Ptg[] ptgs) {
|
||||||
OperationEvaluationContext ec = new OperationEvaluationContext(null, null, 0, 0, 0, null);
|
OperationEvaluationContext ec = new OperationEvaluationContext(null, null, 0, 0, 0, null);
|
||||||
|
@ -65,6 +69,7 @@ public class TestWorkbookEvaluator extends TestCase {
|
||||||
* Make sure that the evaluator can directly handle tAttrSum (instead of relying on re-parsing
|
* Make sure that the evaluator can directly handle tAttrSum (instead of relying on re-parsing
|
||||||
* the whole formula which converts tAttrSum to tFuncVar("SUM") )
|
* the whole formula which converts tAttrSum to tFuncVar("SUM") )
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testAttrSum() {
|
public void testAttrSum() {
|
||||||
|
|
||||||
Ptg[] ptgs = {
|
Ptg[] ptgs = {
|
||||||
|
@ -81,6 +86,7 @@ public class TestWorkbookEvaluator extends TestCase {
|
||||||
* (instead of relying on re-parsing the whole formula which converts these
|
* (instead of relying on re-parsing the whole formula which converts these
|
||||||
* to the error constant #REF! )
|
* to the error constant #REF! )
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testRefErr() {
|
public void testRefErr() {
|
||||||
|
|
||||||
confirmRefErr(new RefErrorPtg());
|
confirmRefErr(new RefErrorPtg());
|
||||||
|
@ -101,6 +107,7 @@ public class TestWorkbookEvaluator extends TestCase {
|
||||||
* Make sure that the evaluator can directly handle tAttrSum (instead of relying on re-parsing
|
* Make sure that the evaluator can directly handle tAttrSum (instead of relying on re-parsing
|
||||||
* the whole formula which converts tAttrSum to tFuncVar("SUM") )
|
* the whole formula which converts tAttrSum to tFuncVar("SUM") )
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testMemFunc() {
|
public void testMemFunc() {
|
||||||
|
|
||||||
Ptg[] ptgs = {
|
Ptg[] ptgs = {
|
||||||
|
@ -113,6 +120,7 @@ public class TestWorkbookEvaluator extends TestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
public void testEvaluateMultipleWorkbooks() {
|
public void testEvaluateMultipleWorkbooks() {
|
||||||
HSSFWorkbook wbA = HSSFTestDataSamples.openSampleWorkbook("multibookFormulaA.xls");
|
HSSFWorkbook wbA = HSSFTestDataSamples.openSampleWorkbook("multibookFormulaA.xls");
|
||||||
HSSFWorkbook wbB = HSSFTestDataSamples.openSampleWorkbook("multibookFormulaB.xls");
|
HSSFWorkbook wbB = HSSFTestDataSamples.openSampleWorkbook("multibookFormulaB.xls");
|
||||||
|
@ -178,6 +186,7 @@ public class TestWorkbookEvaluator extends TestCase {
|
||||||
* This test makes sure that any {@link MissingArgEval} that propagates to
|
* This test makes sure that any {@link MissingArgEval} that propagates to
|
||||||
* the result of a function gets translated to {@link BlankEval}.
|
* the result of a function gets translated to {@link BlankEval}.
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testMissingArg() {
|
public void testMissingArg() {
|
||||||
HSSFWorkbook wb = new HSSFWorkbook();
|
HSSFWorkbook wb = new HSSFWorkbook();
|
||||||
HSSFSheet sheet = wb.createSheet("Sheet1");
|
HSSFSheet sheet = wb.createSheet("Sheet1");
|
||||||
|
@ -185,11 +194,11 @@ public class TestWorkbookEvaluator extends TestCase {
|
||||||
HSSFCell cell = row.createCell(0);
|
HSSFCell cell = row.createCell(0);
|
||||||
cell.setCellFormula("1+IF(1,,)");
|
cell.setCellFormula("1+IF(1,,)");
|
||||||
HSSFFormulaEvaluator fe = new HSSFFormulaEvaluator(wb);
|
HSSFFormulaEvaluator fe = new HSSFFormulaEvaluator(wb);
|
||||||
CellValue cv;
|
CellValue cv = null;
|
||||||
try {
|
try {
|
||||||
cv = fe.evaluate(cell);
|
cv = fe.evaluate(cell);
|
||||||
} catch (RuntimeException e) {
|
} catch (RuntimeException e) {
|
||||||
throw new AssertionFailedError("Missing arg result not being handled correctly.");
|
fail("Missing arg result not being handled correctly.");
|
||||||
}
|
}
|
||||||
assertEquals(HSSFCell.CELL_TYPE_NUMERIC, cv.getCellType());
|
assertEquals(HSSFCell.CELL_TYPE_NUMERIC, cv.getCellType());
|
||||||
// adding blank to 1.0 gives 1.0
|
// adding blank to 1.0 gives 1.0
|
||||||
|
@ -217,6 +226,7 @@ public class TestWorkbookEvaluator extends TestCase {
|
||||||
* should be dereferenced by the evaluator
|
* should be dereferenced by the evaluator
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testResultOutsideRange() throws IOException {
|
public void testResultOutsideRange() throws IOException {
|
||||||
Workbook wb = new HSSFWorkbook();
|
Workbook wb = new HSSFWorkbook();
|
||||||
try {
|
try {
|
||||||
|
@ -228,7 +238,7 @@ public class TestWorkbookEvaluator extends TestCase {
|
||||||
cv = fe.evaluate(cell);
|
cv = fe.evaluate(cell);
|
||||||
} catch (IllegalArgumentException e) {
|
} catch (IllegalArgumentException e) {
|
||||||
if ("Specified row index (0) is outside the allowed range (1..4)".equals(e.getMessage())) {
|
if ("Specified row index (0) is outside the allowed range (1..4)".equals(e.getMessage())) {
|
||||||
throw new AssertionFailedError("Identified bug in result dereferencing");
|
fail("Identified bug in result dereferencing");
|
||||||
}
|
}
|
||||||
throw new RuntimeException(e);
|
throw new RuntimeException(e);
|
||||||
}
|
}
|
||||||
|
@ -251,6 +261,7 @@ public class TestWorkbookEvaluator extends TestCase {
|
||||||
* formulas with defined names.
|
* formulas with defined names.
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testNamesInFormulas() throws IOException {
|
public void testNamesInFormulas() throws IOException {
|
||||||
Workbook wb = new HSSFWorkbook();
|
Workbook wb = new HSSFWorkbook();
|
||||||
Sheet sheet = wb.createSheet("Sheet1");
|
Sheet sheet = wb.createSheet("Sheet1");
|
||||||
|
@ -283,10 +294,10 @@ public class TestWorkbookEvaluator extends TestCase {
|
||||||
row3.createCell(2).setCellFormula("aConstant+aFormula+SUM(aSet)");
|
row3.createCell(2).setCellFormula("aConstant+aFormula+SUM(aSet)");
|
||||||
|
|
||||||
FormulaEvaluator fe = wb.getCreationHelper().createFormulaEvaluator();
|
FormulaEvaluator fe = wb.getCreationHelper().createFormulaEvaluator();
|
||||||
assertEquals(3.14, fe.evaluate(row0.getCell(2)).getNumberValue());
|
assertEquals(3.14, fe.evaluate(row0.getCell(2)).getNumberValue(), EPSILON);
|
||||||
assertEquals(10.0, fe.evaluate(row1.getCell(2)).getNumberValue());
|
assertEquals(10.0, fe.evaluate(row1.getCell(2)).getNumberValue(), EPSILON);
|
||||||
assertEquals(15.0, fe.evaluate(row2.getCell(2)).getNumberValue());
|
assertEquals(15.0, fe.evaluate(row2.getCell(2)).getNumberValue(), EPSILON);
|
||||||
assertEquals(28.14, fe.evaluate(row3.getCell(2)).getNumberValue());
|
assertEquals(28.14, fe.evaluate(row3.getCell(2)).getNumberValue(), EPSILON);
|
||||||
|
|
||||||
wb.close();
|
wb.close();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue