Add sugar to RandomIUtils

This commit is contained in:
Vincent Potucek 2015-10-12 09:47:40 +02:00
parent 00fafe772c
commit 31466db6ec
2 changed files with 81 additions and 7 deletions

View File

@ -90,6 +90,15 @@ public class RandomUtils {
return startInclusive + RANDOM.nextInt(endExclusive - startInclusive); return startInclusive + RANDOM.nextInt(endExclusive - startInclusive);
} }
/**
* <p> Returns a random int within 0 - Integer.MAX_VALUE </p>
*
* @see #nextInt()
*/
public static int nextInt() {
return nextInt(0, Integer.MAX_VALUE);
}
/** /**
* <p> * <p>
@ -115,8 +124,16 @@ public class RandomUtils {
} }
return (long) nextDouble(startInclusive, endExclusive); return (long) nextDouble(startInclusive, endExclusive);
} }
/**
* <p> Returns a random long within 0 - Long.MAX_VALUE </p>
*
* @see #nextLong()
*/
public static long nextLong() {
return nextLong(0, Long.MAX_VALUE);
}
/** /**
* <p> * <p>
@ -136,14 +153,23 @@ public class RandomUtils {
Validate.isTrue(endInclusive >= startInclusive, Validate.isTrue(endInclusive >= startInclusive,
"Start value must be smaller or equal to end value."); "Start value must be smaller or equal to end value.");
Validate.isTrue(startInclusive >= 0, "Both range values must be non-negative."); Validate.isTrue(startInclusive >= 0, "Both range values must be non-negative.");
if (startInclusive == endInclusive) { if (startInclusive == endInclusive) {
return startInclusive; return startInclusive;
} }
return startInclusive + ((endInclusive - startInclusive) * RANDOM.nextDouble()); return startInclusive + ((endInclusive - startInclusive) * RANDOM.nextDouble());
} }
/**
* <p> Returns a random double within 0 - Double.MAX_VALUE </p>
*
* @see #nextDouble()
*/
public static double nextDouble() {
return nextDouble(0, Double.MAX_VALUE);
}
/** /**
* <p> * <p>
* Returns a random float within the specified range. * Returns a random float within the specified range.
@ -168,5 +194,14 @@ public class RandomUtils {
} }
return startInclusive + ((endInclusive - startInclusive) * RANDOM.nextFloat()); return startInclusive + ((endInclusive - startInclusive) * RANDOM.nextFloat());
} }
/**
* <p> Returns a random float within 0 - Float.MAX_VALUE </p>
*
* @see #nextFloat()
*/
public static float nextFloat() {
return nextFloat(0, Float.MAX_VALUE);
}
} }

View File

@ -111,6 +111,16 @@ public class RandomUtilsTest {
final int result = RandomUtils.nextInt(33, 42); final int result = RandomUtils.nextInt(33, 42);
assertTrue(result >= 33 && result < 42); assertTrue(result >= 33 && result < 42);
} }
/**
* Tests next double range, random result.
*/
@Test
public void testNextIntRandomResult() {
int randomResult = RandomUtils.nextInt();
assertTrue(randomResult > 0);
assertTrue(randomResult < Integer.MAX_VALUE);
}
/** /**
* Test next double range with minimal range. * Test next double range with minimal range.
@ -136,6 +146,16 @@ public class RandomUtilsTest {
final double result = RandomUtils.nextDouble(33d, 42d); final double result = RandomUtils.nextDouble(33d, 42d);
assertTrue(result >= 33d && result <= 42d); assertTrue(result >= 33d && result <= 42d);
} }
/**
* Tests next double range, random result.
*/
@Test
public void testNextDoubleRandomResult() {
double randomResult = RandomUtils.nextDouble();
assertTrue(randomResult > 0);
assertTrue(randomResult < Double.MAX_VALUE);
}
/** /**
* Tests next float range. * Tests next float range.
@ -144,7 +164,17 @@ public class RandomUtilsTest {
public void testNextFloat() { public void testNextFloat() {
final double result = RandomUtils.nextFloat(33f, 42f); final double result = RandomUtils.nextFloat(33f, 42f);
assertTrue(result >= 33f && result <= 42f); assertTrue(result >= 33f && result <= 42f);
} }
/**
* Tests next float range, random result.
*/
@Test
public void testNextFloatRandomResult() {
float randomResult = RandomUtils.nextFloat();
assertTrue(randomResult > 0);
assertTrue(randomResult < Float.MAX_VALUE);
}
/** /**
* Test next long range with minimal range. * Test next long range with minimal range.
@ -162,7 +192,16 @@ public class RandomUtilsTest {
final long result = RandomUtils.nextLong(33L, 42L); final long result = RandomUtils.nextLong(33L, 42L);
assertTrue(result >= 33L && result < 42L); assertTrue(result >= 33L && result < 42L);
} }
/**
* Tests next long range, random result.
*/
@Test
public void testNextLongRandomResult() {
long randomResult = RandomUtils.nextLong();
assertTrue(randomResult > 0);
assertTrue(randomResult < Long.MAX_VALUE);
}
/** /**
* Tests extreme range. * Tests extreme range.