7189926: Reduce test size for default run. Add additional run enabling alternative hashing
Reviewed-by: alanb
This commit is contained in:
parent
ebe7692e1d
commit
bb1c4324e9
@ -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);
|
||||||
|
Loading…
Reference in New Issue
Block a user