/*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* 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
* @bug 4406439 4925740
* @summary ClassesByName2 verifies that all the classes in the loaded class list can be found with classesByName..
*
* @author Tim Bell (based on ClassesByName by Robert Field)
*
* @run build TestScaffold VMConnection TargetListener TargetAdapter
* @run compile -g ClassesByName2Test.java
* @run main ClassesByName2Test
*/
/********** target program **********/
class ClassesByName2Targ {
static void bkpt() {
}
try {
public void run () {
}
};
public void run () {
try {
} catch (Exception e) {
e.printStackTrace();
}
}
};
public void run () {
}
};
try {
} catch (InterruptedException iex) {
}
} catch (Exception e) {
e.printStackTrace();
}
bkpt();
}
}
/********** test program **********/
volatile boolean stop = false;
super(args);
}
stop = true;
}
// Don't resume.
}
}
throws Exception {
throw new Exception("test error: should be one " +
}
try {
addListener (this);
failure("failure: Could not add listener");
throw new Exception("ClassesByname2Test: failed");
}
}
/*
Bug 6263966 - Don't just resume because the debuggee can
complete and disconnect while the following loop is
accessing it.
*/
/* The test of 'stop' is so that we stop when the debuggee hits
the bkpt. The 150 is so we stop if the debuggee
is slow (eg, -Xcomp -server) - we don't want to
spend all day waiting for it to get to the bkpt.
*/
//System.out.println("Found class: " + name);
} else {
throw new Exception("CLASS NOT FOUND (by classesByName): " +
name);
}
}
}
// In case of a slow debuggee, we don't want to resume the debuggee and wait
// for it to complete.
/*
* deal with results of test
* if anything has called failure("foo") testFailed will be true
*/
if (!testFailed) {
println("ClassesByName2Test: passed");
} else {
throw new Exception("ClassesByName2Test: failed");
}
}
}