Improve reference map testing
git-svn-id: https://svn.apache.org/repos/asf/jakarta/commons/proper/collections/trunk@131687 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
51c209801f
commit
6f57c5a1f7
|
@ -16,6 +16,7 @@
|
||||||
package org.apache.commons.collections;
|
package org.apache.commons.collections;
|
||||||
|
|
||||||
import java.lang.ref.WeakReference;
|
import java.lang.ref.WeakReference;
|
||||||
|
import java.util.Iterator;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import junit.framework.Test;
|
import junit.framework.Test;
|
||||||
|
@ -25,7 +26,7 @@ import org.apache.commons.collections.map.AbstractTestMap;
|
||||||
/**
|
/**
|
||||||
* Tests for ReferenceMap.
|
* Tests for ReferenceMap.
|
||||||
*
|
*
|
||||||
* @version $Revision: 1.17 $ $Date: 2004/02/18 01:20:35 $
|
* @version $Revision: 1.18 $ $Date: 2004/04/30 22:53:16 $
|
||||||
*
|
*
|
||||||
* @author Paul Jack
|
* @author Paul Jack
|
||||||
*/
|
*/
|
||||||
|
@ -57,13 +58,35 @@ public class TestReferenceMap extends AbstractTestMap {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getCompatibilityVersion() {
|
||||||
|
return "2.1";
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
//-----------------------------------------------------------------------
|
||||||
// Unfortunately, these tests all rely on System.gc(), which is
|
public void testNullHandling() {
|
||||||
// not reliable across platforms. Not sure how to code the tests
|
resetFull();
|
||||||
// without using System.gc() though...
|
assertEquals(null, map.get(null));
|
||||||
// They all passed on my platform though. :)
|
assertEquals(false, map.containsKey(null));
|
||||||
|
assertEquals(false, map.containsValue(null));
|
||||||
|
assertEquals(null, map.remove(null));
|
||||||
|
assertEquals(false, map.entrySet().contains(null));
|
||||||
|
assertEquals(false, map.keySet().contains(null));
|
||||||
|
assertEquals(false, map.values().contains(null));
|
||||||
|
try {
|
||||||
|
map.put(null, null);
|
||||||
|
fail();
|
||||||
|
} catch (NullPointerException ex) {}
|
||||||
|
try {
|
||||||
|
map.put(new Object(), null);
|
||||||
|
fail();
|
||||||
|
} catch (NullPointerException ex) {}
|
||||||
|
try {
|
||||||
|
map.put(null, new Object());
|
||||||
|
fail();
|
||||||
|
} catch (NullPointerException ex) {}
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------
|
||||||
public void testPurge() {
|
public void testPurge() {
|
||||||
ReferenceMap map = new ReferenceMap(ReferenceMap.WEAK, ReferenceMap.WEAK);
|
ReferenceMap map = new ReferenceMap(ReferenceMap.WEAK, ReferenceMap.WEAK);
|
||||||
Object[] hard = new Object[10];
|
Object[] hard = new Object[10];
|
||||||
|
@ -71,13 +94,13 @@ public class TestReferenceMap extends AbstractTestMap {
|
||||||
hard[i] = new Object();
|
hard[i] = new Object();
|
||||||
map.put(hard[i], new Object());
|
map.put(hard[i], new Object());
|
||||||
}
|
}
|
||||||
System.gc();
|
gc();
|
||||||
assertTrue("map should be empty after purge of weak values", map.isEmpty());
|
assertTrue("map should be empty after purge of weak values", map.isEmpty());
|
||||||
|
|
||||||
for (int i = 0; i < hard.length; i++) {
|
for (int i = 0; i < hard.length; i++) {
|
||||||
map.put(new Object(), hard[i]);
|
map.put(new Object(), hard[i]);
|
||||||
}
|
}
|
||||||
System.gc();
|
gc();
|
||||||
assertTrue("map should be empty after purge of weak keys", map.isEmpty());
|
assertTrue("map should be empty after purge of weak keys", map.isEmpty());
|
||||||
|
|
||||||
for (int i = 0; i < hard.length; i++) {
|
for (int i = 0; i < hard.length; i++) {
|
||||||
|
@ -85,7 +108,7 @@ public class TestReferenceMap extends AbstractTestMap {
|
||||||
map.put(hard[i], new Object());
|
map.put(hard[i], new Object());
|
||||||
}
|
}
|
||||||
|
|
||||||
System.gc();
|
gc();
|
||||||
assertTrue("map should be empty after purge of weak keys and values", map.isEmpty());
|
assertTrue("map should be empty after purge of weak keys and values", map.isEmpty());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -96,7 +119,7 @@ public class TestReferenceMap extends AbstractTestMap {
|
||||||
map.put(new Integer(i), new Integer(i));
|
map.put(new Integer(i), new Integer(i));
|
||||||
}
|
}
|
||||||
|
|
||||||
System.gc();
|
gc();
|
||||||
for (int i = 0; i < 10; i++) {
|
for (int i = 0; i < 10; i++) {
|
||||||
Integer I = new Integer(i);
|
Integer I = new Integer(i);
|
||||||
assertTrue("map.containsKey should return false for GC'd element", !map.containsKey(I));
|
assertTrue("map.containsKey should return false for GC'd element", !map.containsKey(I));
|
||||||
|
@ -114,7 +137,7 @@ public class TestReferenceMap extends AbstractTestMap {
|
||||||
map.put(hard[i], hard[i]);
|
map.put(hard[i], hard[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
System.gc();
|
gc();
|
||||||
Iterator iterator = map.entrySet().iterator();
|
Iterator iterator = map.entrySet().iterator();
|
||||||
while (iterator.hasNext()) {
|
while (iterator.hasNext()) {
|
||||||
Map.Entry entry = (Map.Entry)iterator.next();
|
Map.Entry entry = (Map.Entry)iterator.next();
|
||||||
|
@ -125,24 +148,8 @@ public class TestReferenceMap extends AbstractTestMap {
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
// Uncomment to create test files in /data/test
|
|
||||||
public void testCreateTestFiles() throws Exception {
|
|
||||||
ReferenceMap m = (ReferenceMap)makeEmptyMap();
|
|
||||||
writeExternalFormToDisk(m, getCanonicalEmptyCollectionName(m));
|
|
||||||
m = (ReferenceMap)makeFullMap();
|
|
||||||
writeExternalFormToDisk(m, getCanonicalFullCollectionName(m));
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
public String getCompatibilityVersion() {
|
|
||||||
return "2.1";
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Tests whether purge values setting works */
|
/** Tests whether purge values setting works */
|
||||||
public void testPurgeValues() throws Exception {
|
public void testPurgeValues() throws Exception {
|
||||||
// many thanks to Juozas Baliuka for suggesting this method
|
// many thanks to Juozas Baliuka for suggesting this method
|
||||||
|
@ -183,4 +190,14 @@ public class TestReferenceMap extends AbstractTestMap {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static void gc() {
|
||||||
|
try {
|
||||||
|
// trigger GC
|
||||||
|
byte[][] tooLarge = new byte[1000000000][1000000000];
|
||||||
|
fail("you have too much RAM");
|
||||||
|
} catch (OutOfMemoryError ex) {
|
||||||
|
System.gc(); // ignore
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,11 +23,12 @@ import junit.framework.Test;
|
||||||
|
|
||||||
import org.apache.commons.collections.BulkTest;
|
import org.apache.commons.collections.BulkTest;
|
||||||
import org.apache.commons.collections.IterableMap;
|
import org.apache.commons.collections.IterableMap;
|
||||||
|
import org.apache.commons.collections.MapIterator;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests for ReferenceIdentityMap.
|
* Tests for ReferenceIdentityMap.
|
||||||
*
|
*
|
||||||
* @version $Revision: 1.1 $
|
* @version $Revision: 1.2 $
|
||||||
*
|
*
|
||||||
* @author Paul Jack
|
* @author Paul Jack
|
||||||
* @author Stephen Colebourne
|
* @author Stephen Colebourne
|
||||||
|
@ -71,6 +72,10 @@ public class TestReferenceIdentityMap extends AbstractTestIterableMap {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getCompatibilityVersion() {
|
||||||
|
return "3.1";
|
||||||
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
//-----------------------------------------------------------------------
|
||||||
public void testBasics() {
|
public void testBasics() {
|
||||||
IterableMap map = new ReferenceIdentityMap(ReferenceIdentityMap.HARD, ReferenceIdentityMap.HARD);
|
IterableMap map = new ReferenceIdentityMap(ReferenceIdentityMap.HARD, ReferenceIdentityMap.HARD);
|
||||||
|
@ -123,11 +128,30 @@ public class TestReferenceIdentityMap extends AbstractTestIterableMap {
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
//-----------------------------------------------------------------------
|
||||||
// Unfortunately, these tests all rely on System.gc(), which is
|
public void testNullHandling() {
|
||||||
// not reliable across platforms. Not sure how to code the tests
|
resetFull();
|
||||||
// without using System.gc() though...
|
assertEquals(null, map.get(null));
|
||||||
// They all passed on my platform though. :)
|
assertEquals(false, map.containsKey(null));
|
||||||
/*
|
assertEquals(false, map.containsValue(null));
|
||||||
|
assertEquals(null, map.remove(null));
|
||||||
|
assertEquals(false, map.entrySet().contains(null));
|
||||||
|
assertEquals(false, map.keySet().contains(null));
|
||||||
|
assertEquals(false, map.values().contains(null));
|
||||||
|
try {
|
||||||
|
map.put(null, null);
|
||||||
|
fail();
|
||||||
|
} catch (NullPointerException ex) {}
|
||||||
|
try {
|
||||||
|
map.put(new Object(), null);
|
||||||
|
fail();
|
||||||
|
} catch (NullPointerException ex) {}
|
||||||
|
try {
|
||||||
|
map.put(null, new Object());
|
||||||
|
fail();
|
||||||
|
} catch (NullPointerException ex) {}
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------
|
||||||
public void testPurge() {
|
public void testPurge() {
|
||||||
ReferenceIdentityMap map = new ReferenceIdentityMap(ReferenceIdentityMap.WEAK, ReferenceIdentityMap.WEAK);
|
ReferenceIdentityMap map = new ReferenceIdentityMap(ReferenceIdentityMap.WEAK, ReferenceIdentityMap.WEAK);
|
||||||
Object[] hard = new Object[10];
|
Object[] hard = new Object[10];
|
||||||
|
@ -135,13 +159,13 @@ public class TestReferenceIdentityMap extends AbstractTestIterableMap {
|
||||||
hard[i] = new Object();
|
hard[i] = new Object();
|
||||||
map.put(hard[i], new Object());
|
map.put(hard[i], new Object());
|
||||||
}
|
}
|
||||||
System.gc();
|
gc();
|
||||||
assertTrue("map should be empty after purge of weak values", map.isEmpty());
|
assertTrue("map should be empty after purge of weak values", map.isEmpty());
|
||||||
|
|
||||||
for (int i = 0; i < hard.length; i++) {
|
for (int i = 0; i < hard.length; i++) {
|
||||||
map.put(new Object(), hard[i]);
|
map.put(new Object(), hard[i]);
|
||||||
}
|
}
|
||||||
System.gc();
|
gc();
|
||||||
assertTrue("map should be empty after purge of weak keys", map.isEmpty());
|
assertTrue("map should be empty after purge of weak keys", map.isEmpty());
|
||||||
|
|
||||||
for (int i = 0; i < hard.length; i++) {
|
for (int i = 0; i < hard.length; i++) {
|
||||||
|
@ -149,7 +173,7 @@ public class TestReferenceIdentityMap extends AbstractTestIterableMap {
|
||||||
map.put(hard[i], new Object());
|
map.put(hard[i], new Object());
|
||||||
}
|
}
|
||||||
|
|
||||||
System.gc();
|
gc();
|
||||||
assertTrue("map should be empty after purge of weak keys and values", map.isEmpty());
|
assertTrue("map should be empty after purge of weak keys and values", map.isEmpty());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -160,7 +184,7 @@ public class TestReferenceIdentityMap extends AbstractTestIterableMap {
|
||||||
map.put(new Integer(i), new Integer(i));
|
map.put(new Integer(i), new Integer(i));
|
||||||
}
|
}
|
||||||
|
|
||||||
System.gc();
|
gc();
|
||||||
for (int i = 0; i < 10; i++) {
|
for (int i = 0; i < 10; i++) {
|
||||||
Integer I = new Integer(i);
|
Integer I = new Integer(i);
|
||||||
assertTrue("map.containsKey should return false for GC'd element", !map.containsKey(I));
|
assertTrue("map.containsKey should return false for GC'd element", !map.containsKey(I));
|
||||||
|
@ -178,7 +202,7 @@ public class TestReferenceIdentityMap extends AbstractTestIterableMap {
|
||||||
map.put(hard[i], hard[i]);
|
map.put(hard[i], hard[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
System.gc();
|
gc();
|
||||||
Iterator iterator = map.entrySet().iterator();
|
Iterator iterator = map.entrySet().iterator();
|
||||||
while (iterator.hasNext()) {
|
while (iterator.hasNext()) {
|
||||||
Map.Entry entry = (Map.Entry)iterator.next();
|
Map.Entry entry = (Map.Entry)iterator.next();
|
||||||
|
@ -199,7 +223,7 @@ public class TestReferenceIdentityMap extends AbstractTestIterableMap {
|
||||||
map.put(hard[i], hard[i]);
|
map.put(hard[i], hard[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
System.gc();
|
gc();
|
||||||
MapIterator iterator = map.mapIterator();
|
MapIterator iterator = map.mapIterator();
|
||||||
while (iterator.hasNext()) {
|
while (iterator.hasNext()) {
|
||||||
Object key1 = iterator.next();
|
Object key1 = iterator.next();
|
||||||
|
@ -224,7 +248,7 @@ public class TestReferenceIdentityMap extends AbstractTestIterableMap {
|
||||||
MapIterator iterator = map.mapIterator();
|
MapIterator iterator = map.mapIterator();
|
||||||
while (iterator.hasNext()) {
|
while (iterator.hasNext()) {
|
||||||
Object key1 = iterator.next();
|
Object key1 = iterator.next();
|
||||||
System.gc();
|
gc();
|
||||||
Integer key = (Integer) iterator.getKey();
|
Integer key = (Integer) iterator.getKey();
|
||||||
Integer value = (Integer) iterator.getValue();
|
Integer value = (Integer) iterator.getValue();
|
||||||
assertTrue("iterator keys should match", key == key1);
|
assertTrue("iterator keys should match", key == key1);
|
||||||
|
@ -233,21 +257,6 @@ public class TestReferenceIdentityMap extends AbstractTestIterableMap {
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
/*
|
|
||||||
// Uncomment to create test files in /data/test
|
|
||||||
public void testCreateTestFiles() throws Exception {
|
|
||||||
ReferenceIdentityMap m = (ReferenceIdentityMap) makeEmptyMap();
|
|
||||||
writeExternalFormToDisk(m, getCanonicalEmptyCollectionName(m));
|
|
||||||
m = (ReferenceIdentityMap) makeFullMap();
|
|
||||||
writeExternalFormToDisk(m, getCanonicalFullCollectionName(m));
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
public String getCompatibilityVersion() {
|
|
||||||
return "3.1";
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Tests whether purge values setting works */
|
/** Tests whether purge values setting works */
|
||||||
public void testPurgeValues() throws Exception {
|
public void testPurgeValues() throws Exception {
|
||||||
|
@ -289,4 +298,15 @@ public class TestReferenceIdentityMap extends AbstractTestIterableMap {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static void gc() {
|
||||||
|
try {
|
||||||
|
// trigger GC
|
||||||
|
byte[][] tooLarge = new byte[1000000000][1000000000];
|
||||||
|
fail("you have too much RAM");
|
||||||
|
} catch (OutOfMemoryError ex) {
|
||||||
|
System.gc(); // ignore
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,16 +16,18 @@
|
||||||
package org.apache.commons.collections.map;
|
package org.apache.commons.collections.map;
|
||||||
|
|
||||||
import java.lang.ref.WeakReference;
|
import java.lang.ref.WeakReference;
|
||||||
|
import java.util.Iterator;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import junit.framework.Test;
|
import junit.framework.Test;
|
||||||
|
|
||||||
import org.apache.commons.collections.BulkTest;
|
import org.apache.commons.collections.BulkTest;
|
||||||
|
import org.apache.commons.collections.MapIterator;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests for ReferenceMap.
|
* Tests for ReferenceMap.
|
||||||
*
|
*
|
||||||
* @version $Revision: 1.6 $ $Date: 2004/04/27 21:35:23 $
|
* @version $Revision: 1.7 $ $Date: 2004/04/30 22:53:16 $
|
||||||
*
|
*
|
||||||
* @author Paul Jack
|
* @author Paul Jack
|
||||||
*/
|
*/
|
||||||
|
@ -57,13 +59,35 @@ public class TestReferenceMap extends AbstractTestIterableMap {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getCompatibilityVersion() {
|
||||||
|
return "3.1";
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
//-----------------------------------------------------------------------
|
||||||
// Unfortunately, these tests all rely on System.gc(), which is
|
public void testNullHandling() {
|
||||||
// not reliable across platforms. Not sure how to code the tests
|
resetFull();
|
||||||
// without using System.gc() though...
|
assertEquals(null, map.get(null));
|
||||||
// They all passed on my platform though. :)
|
assertEquals(false, map.containsKey(null));
|
||||||
|
assertEquals(false, map.containsValue(null));
|
||||||
|
assertEquals(null, map.remove(null));
|
||||||
|
assertEquals(false, map.entrySet().contains(null));
|
||||||
|
assertEquals(false, map.keySet().contains(null));
|
||||||
|
assertEquals(false, map.values().contains(null));
|
||||||
|
try {
|
||||||
|
map.put(null, null);
|
||||||
|
fail();
|
||||||
|
} catch (NullPointerException ex) {}
|
||||||
|
try {
|
||||||
|
map.put(new Object(), null);
|
||||||
|
fail();
|
||||||
|
} catch (NullPointerException ex) {}
|
||||||
|
try {
|
||||||
|
map.put(null, new Object());
|
||||||
|
fail();
|
||||||
|
} catch (NullPointerException ex) {}
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------
|
||||||
public void testPurge() {
|
public void testPurge() {
|
||||||
ReferenceMap map = new ReferenceMap(ReferenceMap.WEAK, ReferenceMap.WEAK);
|
ReferenceMap map = new ReferenceMap(ReferenceMap.WEAK, ReferenceMap.WEAK);
|
||||||
Object[] hard = new Object[10];
|
Object[] hard = new Object[10];
|
||||||
|
@ -71,13 +95,13 @@ public class TestReferenceMap extends AbstractTestIterableMap {
|
||||||
hard[i] = new Object();
|
hard[i] = new Object();
|
||||||
map.put(hard[i], new Object());
|
map.put(hard[i], new Object());
|
||||||
}
|
}
|
||||||
System.gc();
|
gc();
|
||||||
assertTrue("map should be empty after purge of weak values", map.isEmpty());
|
assertTrue("map should be empty after purge of weak values", map.isEmpty());
|
||||||
|
|
||||||
for (int i = 0; i < hard.length; i++) {
|
for (int i = 0; i < hard.length; i++) {
|
||||||
map.put(new Object(), hard[i]);
|
map.put(new Object(), hard[i]);
|
||||||
}
|
}
|
||||||
System.gc();
|
gc();
|
||||||
assertTrue("map should be empty after purge of weak keys", map.isEmpty());
|
assertTrue("map should be empty after purge of weak keys", map.isEmpty());
|
||||||
|
|
||||||
for (int i = 0; i < hard.length; i++) {
|
for (int i = 0; i < hard.length; i++) {
|
||||||
|
@ -85,7 +109,7 @@ public class TestReferenceMap extends AbstractTestIterableMap {
|
||||||
map.put(hard[i], new Object());
|
map.put(hard[i], new Object());
|
||||||
}
|
}
|
||||||
|
|
||||||
System.gc();
|
gc();
|
||||||
assertTrue("map should be empty after purge of weak keys and values", map.isEmpty());
|
assertTrue("map should be empty after purge of weak keys and values", map.isEmpty());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -96,7 +120,7 @@ public class TestReferenceMap extends AbstractTestIterableMap {
|
||||||
map.put(new Integer(i), new Integer(i));
|
map.put(new Integer(i), new Integer(i));
|
||||||
}
|
}
|
||||||
|
|
||||||
System.gc();
|
gc();
|
||||||
for (int i = 0; i < 10; i++) {
|
for (int i = 0; i < 10; i++) {
|
||||||
Integer I = new Integer(i);
|
Integer I = new Integer(i);
|
||||||
assertTrue("map.containsKey should return false for GC'd element", !map.containsKey(I));
|
assertTrue("map.containsKey should return false for GC'd element", !map.containsKey(I));
|
||||||
|
@ -114,7 +138,7 @@ public class TestReferenceMap extends AbstractTestIterableMap {
|
||||||
map.put(hard[i], hard[i]);
|
map.put(hard[i], hard[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
System.gc();
|
gc();
|
||||||
Iterator iterator = map.entrySet().iterator();
|
Iterator iterator = map.entrySet().iterator();
|
||||||
while (iterator.hasNext()) {
|
while (iterator.hasNext()) {
|
||||||
Map.Entry entry = (Map.Entry)iterator.next();
|
Map.Entry entry = (Map.Entry)iterator.next();
|
||||||
|
@ -135,7 +159,7 @@ public class TestReferenceMap extends AbstractTestIterableMap {
|
||||||
map.put(hard[i], hard[i]);
|
map.put(hard[i], hard[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
System.gc();
|
gc();
|
||||||
MapIterator iterator = map.mapIterator();
|
MapIterator iterator = map.mapIterator();
|
||||||
while (iterator.hasNext()) {
|
while (iterator.hasNext()) {
|
||||||
Object key1 = iterator.next();
|
Object key1 = iterator.next();
|
||||||
|
@ -160,7 +184,7 @@ public class TestReferenceMap extends AbstractTestIterableMap {
|
||||||
MapIterator iterator = map.mapIterator();
|
MapIterator iterator = map.mapIterator();
|
||||||
while (iterator.hasNext()) {
|
while (iterator.hasNext()) {
|
||||||
Object key1 = iterator.next();
|
Object key1 = iterator.next();
|
||||||
System.gc();
|
gc();
|
||||||
Integer key = (Integer) iterator.getKey();
|
Integer key = (Integer) iterator.getKey();
|
||||||
Integer value = (Integer) iterator.getValue();
|
Integer value = (Integer) iterator.getValue();
|
||||||
assertTrue("iterator keys should match", key == key1);
|
assertTrue("iterator keys should match", key == key1);
|
||||||
|
@ -170,23 +194,6 @@ public class TestReferenceMap extends AbstractTestIterableMap {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
// Uncomment to create test files in /data/test
|
|
||||||
public void testCreateTestFiles() throws Exception {
|
|
||||||
ReferenceMap m = (ReferenceMap)makeEmptyMap();
|
|
||||||
writeExternalFormToDisk(m, getCanonicalEmptyCollectionName(m));
|
|
||||||
m = (ReferenceMap)makeFullMap();
|
|
||||||
writeExternalFormToDisk(m, getCanonicalFullCollectionName(m));
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
public String getCompatibilityVersion() {
|
|
||||||
return "3.1";
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Tests whether purge values setting works */
|
/** Tests whether purge values setting works */
|
||||||
public void testPurgeValues() throws Exception {
|
public void testPurgeValues() throws Exception {
|
||||||
// many thanks to Juozas Baliuka for suggesting this method
|
// many thanks to Juozas Baliuka for suggesting this method
|
||||||
|
@ -227,4 +234,15 @@ public class TestReferenceMap extends AbstractTestIterableMap {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static void gc() {
|
||||||
|
try {
|
||||||
|
// trigger GC
|
||||||
|
byte[][] tooLarge = new byte[1000000000][1000000000];
|
||||||
|
fail("you have too much RAM");
|
||||||
|
} catch (OutOfMemoryError ex) {
|
||||||
|
System.gc(); // ignore
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue