From 46b9ccf9d573c47d0e4c8e1e9087b3c0103a4772 Mon Sep 17 00:00:00 2001 From: Armin Braun Date: Fri, 3 Nov 2017 20:23:07 +0100 Subject: [PATCH] #27189 Fixed rounding of bounds in scaled float comparison (#27207) * #27189 Fixed rounding of bounds in scaled float comparison * #27189 more assertions from CR --- .../index/mapper/ScaledFloatFieldMapper.java | 8 ++--- .../mapper/ScaledFloatFieldTypeTests.java | 36 +++++++++++++++++++ 2 files changed, 40 insertions(+), 4 deletions(-) diff --git a/modules/mapper-extras/src/main/java/org/elasticsearch/index/mapper/ScaledFloatFieldMapper.java b/modules/mapper-extras/src/main/java/org/elasticsearch/index/mapper/ScaledFloatFieldMapper.java index 0dc9bab6f57bc..6ba66ed670441 100644 --- a/modules/mapper-extras/src/main/java/org/elasticsearch/index/mapper/ScaledFloatFieldMapper.java +++ b/modules/mapper-extras/src/main/java/org/elasticsearch/index/mapper/ScaledFloatFieldMapper.java @@ -258,19 +258,19 @@ public Query rangeQuery(Object lowerTerm, Object upperTerm, boolean includeLower failIfNotIndexed(); Long lo = null; if (lowerTerm != null) { - double dValue = parse(lowerTerm); + double dValue = parse(lowerTerm) * scalingFactor; if (includeLower == false) { dValue = Math.nextUp(dValue); } - lo = Math.round(Math.ceil(dValue * scalingFactor)); + lo = Math.round(Math.ceil(dValue)); } Long hi = null; if (upperTerm != null) { - double dValue = parse(upperTerm); + double dValue = parse(upperTerm) * scalingFactor; if (includeUpper == false) { dValue = Math.nextDown(dValue); } - hi = Math.round(Math.floor(dValue * scalingFactor)); + hi = Math.round(Math.floor(dValue)); } Query query = NumberFieldMapper.NumberType.LONG.rangeQuery(name(), lo, hi, true, true, hasDocValues()); if (boost() != 1f) { diff --git a/modules/mapper-extras/src/test/java/org/elasticsearch/index/mapper/ScaledFloatFieldTypeTests.java b/modules/mapper-extras/src/test/java/org/elasticsearch/index/mapper/ScaledFloatFieldTypeTests.java index 811bac82bbce9..83039ebd88319 100644 --- a/modules/mapper-extras/src/test/java/org/elasticsearch/index/mapper/ScaledFloatFieldTypeTests.java +++ b/modules/mapper-extras/src/test/java/org/elasticsearch/index/mapper/ScaledFloatFieldTypeTests.java @@ -124,6 +124,42 @@ public void testRangeQuery() throws IOException { IOUtils.close(reader, dir); } + public void testRoundsUpperBoundCorrectly() { + ScaledFloatFieldMapper.ScaledFloatFieldType ft = new ScaledFloatFieldMapper.ScaledFloatFieldType(); + ft.setName("scaled_float"); + ft.setScalingFactor(100.0); + Query scaledFloatQ = ft.rangeQuery(null, 0.1, true, false, null); + assertEquals("scaled_float:[-9223372036854775808 TO 9]", scaledFloatQ.toString()); + scaledFloatQ = ft.rangeQuery(null, 0.1, true, true, null); + assertEquals("scaled_float:[-9223372036854775808 TO 10]", scaledFloatQ.toString()); + scaledFloatQ = ft.rangeQuery(null, 0.095, true, false, null); + assertEquals("scaled_float:[-9223372036854775808 TO 9]", scaledFloatQ.toString()); + scaledFloatQ = ft.rangeQuery(null, 0.095, true, true, null); + assertEquals("scaled_float:[-9223372036854775808 TO 9]", scaledFloatQ.toString()); + scaledFloatQ = ft.rangeQuery(null, 0.105, true, false, null); + assertEquals("scaled_float:[-9223372036854775808 TO 10]", scaledFloatQ.toString()); + scaledFloatQ = ft.rangeQuery(null, 0.105, true, true, null); + assertEquals("scaled_float:[-9223372036854775808 TO 10]", scaledFloatQ.toString()); + } + + public void testRoundsLowerBoundCorrectly() { + ScaledFloatFieldMapper.ScaledFloatFieldType ft = new ScaledFloatFieldMapper.ScaledFloatFieldType(); + ft.setName("scaled_float"); + ft.setScalingFactor(100.0); + Query scaledFloatQ = ft.rangeQuery(-0.1, null, false, true, null); + assertEquals("scaled_float:[-9 TO 9223372036854775807]", scaledFloatQ.toString()); + scaledFloatQ = ft.rangeQuery(-0.1, null, true, true, null); + assertEquals("scaled_float:[-10 TO 9223372036854775807]", scaledFloatQ.toString()); + scaledFloatQ = ft.rangeQuery(-0.095, null, false, true, null); + assertEquals("scaled_float:[-9 TO 9223372036854775807]", scaledFloatQ.toString()); + scaledFloatQ = ft.rangeQuery(-0.095, null, true, true, null); + assertEquals("scaled_float:[-9 TO 9223372036854775807]", scaledFloatQ.toString()); + scaledFloatQ = ft.rangeQuery(-0.105, null, false, true, null); + assertEquals("scaled_float:[-10 TO 9223372036854775807]", scaledFloatQ.toString()); + scaledFloatQ = ft.rangeQuery(-0.105, null, true, true, null); + assertEquals("scaled_float:[-10 TO 9223372036854775807]", scaledFloatQ.toString()); + } + public void testValueForSearch() { ScaledFloatFieldMapper.ScaledFloatFieldType ft = new ScaledFloatFieldMapper.ScaledFloatFieldType(); ft.setName("scaled_float");