/* * Copyright (c) 2013, 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. */ import java.io.File; import java.nio.charset.Charset; import java.nio.file.Files; import java.util.ArrayList; import java.util.List; import static java.nio.file.StandardOpenOption.*; import java.util.regex.Pattern; /* * @test * @bug 8003549 * @summary tests class files instruction formats introduced in JSR-335 * @compile -XDignore.symbol.file Utils.java InstructionTests.java * @run main InstructionTests * @author ksrini */ public class InstructionTests { public static void main(String... args) throws Exception { testInvokeOpCodes(); } /* * the following should produce invokestatic and invokespecial * on InterfaceMethodRefs vs. MethodRefs, packer/unpacker should work */ static void testInvokeOpCodes() throws Exception { List<String> scratch = new ArrayList<>(); final String fname = "A"; String javaFileName = fname + Utils.JAVA_FILE_EXT; scratch.add("interface IntIterator {"); scratch.add(" default void forEach(){}"); scratch.add(" static void next() {}"); scratch.add("}"); scratch.add("class A implements IntIterator {"); scratch.add("public void forEach(Object o){"); scratch.add("IntIterator.super.forEach();"); scratch.add("IntIterator.next();"); scratch.add("}"); scratch.add("}"); File cwd = new File("."); File javaFile = new File(cwd, javaFileName); Files.write(javaFile.toPath(), scratch, Charset.defaultCharset(), CREATE, TRUNCATE_EXISTING); // make sure we have -g so that we compare LVT and LNT entries Utils.compiler("-g", javaFile.getName()); // jar the file up File testjarFile = new File(cwd, "test" + Utils.JAR_FILE_EXT); Utils.jar("cvf", testjarFile.getName(), "."); // pack using --repack File outjarFile = new File(cwd, "out" + Utils.JAR_FILE_EXT); scratch.clear(); scratch.add(Utils.getPack200Cmd()); scratch.add("-J-ea"); scratch.add("-J-esa"); scratch.add("--repack"); scratch.add(outjarFile.getName()); scratch.add(testjarFile.getName()); List<String> output = Utils.runExec(scratch); // TODO remove this when we get bc escapes working correctly // this test anyhow would fail at that time findString("WARNING: Passing.*" + fname + Utils.CLASS_FILE_EXT, output); Utils.doCompareVerify(testjarFile, outjarFile); } static boolean findString(String str, List<String> list) { Pattern p = Pattern.compile(str); for (String x : list) { if (p.matcher(x).matches()) return true; } throw new RuntimeException("Error: " + str + " not found in output"); } }