Try to eliminate random failures which did happen on GH with a 100 limit

This commit is contained in:
Gary Gregory 2023-07-02 16:01:51 -04:00
parent 8168aa2bc1
commit 6000dd8a3c
1 changed files with 16 additions and 13 deletions

View File

@ -37,10 +37,12 @@ import java.util.Random;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
/** /**
* Unit tests {@link org.apache.commons.lang3.RandomStringUtils}. * Tests {@link org.apache.commons.lang3.RandomStringUtils}.
*/ */
public class RandomStringUtilsTest extends AbstractLangTest { public class RandomStringUtilsTest extends AbstractLangTest {
private static final int LOOP_COUNT = 1_000;
@Test @Test
public void testConstructor() { public void testConstructor() {
assertNotNull(new RandomStringUtils()); assertNotNull(new RandomStringUtils());
@ -195,7 +197,7 @@ public class RandomStringUtilsTest extends AbstractLangTest {
public void testRandomAlphaNumeric() { public void testRandomAlphaNumeric() {
final char[] testChars = {'a', 'z', 'A', 'Z', '0', '9'}; final char[] testChars = {'a', 'z', 'A', 'Z', '0', '9'};
final boolean[] found = {false, false, false, false, false, false}; final boolean[] found = {false, false, false, false, false, false};
for (int i = 0; i < 100; i++) { for (int i = 0; i < LOOP_COUNT; i++) {
final String randString = RandomStringUtils.randomAlphanumeric(10); final String randString = RandomStringUtils.randomAlphanumeric(10);
for (int j = 0; j < testChars.length; j++) { for (int j = 0; j < testChars.length; j++) {
if (randString.indexOf(testChars[j]) > 0) { if (randString.indexOf(testChars[j]) > 0) {
@ -218,7 +220,7 @@ public class RandomStringUtilsTest extends AbstractLangTest {
public void testRandomNumeric() { public void testRandomNumeric() {
final char[] testChars = {'0', '9'}; final char[] testChars = {'0', '9'};
final boolean[] found = {false, false}; final boolean[] found = {false, false};
for (int i = 0; i < 100; i++) { for (int i = 0; i < LOOP_COUNT; i++) {
final String randString = RandomStringUtils.randomNumeric(10); final String randString = RandomStringUtils.randomNumeric(10);
for (int j = 0; j < testChars.length; j++) { for (int j = 0; j < testChars.length; j++) {
if (randString.indexOf(testChars[j]) > 0) { if (randString.indexOf(testChars[j]) > 0) {
@ -241,7 +243,7 @@ public class RandomStringUtilsTest extends AbstractLangTest {
public void testRandomAlphabetic() { public void testRandomAlphabetic() {
final char[] testChars = {'a', 'z', 'A', 'Z'}; final char[] testChars = {'a', 'z', 'A', 'Z'};
final boolean[] found = {false, false, false, false}; final boolean[] found = {false, false, false, false};
for (int i = 0; i < 100; i++) { for (int i = 0; i < LOOP_COUNT; i++) {
final String randString = RandomStringUtils.randomAlphabetic(10); final String randString = RandomStringUtils.randomAlphabetic(10);
for (int j = 0; j < testChars.length; j++) { for (int j = 0; j < testChars.length; j++) {
if (randString.indexOf(testChars[j]) > 0) { if (randString.indexOf(testChars[j]) > 0) {
@ -265,7 +267,7 @@ public class RandomStringUtilsTest extends AbstractLangTest {
final char[] testChars = {(char) 32, (char) 126}; final char[] testChars = {(char) 32, (char) 126};
final boolean[] found = {false, false}; final boolean[] found = {false, false};
// Test failures have been observed on GitHub builds with a 100 limit. // Test failures have been observed on GitHub builds with a 100 limit.
for (int i = 0; i < 1_000; i++) { for (int i = 0; i < LOOP_COUNT; i++) {
final String randString = RandomStringUtils.randomAscii(10); final String randString = RandomStringUtils.randomAscii(10);
for (int j = 0; j < testChars.length; j++) { for (int j = 0; j < testChars.length; j++) {
if (randString.indexOf(testChars[j]) > 0) { if (randString.indexOf(testChars[j]) > 0) {
@ -288,7 +290,7 @@ public class RandomStringUtilsTest extends AbstractLangTest {
int maxCreatedLength = expectedMinLengthInclusive; int maxCreatedLength = expectedMinLengthInclusive;
int minCreatedLength = expectedMaxLengthExclusive - 1; int minCreatedLength = expectedMaxLengthExclusive - 1;
for (int i = 0; i < 1000; i++) { for (int i = 0; i < LOOP_COUNT; i++) {
final String s = RandomStringUtils.randomAscii(expectedMinLengthInclusive, expectedMaxLengthExclusive); final String s = RandomStringUtils.randomAscii(expectedMinLengthInclusive, expectedMaxLengthExclusive);
assertThat("within range", s.length(), allOf(greaterThanOrEqualTo(expectedMinLengthInclusive), lessThanOrEqualTo(expectedMaxLengthExclusive - 1))); assertThat("within range", s.length(), allOf(greaterThanOrEqualTo(expectedMinLengthInclusive), lessThanOrEqualTo(expectedMaxLengthExclusive - 1)));
assertTrue(s.matches(pattern), s); assertTrue(s.matches(pattern), s);
@ -313,7 +315,7 @@ public class RandomStringUtilsTest extends AbstractLangTest {
int maxCreatedLength = expectedMinLengthInclusive; int maxCreatedLength = expectedMinLengthInclusive;
int minCreatedLength = expectedMaxLengthExclusive - 1; int minCreatedLength = expectedMaxLengthExclusive - 1;
for (int i = 0; i < 1000; i++) { for (int i = 0; i < LOOP_COUNT; i++) {
final String s = RandomStringUtils.randomAlphabetic(expectedMinLengthInclusive, expectedMaxLengthExclusive); final String s = RandomStringUtils.randomAlphabetic(expectedMinLengthInclusive, expectedMaxLengthExclusive);
assertThat("within range", s.length(), allOf(greaterThanOrEqualTo(expectedMinLengthInclusive), lessThanOrEqualTo(expectedMaxLengthExclusive - 1))); assertThat("within range", s.length(), allOf(greaterThanOrEqualTo(expectedMinLengthInclusive), lessThanOrEqualTo(expectedMaxLengthExclusive - 1)));
assertTrue(s.matches(pattern), s); assertTrue(s.matches(pattern), s);
@ -338,7 +340,7 @@ public class RandomStringUtilsTest extends AbstractLangTest {
int maxCreatedLength = expectedMinLengthInclusive; int maxCreatedLength = expectedMinLengthInclusive;
int minCreatedLength = expectedMaxLengthExclusive - 1; int minCreatedLength = expectedMaxLengthExclusive - 1;
for (int i = 0; i < 1000; i++) { for (int i = 0; i < LOOP_COUNT; i++) {
final String s = RandomStringUtils.randomAlphanumeric(expectedMinLengthInclusive, expectedMaxLengthExclusive); final String s = RandomStringUtils.randomAlphanumeric(expectedMinLengthInclusive, expectedMaxLengthExclusive);
assertThat("within range", s.length(), allOf(greaterThanOrEqualTo(expectedMinLengthInclusive), lessThanOrEqualTo(expectedMaxLengthExclusive - 1))); assertThat("within range", s.length(), allOf(greaterThanOrEqualTo(expectedMinLengthInclusive), lessThanOrEqualTo(expectedMaxLengthExclusive - 1)));
assertTrue(s.matches(pattern), s); assertTrue(s.matches(pattern), s);
@ -363,7 +365,7 @@ public class RandomStringUtilsTest extends AbstractLangTest {
int maxCreatedLength = expectedMinLengthInclusive; int maxCreatedLength = expectedMinLengthInclusive;
int minCreatedLength = expectedMaxLengthExclusive - 1; int minCreatedLength = expectedMaxLengthExclusive - 1;
for (int i = 0; i < 1000; i++) { for (int i = 0; i < LOOP_COUNT; i++) {
final String s = RandomStringUtils.randomGraph(expectedMinLengthInclusive, expectedMaxLengthExclusive); final String s = RandomStringUtils.randomGraph(expectedMinLengthInclusive, expectedMaxLengthExclusive);
assertThat("within range", s.length(), allOf(greaterThanOrEqualTo(expectedMinLengthInclusive), lessThanOrEqualTo(expectedMaxLengthExclusive - 1))); assertThat("within range", s.length(), allOf(greaterThanOrEqualTo(expectedMinLengthInclusive), lessThanOrEqualTo(expectedMaxLengthExclusive - 1)));
assertTrue(s.matches(pattern), s); assertTrue(s.matches(pattern), s);
@ -388,7 +390,7 @@ public class RandomStringUtilsTest extends AbstractLangTest {
int maxCreatedLength = expectedMinLengthInclusive; int maxCreatedLength = expectedMinLengthInclusive;
int minCreatedLength = expectedMaxLengthExclusive - 1; int minCreatedLength = expectedMaxLengthExclusive - 1;
for (int i = 0; i < 1000; i++) { for (int i = 0; i < LOOP_COUNT; i++) {
final String s = RandomStringUtils.randomNumeric(expectedMinLengthInclusive, expectedMaxLengthExclusive); final String s = RandomStringUtils.randomNumeric(expectedMinLengthInclusive, expectedMaxLengthExclusive);
assertThat("within range", s.length(), allOf(greaterThanOrEqualTo(expectedMinLengthInclusive), lessThanOrEqualTo(expectedMaxLengthExclusive - 1))); assertThat("within range", s.length(), allOf(greaterThanOrEqualTo(expectedMinLengthInclusive), lessThanOrEqualTo(expectedMaxLengthExclusive - 1)));
assertTrue(s.matches(pattern), s); assertTrue(s.matches(pattern), s);
@ -413,7 +415,7 @@ public class RandomStringUtilsTest extends AbstractLangTest {
int maxCreatedLength = expectedMinLengthInclusive; int maxCreatedLength = expectedMinLengthInclusive;
int minCreatedLength = expectedMaxLengthExclusive - 1; int minCreatedLength = expectedMaxLengthExclusive - 1;
for (int i = 0; i < 1000; i++) { for (int i = 0; i < LOOP_COUNT; i++) {
final String s = RandomStringUtils.randomPrint(expectedMinLengthInclusive, expectedMaxLengthExclusive); final String s = RandomStringUtils.randomPrint(expectedMinLengthInclusive, expectedMaxLengthExclusive);
assertThat("within range", s.length(), allOf(greaterThanOrEqualTo(expectedMinLengthInclusive), lessThanOrEqualTo(expectedMaxLengthExclusive - 1))); assertThat("within range", s.length(), allOf(greaterThanOrEqualTo(expectedMinLengthInclusive), lessThanOrEqualTo(expectedMaxLengthExclusive - 1)));
assertTrue(s.matches(pattern), s); assertTrue(s.matches(pattern), s);
@ -433,7 +435,7 @@ public class RandomStringUtilsTest extends AbstractLangTest {
/** /**
* Test homogeneity of random strings generated -- * Test homogeneity of random strings generated --
* i.e., test that characters show up with expected frequencies * i.e., test that characters show up with expected frequencies
* in generated strings. Will fail randomly about 1 in 1000 times. * in generated strings. Will fail randomly about 1 in LOOP_COUNT times.
* Repeated failures indicate a problem. * Repeated failures indicate a problem.
*/ */
@Test @Test
@ -443,7 +445,8 @@ public class RandomStringUtilsTest extends AbstractLangTest {
String gen = ""; String gen = "";
final int[] counts = {0, 0, 0}; final int[] counts = {0, 0, 0};
final int[] expected = {200, 200, 200}; final int[] expected = {200, 200, 200};
for (int i = 0; i< 100; i++) { // More likely to fail for 1000?
for (int i = 0; i < 100; i++) {
gen = RandomStringUtils.random(6, chars); gen = RandomStringUtils.random(6, chars);
for (int j = 0; j < 6; j++) { for (int j = 0; j < 6; j++) {
switch (gen.charAt(j)) { switch (gen.charAt(j)) {