diff --git a/src/documentation/content/xdocs/changes.xml b/src/documentation/content/xdocs/changes.xml index 37b8514b0f..61605b2776 100644 --- a/src/documentation/content/xdocs/changes.xml +++ b/src/documentation/content/xdocs/changes.xml @@ -37,6 +37,7 @@ + 46613 - Fixed evaluator to perform case insensitive string comparisons 46544 - command line interface for hssf ExcelExtractor 46547 - Allow addition of conditional formatting after data validation 46548 - Page Settings Block fixes - continued PLS records and PSB in sheet sub-streams diff --git a/src/documentation/content/xdocs/status.xml b/src/documentation/content/xdocs/status.xml index 8c937f51b9..595dfa1690 100644 --- a/src/documentation/content/xdocs/status.xml +++ b/src/documentation/content/xdocs/status.xml @@ -34,6 +34,7 @@ + 46613 - Fixed evaluator to perform case insensitive string comparisons 46544 - command line interface for hssf ExcelExtractor 46547 - Allow addition of conditional formatting after data validation 46548 - Page Settings Block fixes - continued PLS records and PSB in sheet sub-streams diff --git a/src/java/org/apache/poi/hssf/record/formula/eval/RelationalOperationEval.java b/src/java/org/apache/poi/hssf/record/formula/eval/RelationalOperationEval.java index a1397f07f4..9dee4bc1e0 100644 --- a/src/java/org/apache/poi/hssf/record/formula/eval/RelationalOperationEval.java +++ b/src/java/org/apache/poi/hssf/record/formula/eval/RelationalOperationEval.java @@ -97,7 +97,7 @@ public abstract class RelationalOperationEval implements OperationEval { if (vb instanceof StringEval) { StringEval sA = (StringEval) va; StringEval sB = (StringEval) vb; - return sA.getStringValue().compareTo(sB.getStringValue()); + return sA.getStringValue().compareToIgnoreCase(sB.getStringValue()); } return 1; } diff --git a/src/testcases/org/apache/poi/hssf/record/formula/eval/TestEqualEval.java b/src/testcases/org/apache/poi/hssf/record/formula/eval/TestEqualEval.java index d1b1db0d16..92f603923c 100644 --- a/src/testcases/org/apache/poi/hssf/record/formula/eval/TestEqualEval.java +++ b/src/testcases/org/apache/poi/hssf/record/formula/eval/TestEqualEval.java @@ -23,7 +23,7 @@ import junit.framework.TestCase; import org.apache.poi.hssf.record.formula.functions.EvalFactory; /** - * Test for unary plus operator evaluator. + * Test for {@link EqualEval} * * @author Josh Micich */ @@ -66,4 +66,29 @@ public final class TestEqualEval extends TestCase { } assertTrue(be.getBooleanValue()); } + + /** + * Test for bug 46613 (observable at svn r737248) + */ + public void testStringInsensitive_bug46613() { + if (!evalStringCmp("abc", "aBc", EqualEval.instance)) { + throw new AssertionFailedError("Identified bug 46613"); + } + assertTrue(evalStringCmp("abc", "aBc", EqualEval.instance)); + assertTrue(evalStringCmp("ABC", "azz", LessThanEval.instance)); + assertTrue(evalStringCmp("abc", "AZZ", LessThanEval.instance)); + assertTrue(evalStringCmp("ABC", "aaa", GreaterThanEval.instance)); + assertTrue(evalStringCmp("abc", "AAA", GreaterThanEval.instance)); + } + + private static boolean evalStringCmp(String a, String b, OperationEval cmpOp) { + Eval[] args = { + new StringEval(a), + new StringEval(b), + }; + Eval result = cmpOp.evaluate(args, 10, (short)20); + assertEquals(BoolEval.class, result.getClass()); + BoolEval be = (BoolEval) result; + return be.getBooleanValue(); + } }