blob: 070b34db76ed5b786f29a8c3a4beebebbaa73fea [file] [log] [blame]
/*
* 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.
*/
/**
* @author Anatoly F. Bondarenko
*/
/**
* Created on 04.03.2005
*/
package org.apache.harmony.jpda.tests.jdwp.ObjectReference;
import org.apache.harmony.jpda.tests.share.JPDADebuggeeSynchronizer;
import org.apache.harmony.jpda.tests.share.SyncDebuggee;
public class IsCollectedDebuggee extends SyncDebuggee {
static IsCollectedObject001_01 checkedObject_01;
static volatile boolean checkedObject_01_Finalized = false;
static IsCollectedObject001_02 checkedObject_02;
static volatile boolean checkedObject_02_Finalized = false;
static IsCollectedObject001_03 checkedObject_03;
static volatile boolean checkedObject_03_Finalized = false;
public void run() {
logWriter.println("--> Debuggee: IsCollectedDebuggee: START");
checkedObject_01 = new IsCollectedObject001_01();
checkedObject_02 = new IsCollectedObject001_02();
checkedObject_03 = new IsCollectedObject001_03();
synchronizer.sendMessage(JPDADebuggeeSynchronizer.SGNL_READY);
String messageFromTest = synchronizer.receiveMessage();
if ( messageFromTest.equals("TO_FINISH")) {
logWriter.println("--> Debuggee: IsCollectedDebuggee: FINISH");
return;
}
checkedObject_01 = null;
checkedObject_02 = null;
checkedObject_03 = null;
long[][] longArray;
int i = 0;
try {
longArray = new long[1000000][];
int arraysNumberLimit = 7; // max - longArray.length
logWriter.println
("--> Debuggee: memory depletion - creating 'long[1000000]' arrays (" + arraysNumberLimit + ")...");
for (; i < arraysNumberLimit; i++) {
longArray[i] = new long[1000000];
}
} catch ( OutOfMemoryError outOfMem ) {
logWriter.println("--> Debuggee: OutOfMemoryError!!!");
// logWriter.println("--> Debuggee: i = " + i);
}
longArray = null;
Runtime.getRuntime().gc();
System.runFinalization(); // Make sure that the finalizers are finished running.
// Make sure the JNI weak globals are cleared, need to do this after runFinalization.
Runtime.getRuntime().gc();
logWriter.println("--> Debuggee: AFTER System.gc():");
logWriter.println("--> Debuggee: checkedObject_01 = " +
checkedObject_01);
logWriter.println("--> Debuggee: checkedObject_01_UNLOADed = " +
checkedObject_01_Finalized);
logWriter.println("--> Debuggee: checkedObject_02 = " +
checkedObject_02);
logWriter.println("--> Debuggee: checkedObject_02_UNLOADed = " +
checkedObject_02_Finalized);
logWriter.println("--> Debuggee: checkedObject_03 = " +
checkedObject_03);
logWriter.println("--> Debuggee: checkedObject_03_UNLOADed = " +
checkedObject_03_Finalized);
String messageForTest = null;
if ( checkedObject_01_Finalized ) {
if ( checkedObject_02_Finalized ) {
messageForTest = "checkedObject_01 is UNLOADed; checkedObject_02 is UNLOADed;";
} else {
messageForTest = "checkedObject_01 is UNLOADed; checkedObject_02 is NOT UNLOADed;";
}
} else {
if ( checkedObject_02_Finalized ) {
messageForTest = "checkedObject_01 is NOT UNLOADed; checkedObject_02 is UNLOADed;";
} else {
messageForTest = "checkedObject_01 is NOT UNLOADed; checkedObject_02 is NOT UNLOADed;";
}
}
logWriter.println("--> Debuggee: Send to test message: \"" + messageForTest + "\"");
synchronizer.sendMessage(messageForTest);
synchronizer.receiveMessage(JPDADebuggeeSynchronizer.SGNL_CONTINUE);
logWriter.println("--> Debuggee: IsCollectedDebuggee: FINISH");
}
public static void main(String [] args) {
runDebuggee(IsCollectedDebuggee.class);
}
}
class IsCollectedObject001_01 {
protected void finalize() throws Throwable {
IsCollectedDebuggee.checkedObject_01_Finalized = true;
super.finalize();
}
}
class IsCollectedObject001_02 {
protected void finalize() throws Throwable {
IsCollectedDebuggee.checkedObject_02_Finalized = true;
super.finalize();
}
}
class IsCollectedObject001_03 {
protected void finalize() throws Throwable {
IsCollectedDebuggee.checkedObject_03_Finalized = true;
super.finalize();
}
}