examples/tomcat6/apache-tomcat-6.0.35-src/libs/commons-pool-1.5.6-src/src/test/org/apache/commons/pool/impl/TestSoftRefOutOfMemory.java
Merged with mercurial revision 4f3cc813be4 (8 changesets total)
Merged changesets:
- f14cd4bbd33f: Jan Vrany, 2015-03-11 11:41 +0000: Zulu support: added Zulu7 and Zulu8 JavaReleases
- f8bc54a17beb: Jan Vrany, 2015-03-11 12:38 +0000: Java release: On UNIX, prefer OpenJDK over Zulu, on Windows, prefer Zulu over Oracle JDK
- 5dd55aa7d949: Jan Vrany, 2015-03-12 14:50 +0000: Zulu support: move natives from OracleJDK7 to OpenJDK7 as they are used by OpenJDK7 on Windows
- 2127b5057d60: Jan Vrany, 2015-03-13 09:40 +0000: testing: improved run-all.rb script to run tests with different configurations.
- a6d8f5c2ad73: Jan Vrany, 2015-03-13 13:33 +0000: Updated .hgignore
- e18d5c89221d: Jan Vrany, 2015-03-13 16:09 +0000: Java release: consult 64bit registry entries as well as 32 bit when searching for installed JDKs
- 183e4567bda7: Jan Vrany, 2015-03-17 20:56 +0000: Java release: added #is32bit & #is64bit testing methods
- 4f3cc813be4b: Jan Vrany, 2015-03-19 17:27 +0000: settings: JavaCodeLibrary validation refactored and improved
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.commons.pool.impl;
import java.util.Arrays;
import java.util.LinkedList;
import java.util.List;
import junit.framework.TestCase;
import org.apache.commons.pool.BasePoolableObjectFactory;
import org.apache.commons.pool.PoolableObjectFactory;
/**
* @author Dirk Verbeeck
* @author Sandy McArthur
* @version $Revision: 1.5 $ $Date: 2015-03-20 13:29:42 $
*/
public class TestSoftRefOutOfMemory extends TestCase {
private SoftReferenceObjectPool pool;
public TestSoftRefOutOfMemory(String testName) {
super(testName);
}
public void tearDown() throws Exception {
if (pool != null) {
pool.close();
pool = null;
}
System.gc();
}
public void testOutOfMemory() throws Exception {
pool = new SoftReferenceObjectPool(new SmallPoolableObjectFactory());
Object obj = pool.borrowObject();
assertEquals("1", obj);
pool.returnObject(obj);
obj = null;
assertEquals(1, pool.getNumIdle());
final List garbage = new LinkedList();
final Runtime runtime = Runtime.getRuntime();
while (pool.getNumIdle() > 0) {
try {
long freeMemory = runtime.freeMemory();
if (freeMemory > Integer.MAX_VALUE) {
freeMemory = Integer.MAX_VALUE;
}
garbage.add(new byte[Math.min(1024 * 1024, (int)freeMemory/2)]);
} catch (OutOfMemoryError oome) {
System.gc();
}
System.gc();
}
garbage.clear();
System.gc();
obj = pool.borrowObject();
assertEquals("2", obj);
pool.returnObject(obj);
obj = null;
assertEquals(1, pool.getNumIdle());
}
public void testOutOfMemory1000() throws Exception {
pool = new SoftReferenceObjectPool(new SmallPoolableObjectFactory());
for (int i = 0 ; i < 1000 ; i++) {
pool.addObject();
}
Object obj = pool.borrowObject();
assertEquals("1000", obj);
pool.returnObject(obj);
obj = null;
assertEquals(1000, pool.getNumIdle());
final List garbage = new LinkedList();
final Runtime runtime = Runtime.getRuntime();
while (pool.getNumIdle() > 0) {
try {
long freeMemory = runtime.freeMemory();
if (freeMemory > Integer.MAX_VALUE) {
freeMemory = Integer.MAX_VALUE;
}
garbage.add(new byte[Math.min(1024 * 1024, (int)freeMemory/2)]);
} catch (OutOfMemoryError oome) {
System.gc();
}
System.gc();
}
garbage.clear();
System.gc();
obj = pool.borrowObject();
assertEquals("1001", obj);
pool.returnObject(obj);
obj = null;
assertEquals(1, pool.getNumIdle());
}
public void testOutOfMemoryLarge() throws Exception {
pool = new SoftReferenceObjectPool(new LargePoolableObjectFactory(1000000));
Object obj = pool.borrowObject();
assertTrue(((String)obj).startsWith("1."));
pool.returnObject(obj);
obj = null;
assertEquals(1, pool.getNumIdle());
final List garbage = new LinkedList();
final Runtime runtime = Runtime.getRuntime();
while (pool.getNumIdle() > 0) {
try {
long freeMemory = runtime.freeMemory();
if (freeMemory > Integer.MAX_VALUE) {
freeMemory = Integer.MAX_VALUE;
}
garbage.add(new byte[Math.min(1024 * 1024, (int)freeMemory/2)]);
} catch (OutOfMemoryError oome) {
System.gc();
}
System.gc();
}
garbage.clear();
System.gc();
obj = pool.borrowObject();
assertTrue(((String)obj).startsWith("2."));
pool.returnObject(obj);
obj = null;
assertEquals(1, pool.getNumIdle());
}
/**
* Makes sure an {@link OutOfMemoryError} isn't swallowed.
*/
public void testOutOfMemoryError() throws Exception {
pool = new SoftReferenceObjectPool(new BasePoolableObjectFactory() {
public Object makeObject() throws Exception {
throw new OutOfMemoryError();
}
});
try {
pool.borrowObject();
fail("Expected out of memory.");
}
catch (OutOfMemoryError ex) {
// expected
}
pool.close();
pool = new SoftReferenceObjectPool(new BasePoolableObjectFactory() {
public Object makeObject() throws Exception {
return new Object();
}
public boolean validateObject(Object obj) {
throw new OutOfMemoryError();
}
});
try {
pool.borrowObject();
fail("Expected out of memory.");
}
catch (OutOfMemoryError ex) {
// expected
}
pool.close();
pool = new SoftReferenceObjectPool(new BasePoolableObjectFactory() {
public Object makeObject() throws Exception {
return new Object();
}
public boolean validateObject(Object obj) {
throw new IllegalAccessError();
}
public void destroyObject(Object obj) throws Exception {
throw new OutOfMemoryError();
}
});
try {
pool.borrowObject();
fail("Expected out of memory.");
}
catch (OutOfMemoryError ex) {
// expected
}
pool.close();
}
public static class SmallPoolableObjectFactory implements PoolableObjectFactory {
private int counter = 0;
public Object makeObject() {
counter++;
// It seems that as of Java 1.4 String.valueOf may return an
// intern()'ed String this may cause problems when the tests
// depend on the returned object to be eventually garbaged
// collected. Either way, making sure a new String instance
// is returned eliminated false failures.
return new String(String.valueOf(counter));
}
public boolean validateObject(Object obj) {
return true;
}
public void activateObject(Object obj) { }
public void passivateObject(Object obj) { }
public void destroyObject(Object obj) { }
}
public static class LargePoolableObjectFactory implements PoolableObjectFactory {
private String buffer;
private int counter = 0;
public LargePoolableObjectFactory(int size) {
char[] data = new char[size];
Arrays.fill(data, '.');
buffer = new String(data);
}
public Object makeObject() {
counter++;
return String.valueOf(counter) + buffer;
}
public boolean validateObject(Object obj) {
return true;
}
public void activateObject(Object obj) { }
public void passivateObject(Object obj) { }
public void destroyObject(Object obj) { }
}
}