| /* |
| * Copyright (c) 2006, 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 |
| * @bug 6270982 |
| * @summary Redefine a class so that the order of external classes in |
| * the constant pool are changed. |
| * @comment converted from test/jdk/com/sun/jdi/RedefineChangeClassOrder.sh |
| * |
| * @library /test/lib |
| * @compile -g RedefineChangeClassOrder.java |
| * @run main/othervm RedefineChangeClassOrder |
| */ |
| |
| import jdk.test.lib.process.OutputAnalyzer; |
| import lib.jdb.JdbCommand; |
| import lib.jdb.JdbTest; |
| |
| import java.lang.annotation.Retention; |
| import java.lang.annotation.RetentionPolicy; |
| |
| class RedefineChangeClassOrderTarg { |
| public static void main(String[] args) { |
| new RedefineChangeClassOrderTarg().hi(false); |
| new RedefineChangeClassOrderTarg().hi(true); // @1 breakpoint |
| } |
| |
| public void hi(boolean expected) { |
| boolean isNewVersion = false; // @1 commentout |
| // @1 uncomment boolean isNewVersion = true; |
| |
| if (expected == isNewVersion) { |
| System.out.println("PASS: expected and isNewVersion match."); |
| } else { |
| System.out.println("FAIL: expected and isNewVersion do not match."); |
| System.out.println("expected=" + expected |
| + " isNewVersion=" + isNewVersion); |
| } |
| |
| Foo1 foo1 = new Foo1(); // @1 commentout |
| foo1.hi(); // @1 commentout |
| |
| // This Hack code block exists to force some verification_type_info |
| // objects of subtype Object_variable_info into the StackMapTable. |
| // |
| // In the redefined code, the above Foo1 code is effectively |
| // moved after the Foo2 code below which causes things to be |
| // layed out in a different order in the constant pool. The |
| // cpool_index in the Object_variable_info has to be updated |
| // in the redefined code's StackMapTable to refer to right |
| /// constant pool index in the merged constant pool. |
| Hack hack = getClass().getAnnotation(Hack.class); |
| if (hack != null) { |
| String class_annotation = hack.value(); |
| System.out.println("class annotation is: " + class_annotation); |
| if (isNewVersion) { |
| if (class_annotation.equals("JUNK")) { |
| System.out.println("class_annotation is JUNK."); |
| } else { |
| System.out.println("class_annotation is NOT JUNK."); |
| } |
| } |
| } |
| |
| Foo2 foo2 = new Foo2(); |
| foo2.hi(); |
| |
| // @1 uncomment Foo1 foo1 = new Foo1(); |
| // @1 uncomment foo1.hi(); |
| } |
| } |
| |
| class Foo1 { |
| public void hi() { |
| System.out.println("Hello from " + getClass()); |
| } |
| } |
| |
| class Foo2 { |
| public void hi() { |
| System.out.println("Hello from " + getClass()); |
| } |
| } |
| |
| @Retention(RetentionPolicy.RUNTIME) |
| @interface Hack { |
| String value(); |
| } |
| |
| |
| public class RedefineChangeClassOrder extends JdbTest { |
| |
| public static void main(String argv[]) { |
| new RedefineChangeClassOrder().run(); |
| } |
| |
| private RedefineChangeClassOrder() { |
| super(DEBUGGEE_CLASS, SOURCE_FILE); |
| } |
| |
| private static final String DEBUGGEE_CLASS = RedefineChangeClassOrderTarg.class.getName(); |
| private static final String SOURCE_FILE = "RedefineChangeClassOrder.java"; |
| |
| @Override |
| protected void runCases() { |
| setBreakpoints(1); |
| jdb.command(JdbCommand.run()); |
| redefineClass(1, "-g"); |
| jdb.contToExit(1); |
| |
| new OutputAnalyzer(getDebuggeeOutput()) |
| .shouldNotContain("FAIL:"); |
| } |
| } |