diff options
author | Cédric Walter <cedricwalter@apache.org> | 2014-10-27 12:29:32 +0000 |
---|---|---|
committer | Cédric Walter <cedricwalter@apache.org> | 2014-10-27 12:29:32 +0000 |
commit | 4364b1621db832808540623d9405cafecb6daf32 (patch) | |
tree | e55f58b23bcacc6d29f9af743dc50c0453645ec4 /src/testcases/org/apache/poi/ss/formula | |
parent | 4112a026f9b150b90e0f782750070c817bbc15fd (diff) | |
download | poi-4364b1621db832808540623d9405cafecb6daf32.tar.gz poi-4364b1621db832808540623d9405cafecb6daf32.zip |
Bug 57150: Added EOMONTH function
git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1634515 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'src/testcases/org/apache/poi/ss/formula')
3 files changed, 205 insertions, 36 deletions
diff --git a/src/testcases/org/apache/poi/ss/formula/functions/RefValueImplementation.java b/src/testcases/org/apache/poi/ss/formula/functions/RefValueImplementation.java new file mode 100644 index 0000000000..1a3fc1e62b --- /dev/null +++ b/src/testcases/org/apache/poi/ss/formula/functions/RefValueImplementation.java @@ -0,0 +1,68 @@ +/* ====================================================================
+ Licensed to the Apache Software Foundation (ASF) under one or more
+ contributor license agreements. See the NOTICE file distributed with
+ this work for additional information regarding copyright ownership.
+ The ASF licenses this file to You under the Apache License, Version 2.0
+ (the "License"); you may not use this file except in compliance with
+ the License. You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+==================================================================== */
+
+package org.apache.poi.ss.formula.functions;
+
+import org.apache.poi.ss.formula.eval.AreaEval;
+import org.apache.poi.ss.formula.eval.RefEval;
+import org.apache.poi.ss.formula.eval.ValueEval;
+
+final class RefEvalImplementation implements RefEval {
+
+ private final ValueEval value;
+
+ public RefEvalImplementation(ValueEval value) {
+ this.value = value;
+ }
+
+ @Override
+ public AreaEval offset(int relFirstRowIx, int relLastRowIx,
+ int relFirstColIx, int relLastColIx) {
+ throw new UnsupportedOperationException();
+ }
+
+ @Override
+ public ValueEval getInnerValueEval(int sheetIndex) {
+ return value;
+ }
+
+ @Override
+ public int getNumberOfSheets() {
+ return 1;
+ }
+
+ @Override
+ public int getFirstSheetIndex() {
+ return 0;
+ }
+
+ @Override
+ public int getLastSheetIndex() {
+ return 0;
+ }
+
+ @Override
+ public int getRow() {
+ throw new UnsupportedOperationException();
+ }
+
+ @Override
+ public int getColumn() {
+ throw new UnsupportedOperationException();
+ }
+
+}
diff --git a/src/testcases/org/apache/poi/ss/formula/functions/TestEDate.java b/src/testcases/org/apache/poi/ss/formula/functions/TestEDate.java index 3a5d527b77..3917f44cb9 100644 --- a/src/testcases/org/apache/poi/ss/formula/functions/TestEDate.java +++ b/src/testcases/org/apache/poi/ss/formula/functions/TestEDate.java @@ -31,42 +31,7 @@ import org.apache.poi.ss.formula.eval.ValueEval; import org.apache.poi.ss.usermodel.DateUtil; import org.apache.poi.ss.usermodel.ErrorConstants; -public class TestEDate extends TestCase{ - - private final class RefEvalImplementation implements RefEval { - private final ValueEval value; - - public RefEvalImplementation(ValueEval value) { - super(); - this.value = value; - } - - public AreaEval offset(int relFirstRowIx, int relLastRowIx, - int relFirstColIx, int relLastColIx) { - throw new UnsupportedOperationException(); - } - - public ValueEval getInnerValueEval(int sheetIndex) { - return value; - } - - public int getNumberOfSheets() { - return 1; - } - public int getFirstSheetIndex() { - return 0; - } - public int getLastSheetIndex() { - return 0; - } - - public int getRow() { - throw new UnsupportedOperationException(); - } - public int getColumn() { - throw new UnsupportedOperationException(); - } - } +public class TestEDate extends TestCase { public void testEDateProperValues() { // verify some border-case combinations of startDate and month-increase diff --git a/src/testcases/org/apache/poi/ss/formula/functions/TestEOMonth.java b/src/testcases/org/apache/poi/ss/formula/functions/TestEOMonth.java new file mode 100644 index 0000000000..55372b03a5 --- /dev/null +++ b/src/testcases/org/apache/poi/ss/formula/functions/TestEOMonth.java @@ -0,0 +1,136 @@ +/* ====================================================================
+ Licensed to the Apache Software Foundation (ASF) under one or more
+ contributor license agreements. See the NOTICE file distributed with
+ this work for additional information regarding copyright ownership.
+ The ASF licenses this file to You under the Apache License, Version 2.0
+ (the "License"); you may not use this file except in compliance with
+ the License. You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+==================================================================== */
+
+package org.apache.poi.ss.formula.functions;
+
+import java.util.Calendar;
+import java.util.Date;
+
+import junit.framework.TestCase;
+import org.apache.poi.ss.formula.OperationEvaluationContext;
+
+import org.apache.poi.ss.formula.eval.BlankEval;
+import org.apache.poi.ss.formula.eval.ErrorEval;
+import org.apache.poi.ss.formula.eval.NumberEval;
+import org.apache.poi.ss.formula.eval.StringEval;
+import org.apache.poi.ss.formula.eval.ValueEval;
+import org.apache.poi.ss.usermodel.DateUtil;
+import org.apache.poi.ss.usermodel.ErrorConstants;
+
+public class TestEOMonth extends TestCase{
+
+ private static final double BAD_DATE = -1.0;
+
+ private static final double DATE_1900_01_01 = 1.0;
+ private static final double DATE_1900_01_31 = 31.0;
+ private static final double DATE_1900_02_28 = 59.0;
+ private static final double DATE_1902_09_26 = 1000.0;
+ private static final double DATE_1902_09_30 = 1004.0;
+ private static final double DATE_2034_06_09 = 49104.0;
+ private static final double DATE_2034_06_30 = 49125.0;
+ private static final double DATE_2034_07_31 = 49156.0;
+
+ private final FreeRefFunction eOMonth = EOMonth.instance;
+ private final OperationEvaluationContext ec = new OperationEvaluationContext(null, null, 0, 0, 0, null);
+
+ public void testEOMonthProperValues() {
+ // verify some border-case combinations of startDate and month-increase
+ checkValue(DATE_1900_01_01, 0, DATE_1900_01_31);
+ checkValue(DATE_1900_01_01, 1, DATE_1900_02_28);
+ checkValue(DATE_1902_09_26, 0, DATE_1902_09_30);
+ checkValue(DATE_2034_06_09, 0, DATE_2034_06_30);
+ checkValue(DATE_2034_06_09, 1, DATE_2034_07_31);
+ }
+
+ public void testEOMonthBadDateValues() {
+ checkValue(0.0, -2, BAD_DATE);
+ checkValue(0.0, -3, BAD_DATE);
+ checkValue(DATE_1900_01_31, -1, BAD_DATE);
+ }
+
+ private void checkValue(double startDate, int monthInc, double expectedResult) {
+ NumberEval result = (NumberEval) eOMonth.evaluate(new ValueEval[] {new NumberEval(startDate), new NumberEval(monthInc)}, ec);
+ assertEquals(expectedResult, result.getNumberValue());
+ }
+
+ public void testEOMonthZeroDate() {
+ NumberEval result = (NumberEval) eOMonth.evaluate(new ValueEval[] {new NumberEval(0), new NumberEval(0)}, ec);
+ assertEquals("0 startDate is 1900-01-00", DATE_1900_01_31, result.getNumberValue());
+
+ result = (NumberEval) eOMonth.evaluate(new ValueEval[] {new NumberEval(0), new NumberEval(1)}, ec);
+ assertEquals("0 startDate is 1900-01-00", DATE_1900_02_28, result.getNumberValue());
+ }
+
+ public void testEOMonthInvalidArguments() {
+ ValueEval result = eOMonth.evaluate(new ValueEval[] {new NumberEval(DATE_1902_09_26)}, ec);
+ assertTrue(result instanceof ErrorEval);
+ assertEquals(ErrorConstants.ERROR_VALUE, ((ErrorEval) result).getErrorCode());
+
+ result = eOMonth.evaluate(new ValueEval[] {new StringEval("a"), new StringEval("b")}, ec);
+ assertTrue(result instanceof ErrorEval);
+ assertEquals(ErrorConstants.ERROR_VALUE, ((ErrorEval) result).getErrorCode());
+ }
+
+ public void testEOMonthIncrease() {
+ checkOffset(new Date(), 2);
+ }
+
+ public void testEOMonthDecrease() {
+ checkOffset(new Date(), -2);
+ }
+
+ private void checkOffset(Date startDate, int offset) {
+ NumberEval result = (NumberEval) eOMonth.evaluate(new ValueEval[] {new NumberEval(DateUtil.getExcelDate(startDate)), new NumberEval(offset)}, ec);
+ Date resultDate = DateUtil.getJavaDate(result.getNumberValue());
+ Calendar instance = Calendar.getInstance();
+ instance.setTime(startDate);
+ instance.add(Calendar.MONTH, offset);
+ instance.add(Calendar.MONTH, 1);
+ instance.set(Calendar.DAY_OF_MONTH, 1);
+ instance.add(Calendar.DAY_OF_MONTH, -1);
+ instance.set(Calendar.HOUR_OF_DAY, 0);
+ instance.set(Calendar.MINUTE, 0);
+ instance.set(Calendar.SECOND, 0);
+ instance.set(Calendar.MILLISECOND, 0);
+ assertEquals(instance.getTime(), resultDate);
+ }
+
+ public void testBug56688() {
+ NumberEval result = (NumberEval) eOMonth.evaluate(new ValueEval[] {new NumberEval(DATE_1902_09_26), new RefEvalImplementation(new NumberEval(0))}, ec);
+ assertEquals(DATE_1902_09_30, result.getNumberValue());
+ }
+
+ public void testRefEvalStartDate() {
+ NumberEval result = (NumberEval) eOMonth.evaluate(new ValueEval[] {new RefEvalImplementation(new NumberEval(DATE_1902_09_26)), new NumberEval(0)}, ec);
+ assertEquals(DATE_1902_09_30, result.getNumberValue());
+ }
+
+ public void testEOMonthBlankValueEval() {
+ NumberEval evaluate = (NumberEval) eOMonth.evaluate(new ValueEval[] {BlankEval.instance, new NumberEval(0)}, ec);
+ assertEquals("Blank is handled as 0", DATE_1900_01_31, evaluate.getNumberValue());
+ }
+
+ public void testEOMonthBlankRefValueEval() {
+ NumberEval result = (NumberEval) eOMonth.evaluate(new ValueEval[] {new RefEvalImplementation(BlankEval.instance), new NumberEval(1)}, ec);
+ assertEquals("Blank is handled as 0",
+ DATE_1900_02_28, result.getNumberValue());
+
+ result = (NumberEval) eOMonth.evaluate(new ValueEval[] {new NumberEval(1), new RefEvalImplementation(BlankEval.instance)}, ec);
+ assertEquals("Blank is handled as 0",
+ DATE_1900_01_31, result.getNumberValue());
+ }
+}
|