79 lines
3.9 KiB
Java
Raw Normal View History

/*
* Copyright (c) 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
*
* @summary converted from VM Testbase nsk/jvmti/AddToBootstrapClassLoaderSearch/bootclssearch004.
* VM Testbase keywords: [quick, jpda, jvmti, onload_only_logic, noras, no_cds]
* VM Testbase readme:
* DESCRIPTION
* This JVMTI test exercises JVMTI thread function AddToBootstrapClassLoaderSearch().
* This test checks that AddToBootstrapClassLoaderSearch() can add two segments
* to bootstrap class search path in OnLoad phase, and debuggee class will be
* loaded from the first segment even if it is found in the second segment too,
* The following checks are performed by the test:
* - AddToBootstrapClassLoaderSearch() adds two segments and returns
* no errors in OnLoad phase
* - debuggee class located by the first added segment will be loaded
* - debuggee class located by the second added segment will NOT be loaded
* There are two different implementations of debuggee class 'bootclssearch004'.
* Source of "positive" implementation is located in subdirectory 'newclass01'.
* It will be compiled to '$COMMON_CLASSES_LOCATION/newclass01', that will be
* added first to bootstrap class search path.
* This implementation returns PASS.
* Source of "negative" implementation is located in subdirectory 'newclass02'.
* It will be compiled to '$COMMON_CLASSES_LOCATION/newclass02', that will be
* added second to bootstrap class search path.
* This implementation returns FAIL.
* The agent adds both subdirectories to the bootstrap class search path
* in Agent_OnLoad(), and expects that positive implementation of debuggee class
* from the first added segment will be loaded and executed.
* If AddToBootstrapClassLoaderSearch() returns error in Agent_OnLoad(),
* then agent returns JNI_ERR and VM fails on initialization.
* If negative implementation of debuggee class is loaded and executed,
* then it returns FAIL and test fails with exit code 97.
* Otherwise, if both segments are successfully added and positive implementation
* of debuggee class is loaded and executed, then it returns PASS and test
* passes with exit code 95.
* COMMENTS
* Made code cleanup: nsk/share/jvmti/AddToBootstrapClassLoaderSearch/bootclssearch_agent
* agent is used now.
*
* @library /vmTestbase
* /test/lib
* @run driver jdk.test.lib.FileInstaller . .
* @build nsk.share.Consts
*
* @comment compile newclassXX to bin/newclassXX
* @run driver nsk.share.ExtraClassesBuilder
* newclass02 newclass01
*
* @build ExecDriver
* @run main/othervm/native PropertyResolvingWrapper ExecDriver --java
* "-agentlib:bootclssearch_agent=-waittime=5 phasetocheck=onload segment1=./bin/newclass01 segment2=./bin/newclass02"
* nsk.jvmti.AddToBootstrapClassLoaderSearch.bootclssearch004
*/