Thanks for following up, Adrien. That's my mistake of making
randomInt() inclusive in RandomizedTest -- while technically fine, its
confusing similarity of naming with Random.nextInt() that is
range-exclusive can lead to mistakes. I'll  deprecate those methods in
RandomizedTest.

Dawid
On Wed, Aug 1, 2018 at 3:50 PM Adrien Grand <[email protected]> wrote:
>
> Sorry Dawid this commit triggered lots of off-by-1 errors since randomInt(X) 
> returns numbers up to X included while random.nextInt(X) returns numbers up 
> to X-1 so I reverted it to stop the flood of test failures on our internal CI 
> server. I'll re-apply the part that decreases the test size.
>
> Le mer. 1 août 2018 à 14:05, <[email protected]> a écrit :
>>
>> Repository: lucene-solr
>> Updated Branches:
>>   refs/heads/branch_7x fd2cc195f -> 7396da542
>>   refs/heads/master 5dffff7df -> 3203e99d8
>>
>>
>> Make the nightly test smaller so that it does not fail with GC overhead 
>> exceeded (OOM). Clean up random number fetching to make it shorter.
>>
>>
>> Project: http://git-wip-us.apache.org/repos/asf/lucene-solr/repo
>> Commit: http://git-wip-us.apache.org/repos/asf/lucene-solr/commit/3203e99d
>> Tree: http://git-wip-us.apache.org/repos/asf/lucene-solr/tree/3203e99d
>> Diff: http://git-wip-us.apache.org/repos/asf/lucene-solr/diff/3203e99d
>>
>> Branch: refs/heads/master
>> Commit: 3203e99d8fbcaac3458fcf882d4ec229f97dfa43
>> Parents: 5dffff7
>> Author: Dawid Weiss <[email protected]>
>> Authored: Wed Aug 1 13:49:39 2018 +0200
>> Committer: Dawid Weiss <[email protected]>
>> Committed: Wed Aug 1 14:05:02 2018 +0200
>>
>> ----------------------------------------------------------------------
>>  .../lucene/document/TestLatLonShapeQueries.java | 15 +++--
>>  .../java/org/apache/lucene/geo/GeoTestUtil.java | 70 ++++++++++----------
>>  2 files changed, 43 insertions(+), 42 deletions(-)
>> ----------------------------------------------------------------------
>>
>>
>> http://git-wip-us.apache.org/repos/asf/lucene-solr/blob/3203e99d/lucene/sandbox/src/test/org/apache/lucene/document/TestLatLonShapeQueries.java
>> ----------------------------------------------------------------------
>> diff --git 
>> a/lucene/sandbox/src/test/org/apache/lucene/document/TestLatLonShapeQueries.java
>>  
>> b/lucene/sandbox/src/test/org/apache/lucene/document/TestLatLonShapeQueries.java
>> index 03941b9..21d4e83 100644
>> --- 
>> a/lucene/sandbox/src/test/org/apache/lucene/document/TestLatLonShapeQueries.java
>> +++ 
>> b/lucene/sandbox/src/test/org/apache/lucene/document/TestLatLonShapeQueries.java
>> @@ -45,6 +45,8 @@ import org.apache.lucene.util.FixedBitSet;
>>  import org.apache.lucene.util.IOUtils;
>>  import org.apache.lucene.util.LuceneTestCase;
>>
>> +import static 
>> com.carrotsearch.randomizedtesting.RandomizedTest.randomBoolean;
>> +import static com.carrotsearch.randomizedtesting.RandomizedTest.randomInt;
>>  import static org.apache.lucene.geo.GeoEncodingUtils.decodeLatitude;
>>  import static org.apache.lucene.geo.GeoEncodingUtils.decodeLongitude;
>>  import static org.apache.lucene.geo.GeoEncodingUtils.encodeLatitude;
>> @@ -104,7 +106,7 @@ public class TestLatLonShapeQueries extends 
>> LuceneTestCase {
>>
>>    @Nightly
>>    public void testRandomBig() throws Exception {
>> -    doTestRandom(200000);
>> +    doTestRandom(50000);
>>    }
>>
>>    private void doTestRandom(int count) throws Exception {
>> @@ -116,7 +118,7 @@ public class TestLatLonShapeQueries extends 
>> LuceneTestCase {
>>
>>      Polygon[] polygons = new Polygon[numPolygons];
>>      for (int id = 0; id < numPolygons; ++id) {
>> -      int x = random().nextInt(20);
>> +      int x = randomInt(20);
>>        if (x == 17) {
>>          polygons[id] = null;
>>          if (VERBOSE) {
>> @@ -127,6 +129,7 @@ public class TestLatLonShapeQueries extends 
>> LuceneTestCase {
>>          polygons[id] = GeoTestUtil.nextPolygon();
>>        }
>>      }
>> +
>>      verify(polygons);
>>    }
>>
>> @@ -173,8 +176,8 @@ public class TestLatLonShapeQueries extends 
>> LuceneTestCase {
>>          poly2D[id] = Polygon2D.create(quantizePolygon(polygons[id]));
>>        }
>>        w.addDocument(doc);
>> -      if (id > 0 && random().nextInt(100) == 42) {
>> -        int idToDelete = random().nextInt(id);
>> +      if (id > 0 && randomInt(100) == 42) {
>> +        int idToDelete = randomInt(id);
>>          w.deleteDocuments(new Term("id", ""+idToDelete));
>>          deleted.add(idToDelete);
>>          if (VERBOSE) {
>> @@ -183,7 +186,7 @@ public class TestLatLonShapeQueries extends 
>> LuceneTestCase {
>>        }
>>      }
>>
>> -    if (random().nextBoolean()) {
>> +    if (randomBoolean()) {
>>        w.forceMerge(1);
>>      }
>>      final IndexReader r = DirectoryReader.open(w);
>> @@ -198,7 +201,7 @@ public class TestLatLonShapeQueries extends 
>> LuceneTestCase {
>>
>>      for (int iter = 0; iter < iters; ++iter) {
>>        if (VERBOSE) {
>> -        System.out.println("\nTEST: iter=" + (iter+1) + " of " + iters + " 
>> s=" + s);
>> +        System.out.println("\nTEST: iter=" + (iter + 1) + " of " + iters + 
>> " s=" + s);
>>        }
>>
>>        // BBox
>>
>> http://git-wip-us.apache.org/repos/asf/lucene-solr/blob/3203e99d/lucene/test-framework/src/java/org/apache/lucene/geo/GeoTestUtil.java
>> ----------------------------------------------------------------------
>> diff --git 
>> a/lucene/test-framework/src/java/org/apache/lucene/geo/GeoTestUtil.java 
>> b/lucene/test-framework/src/java/org/apache/lucene/geo/GeoTestUtil.java
>> index fe81fd6..8817d20 100644
>> --- a/lucene/test-framework/src/java/org/apache/lucene/geo/GeoTestUtil.java
>> +++ b/lucene/test-framework/src/java/org/apache/lucene/geo/GeoTestUtil.java
>> @@ -19,13 +19,16 @@ package org.apache.lucene.geo;
>>  import java.util.ArrayList;
>>  import java.util.Arrays;
>>  import java.util.List;
>> -import java.util.Random;
>>
>>  import org.apache.lucene.util.NumericUtils;
>>  import org.apache.lucene.util.SloppyMath;
>>  import org.apache.lucene.util.TestUtil;
>>
>> -import com.carrotsearch.randomizedtesting.RandomizedContext;
>> +import static 
>> com.carrotsearch.randomizedtesting.RandomizedTest.randomBoolean;
>> +import static 
>> com.carrotsearch.randomizedtesting.RandomizedTest.randomDouble;
>> +import static com.carrotsearch.randomizedtesting.RandomizedTest.randomInt;
>> +import static 
>> com.carrotsearch.randomizedtesting.RandomizedTest.randomIntBetween;
>> +import static org.apache.lucene.util.LuceneTestCase.random;
>>
>>  /** static methods for testing geo */
>>  public class GeoTestUtil {
>> @@ -63,7 +66,7 @@ public class GeoTestUtil {
>>
>>      // first pick a base value.
>>      final double baseValue;
>> -    int surpriseMe = random().nextInt(17);
>> +    int surpriseMe = randomInt(17);
>>      if (surpriseMe == 0) {
>>        // random bits
>>        long lowBits = NumericUtils.doubleToSortableLong(low);
>> @@ -81,18 +84,18 @@ public class GeoTestUtil {
>>      } else if (surpriseMe == 4) {
>>        // divide up space into block of 360
>>        double delta = (high - low) / 360;
>> -      int block = random().nextInt(360);
>> +      int block = randomInt(360);
>>        baseValue = low + delta * block;
>>      } else {
>>        // distributed ~ evenly
>> -      baseValue = low + (high - low) * random().nextDouble();
>> +      baseValue = low + (high - low) * randomDouble();
>>      }
>>
>>      assert baseValue >= low;
>>      assert baseValue <= high;
>>
>>      // either return the base value or adjust it by 1 ulp in a random 
>> direction (if possible)
>> -    int adjustMe = random().nextInt(17);
>> +    int adjustMe = randomInt(17);
>>      if (adjustMe == 0) {
>>        return Math.nextAfter(adjustMe, high);
>>      } else if (adjustMe == 1) {
>> @@ -106,7 +109,7 @@ public class GeoTestUtil {
>>    private static double nextLatitudeNear(double otherLatitude, double 
>> delta) {
>>      delta = Math.abs(delta);
>>      GeoUtils.checkLatitude(otherLatitude);
>> -    int surpriseMe = random().nextInt(97);
>> +    int surpriseMe = randomInt(97);
>>      if (surpriseMe == 0) {
>>        // purely random
>>        return nextLatitude();
>> @@ -123,7 +126,7 @@ public class GeoTestUtil {
>>    private static double nextLongitudeNear(double otherLongitude, double 
>> delta) {
>>      delta = Math.abs(delta);
>>      GeoUtils.checkLongitude(otherLongitude);
>> -    int surpriseMe = random().nextInt(97);
>> +    int surpriseMe = randomInt(97);
>>      if (surpriseMe == 0) {
>>        // purely random
>>        return nextLongitude();
>> @@ -145,7 +148,7 @@ public class GeoTestUtil {
>>      assert maxLatitude >= minLatitude;
>>      GeoUtils.checkLatitude(minLatitude);
>>      GeoUtils.checkLatitude(maxLatitude);
>> -    if (random().nextInt(47) == 0) {
>> +    if (randomInt(47) == 0) {
>>        // purely random
>>        return nextLatitude();
>>      } else {
>> @@ -166,7 +169,7 @@ public class GeoTestUtil {
>>      assert maxLongitude >= minLongitude;
>>      GeoUtils.checkLongitude(minLongitude);
>>      GeoUtils.checkLongitude(maxLongitude);
>> -    if (random().nextInt(47) == 0) {
>> +    if (randomInt(47) == 0) {
>>        // purely random
>>        return nextLongitude();
>>      } else {
>> @@ -211,7 +214,7 @@ public class GeoTestUtil {
>>    public static double[] nextPointNear(Rectangle rectangle) {
>>      if (rectangle.crossesDateline()) {
>>        // pick a "side" of the two boxes we really are
>> -      if (random().nextBoolean()) {
>> +      if (randomBoolean()) {
>>          return nextPointNear(new Rectangle(rectangle.minLat, 
>> rectangle.maxLat, -180, rectangle.maxLon));
>>        } else {
>>          return nextPointNear(new Rectangle(rectangle.minLat, 
>> rectangle.maxLat, rectangle.minLon, 180));
>> @@ -229,11 +232,11 @@ public class GeoTestUtil {
>>      Polygon holes[] = polygon.getHoles();
>>
>>      // if there are any holes, target them aggressively
>> -    if (holes.length > 0 && random().nextInt(3) == 0) {
>> -      return nextPointNear(holes[random().nextInt(holes.length)]);
>> +    if (holes.length > 0 && randomInt(3) == 0) {
>> +      return nextPointNear(holes[randomInt(holes.length)]);
>>      }
>>
>> -    int surpriseMe = random().nextInt(97);
>> +    int surpriseMe = randomInt(97);
>>      if (surpriseMe == 0) {
>>        // purely random
>>        return new double[] { nextLatitude(), nextLongitude() };
>> @@ -242,7 +245,7 @@ public class GeoTestUtil {
>>        return new double[] { nextLatitudeBetween(polygon.minLat, 
>> polygon.maxLat), nextLongitudeBetween(polygon.minLon, polygon.maxLon) };
>>      } else if (surpriseMe < 20) {
>>        // target a vertex
>> -      int vertex = random().nextInt(polyLats.length - 1);
>> +      int vertex = randomInt(polyLats.length - 1);
>>        return new double[] { nextLatitudeNear(polyLats[vertex], 
>> polyLats[vertex+1] - polyLats[vertex]),
>>                              nextLongitudeNear(polyLons[vertex], 
>> polyLons[vertex+1] - polyLons[vertex]) };
>>      } else if (surpriseMe < 30) {
>> @@ -250,14 +253,14 @@ public class GeoTestUtil {
>>        Polygon container = boxPolygon(new Rectangle(polygon.minLat, 
>> polygon.maxLat, polygon.minLon, polygon.maxLon));
>>        double containerLats[] = container.getPolyLats();
>>        double containerLons[] = container.getPolyLons();
>> -      int startVertex = random().nextInt(containerLats.length - 1);
>> +      int startVertex = randomInt(containerLats.length - 1);
>>        return nextPointAroundLine(containerLats[startVertex], 
>> containerLons[startVertex],
>>                                   containerLats[startVertex+1], 
>> containerLons[startVertex+1]);
>>      } else {
>>        // target points around diagonals between vertices
>> -      int startVertex = random().nextInt(polyLats.length - 1);
>> +      int startVertex = randomInt(polyLats.length - 1);
>>        // but favor edges heavily
>> -      int endVertex = random().nextBoolean() ? startVertex + 1 : 
>> random().nextInt(polyLats.length - 1);
>> +      int endVertex = randomBoolean() ? startVertex + 1 : 
>> randomInt(polyLats.length - 1);
>>        return nextPointAroundLine(polyLats[startVertex], 
>> polyLons[startVertex],
>>                                   polyLats[endVertex],   
>> polyLons[endVertex]);
>>      }
>> @@ -270,11 +273,11 @@ public class GeoTestUtil {
>>
>>      // if there are any holes, target them aggressively
>>      Polygon holes[] = polygon.getHoles();
>> -    if (holes.length > 0 && random().nextInt(3) == 0) {
>> -      return nextBoxNear(holes[random().nextInt(holes.length)]);
>> +    if (holes.length > 0 && randomInt(3) == 0) {
>> +      return nextBoxNear(holes[randomInt(holes.length)]);
>>      }
>>
>> -    int surpriseMe = random().nextInt(97);
>> +    int surpriseMe = randomInt(97);
>>      if (surpriseMe == 0) {
>>        // formed from two interesting points
>>        point1 = nextPointNear(polygon);
>> @@ -286,7 +289,7 @@ public class GeoTestUtil {
>>        // now figure out a good delta: we use a rough heuristic, up to the 
>> length of an edge
>>        double polyLats[] = polygon.getPolyLats();
>>        double polyLons[] = polygon.getPolyLons();
>> -      int vertex = random().nextInt(polyLats.length - 1);
>> +      int vertex = randomInt(polyLats.length - 1);
>>        double deltaX = polyLons[vertex+1] - polyLons[vertex];
>>        double deltaY = polyLats[vertex+1] - polyLats[vertex];
>>        double edgeLength = Math.sqrt(deltaX * deltaX + deltaY * deltaY);
>> @@ -386,14 +389,14 @@ public class GeoTestUtil {
>>
>>    /** returns next pseudorandom polygon */
>>    public static Polygon nextPolygon() {
>> -    if (random().nextBoolean()) {
>> +    if (randomBoolean()) {
>>        return surpriseMePolygon();
>> -    } else if (random().nextInt(10) == 1) {
>> +    } else if (randomInt(10) == 1) {
>>        // this poly is slow to create ... only do it 10% of the time:
>>        while (true) {
>> -        int gons = TestUtil.nextInt(random(), 4, 500);
>> +        int gons = randomIntBetween(4, 500);
>>          // So the poly can cover at most 50% of the earth's surface:
>> -        double radiusMeters = random().nextDouble() * 
>> GeoUtils.EARTH_MEAN_RADIUS_METERS * Math.PI / 2.0 + 1.0;
>> +        double radiusMeters = randomDouble() * 
>> GeoUtils.EARTH_MEAN_RADIUS_METERS * Math.PI / 2.0 + 1.0;
>>          try {
>>            return createRegularPolygon(nextLatitude(), nextLongitude(), 
>> radiusMeters, gons);
>>          } catch (IllegalArgumentException iae) {
>> @@ -403,7 +406,7 @@ public class GeoTestUtil {
>>      }
>>
>>      Rectangle box = nextBoxInternal(false);
>> -    if (random().nextBoolean()) {
>> +    if (randomBoolean()) {
>>        // box
>>        return boxPolygon(box);
>>      } else {
>> @@ -480,19 +483,19 @@ public class GeoTestUtil {
>>        //System.out.println("\nPOLY ITER");
>>        double centerLat = nextLatitude();
>>        double centerLon = nextLongitude();
>> -      double radius = 0.1 + 20 * random().nextDouble();
>> -      double radiusDelta = random().nextDouble();
>> +      double radius = 0.1 + 20 * randomDouble();
>> +      double radiusDelta = randomDouble();
>>
>>        ArrayList<Double> lats = new ArrayList<>();
>>        ArrayList<Double> lons = new ArrayList<>();
>>        double angle = 0.0;
>>        while (true) {
>> -        angle += random().nextDouble()*40.0;
>> +        angle += randomDouble() * 40.0;
>>          //System.out.println("  angle " + angle);
>>          if (angle > 360) {
>>            break;
>>          }
>> -        double len = radius * (1.0 - radiusDelta + radiusDelta * 
>> random().nextDouble());
>> +        double len = radius * (1.0 - radiusDelta + radiusDelta * 
>> randomDouble());
>>          //System.out.println("    len=" + len);
>>          double lat = centerLat + len * 
>> Math.cos(SloppyMath.toRadians(angle));
>>          double lon = centerLon + len * 
>> Math.sin(SloppyMath.toRadians(angle));
>> @@ -521,11 +524,6 @@ public class GeoTestUtil {
>>      }
>>    }
>>
>> -  /** Keep it simple, we don't need to take arbitrary Random for geo tests 
>> */
>> -  private static Random random() {
>> -   return RandomizedContext.current().getRandom();
>> -  }
>> -
>>    /**
>>     * Returns svg of polygon for debugging.
>>     * <p>
>>

---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to