jdk/test/tools/pack200/InstructionTests.java
author jlaskey
Tue, 19 Feb 2013 09:47:02 -0400
changeset 16248 e4bcc4b4f897
parent 15526 84de8685a2d0
child 16050 1eee624cddb3
permissions -rw-r--r--
Merge

/*
 * 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");
    }
}