121 lines
4.3 KiB
Java
121 lines
4.3 KiB
Java
|
/*
|
||
|
* Copyright (c) 2002, 2018, Oracle and/or its affiliates. All rights reserved.
|
||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||
|
*
|
||
|
* This code is free software; you can redistribute it and/or modify it
|
||
|
* under the terms of the GNU General Public License version 2 only, as
|
||
|
* published by the Free Software Foundation.
|
||
|
*
|
||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||
|
* accompanied this code).
|
||
|
*
|
||
|
* You should have received a copy of the GNU General Public License version
|
||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||
|
*
|
||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||
|
* or visit www.oracle.com if you need additional information or have any
|
||
|
* questions.
|
||
|
*/
|
||
|
|
||
|
/*
|
||
|
* @test
|
||
|
* @key stress gc
|
||
|
*
|
||
|
* @summary converted from VM Testbase gc/gctests/JumbleGC.
|
||
|
* VM Testbase keywords: [gc, stress, stressopt, nonconcurrent]
|
||
|
* VM Testbase readme:
|
||
|
* A vector of 10 elements is filled up with references to
|
||
|
* CicrcularLinkedList and Binary Trees of 0.1 Meg. Once this
|
||
|
* entire structure has been built, all elements in the Vecor are set to null
|
||
|
* creating 1Meg of garbage. The Vector is repopulated once again.
|
||
|
* With ineffective garbage collection, the heap will soon fill up.
|
||
|
* If an OutofMemoryError is thrown, the test fails.
|
||
|
*
|
||
|
* @library /vmTestbase
|
||
|
* /test/lib
|
||
|
* @run driver jdk.test.lib.FileInstaller . .
|
||
|
* @run main/othervm -XX:-UseGCOverheadLimit gc.gctests.JumbleGC.JumbleGC
|
||
|
*/
|
||
|
|
||
|
package gc.gctests.JumbleGC;
|
||
|
|
||
|
import nsk.share.test.*;
|
||
|
import nsk.share.gc.*;
|
||
|
import java.util.Vector;
|
||
|
|
||
|
public class JumbleGC extends TestBase {
|
||
|
public void run() {
|
||
|
int TreeSize = 1000;
|
||
|
int gc_count;
|
||
|
int randNum;
|
||
|
int num = 0;
|
||
|
|
||
|
Vector v = new Vector(10);
|
||
|
|
||
|
// Build a tree containing 100 treeNodes occupying about
|
||
|
// 1Meg of heap space.
|
||
|
|
||
|
gc_count = 0;
|
||
|
try {
|
||
|
for(int i = 0; i < 10 ; i++) {
|
||
|
if ( i % 2 == 0 )
|
||
|
v.addElement(buildCircularLinkedList());
|
||
|
else
|
||
|
v.addElement(buildTree());
|
||
|
}
|
||
|
|
||
|
while (gc_count < 10) {
|
||
|
|
||
|
for (int i = 0; i < 10 ; i++)
|
||
|
v.setElementAt(null, i);
|
||
|
|
||
|
for (int i = 0; i < 10 ; i++) {
|
||
|
if ( i % 2 == 0 )
|
||
|
v.setElementAt(buildCircularLinkedList(),i);
|
||
|
else
|
||
|
v.setElementAt(buildTree(),i);
|
||
|
}
|
||
|
gc_count ++;
|
||
|
log.info("Finished iteration # " + gc_count);
|
||
|
}
|
||
|
|
||
|
} catch (OutOfMemoryError e) {
|
||
|
log.error("Test Failed.");
|
||
|
setFailed(true);
|
||
|
}
|
||
|
log.info("Test Passed.");
|
||
|
}
|
||
|
|
||
|
public static void main(String args[]){
|
||
|
GC.runTest(new JumbleGC(), args);
|
||
|
}
|
||
|
|
||
|
// build a binary tree of 0.1 Meg.(100 treeNodes in the three, each of 100 bytes
|
||
|
|
||
|
private Tree buildTree() {
|
||
|
int i, randNum;
|
||
|
|
||
|
i = 0;
|
||
|
Tree newTree = new Tree(100);
|
||
|
while (i < 100) {
|
||
|
randNum = LocalRandom.nextInt(0, 1000000);
|
||
|
newTree.addElement(randNum);
|
||
|
i++;
|
||
|
}
|
||
|
return newTree;
|
||
|
}
|
||
|
|
||
|
// build a circular linked list of 0.1 Meg
|
||
|
private CircularLinkedList buildCircularLinkedList() {
|
||
|
CircularLinkedList cl;
|
||
|
cl = new CircularLinkedList(100);
|
||
|
for(int i = 0; i < 1000; i++)
|
||
|
cl.grow();
|
||
|
return cl;
|
||
|
}
|
||
|
}
|