7189926: Reduce test size for default run. Add additional run enabling alternative hashing

Reviewed-by: alanb
This commit is contained in:
Mike Duigou 2012-09-11 07:42:02 -07:00
parent ebe7692e1d
commit bb1c4324e9

View File

@ -24,6 +24,8 @@
/* /*
* @test * @test
* @bug 7126277 * @bug 7126277
* @run main Collisions -shortrun
* @run main Collisions -Djdk.map.althashing.threshold=0 -shortrun
* @summary Ensure Maps behave well with lots of hashCode() collisions. * @summary Ensure Maps behave well with lots of hashCode() collisions.
* @author Mike Duigou * @author Mike Duigou
*/ */
@ -33,6 +35,11 @@ import java.util.concurrent.ConcurrentSkipListMap;
public class Collisions { public class Collisions {
/**
* Number of elements per map.
*/
private static final int TEST_SIZE = 5000;
final static class HashableInteger implements Comparable<HashableInteger> { final static class HashableInteger implements Comparable<HashableInteger> {
final int value; final int value;
@ -64,20 +71,19 @@ public class Collisions {
return value - o.value; return value - o.value;
} }
@Override
public String toString() { public String toString() {
return Integer.toString(value); return Integer.toString(value);
} }
} }
private static final int ITEMS = 5000;
private static final Object KEYS[][];
static { private static Object[][] makeTestData(int size) {
HashableInteger UNIQUE_OBJECTS[] = new HashableInteger[ITEMS]; HashableInteger UNIQUE_OBJECTS[] = new HashableInteger[size];
HashableInteger COLLIDING_OBJECTS[] = new HashableInteger[ITEMS]; HashableInteger COLLIDING_OBJECTS[] = new HashableInteger[size];
String UNIQUE_STRINGS[] = new String[ITEMS]; String UNIQUE_STRINGS[] = new String[size];
String COLLIDING_STRINGS[] = new String[ITEMS]; String COLLIDING_STRINGS[] = new String[size];
for (int i = 0; i < ITEMS; i++) { for (int i = 0; i < size; i++) {
UNIQUE_OBJECTS[i] = new HashableInteger(i, Integer.MAX_VALUE); UNIQUE_OBJECTS[i] = new HashableInteger(i, Integer.MAX_VALUE);
COLLIDING_OBJECTS[i] = new HashableInteger(i, 10); COLLIDING_OBJECTS[i] = new HashableInteger(i, 10);
UNIQUE_STRINGS[i] = unhash(i); UNIQUE_STRINGS[i] = unhash(i);
@ -86,7 +92,7 @@ public class Collisions {
: "\u0000\u0000\u0000\u0000\u0000" + COLLIDING_STRINGS[i - 1]; : "\u0000\u0000\u0000\u0000\u0000" + COLLIDING_STRINGS[i - 1];
} }
KEYS = new Object[][] { return new Object[][] {
new Object[]{"Unique Objects", UNIQUE_OBJECTS}, new Object[]{"Unique Objects", UNIQUE_OBJECTS},
new Object[]{"Colliding Objects", COLLIDING_OBJECTS}, new Object[]{"Colliding Objects", COLLIDING_OBJECTS},
new Object[]{"Unique Strings", UNIQUE_STRINGS}, new Object[]{"Unique Strings", UNIQUE_STRINGS},
@ -132,23 +138,29 @@ public class Collisions {
} }
private static void realMain(String[] args) throws Throwable { private static void realMain(String[] args) throws Throwable {
for (Object[] keys_desc : KEYS) { boolean shortRun = args.length > 0 && args[0].equals("-shortrun");
Map<Object, Object>[] MAPS = (Map<Object, Object>[]) new Map[]{
new Hashtable<>(), Object[][] mapKeys = makeTestData(shortRun ? (TEST_SIZE / 2) : TEST_SIZE);
// loop through data sets
for (Object[] keys_desc : mapKeys) {
Map<Object, Object>[] maps = (Map<Object, Object>[]) new Map[]{
new HashMap<>(), new HashMap<>(),
new Hashtable<>(),
new IdentityHashMap<>(), new IdentityHashMap<>(),
new LinkedHashMap<>(), new LinkedHashMap<>(),
new ConcurrentHashMap<>(),
new WeakHashMap<>(),
new TreeMap<>(), new TreeMap<>(),
new WeakHashMap<>(),
new ConcurrentHashMap<>(),
new ConcurrentSkipListMap<>() new ConcurrentSkipListMap<>()
}; };
for (Map<Object, Object> map : MAPS) { // for each map type.
for (Map<Object, Object> map : maps) {
String desc = (String) keys_desc[0]; String desc = (String) keys_desc[0];
Object[] keys = (Object[]) keys_desc[1]; Object[] keys = (Object[]) keys_desc[1];
try { try {
testMap(map, desc, keys); testMap(map, desc, keys);
} catch(Exception all) { } catch(Exception all) {
unexpected("Failed for " + map.getClass().getName() + " with " + desc, all); unexpected("Failed for " + map.getClass().getName() + " with " + desc, all);
} }
@ -397,7 +409,7 @@ public class Collisions {
} }
public static void main(String[] args) throws Throwable { public static void main(String[] args) throws Throwable {
Thread.currentThread().setName("Collisions"); Thread.currentThread().setName(Collisions.class.getName());
// Thread.currentThread().setPriority(Thread.MAX_PRIORITY); // Thread.currentThread().setPriority(Thread.MAX_PRIORITY);
try { try {
realMain(args); realMain(args);