jdk/test/lib/testlibrary/JavaToolUtils.java
author robm
Wed, 09 Dec 2015 17:34:09 +0000
changeset 34531 7f00d9e3e545
parent 26362 b1e9b551e10a
permissions -rw-r--r--
8141370: com/sun/jndi/ldap/LdapTimeoutTest.java failed intermittently Reviewed-by: vinnie
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
26362
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
     1
/*
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
     2
 * Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved.
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
     4
 *
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    10
 *
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    15
 * accompanied this code).
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    16
 *
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    20
 *
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    23
 * questions.
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    24
 */
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    25
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    26
import java.io.BufferedReader;
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    27
import java.io.File;
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    28
import java.io.FileOutputStream;
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    29
import java.io.IOException;
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    30
import java.io.InputStreamReader;
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    31
import java.nio.file.Files;
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    32
import java.util.List;
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    33
import java.util.Objects;
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    34
import java.util.concurrent.TimeUnit;
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    35
import java.util.jar.Attributes;
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    36
import java.util.jar.JarEntry;
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    37
import java.util.jar.JarOutputStream;
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    38
import java.util.jar.Manifest;
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    39
import javax.tools.JavaCompiler;
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    40
import javax.tools.JavaFileObject;
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    41
import javax.tools.StandardJavaFileManager;
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    42
import javax.tools.ToolProvider;
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    43
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    44
/**
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    45
 * Utils class for compiling , creating jar file and executing a java command
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    46
 *
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    47
 * @author Raghu Nair
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    48
 */
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    49
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    50
public class JavaToolUtils {
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    51
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    52
    public static final long DEFAULT_WAIT_TIME = 10000;
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    53
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    54
    private JavaToolUtils() {
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    55
    }
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    56
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    57
    /**
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    58
     * Takes a list of files and compile these files into the working directory.
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    59
     *
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    60
     * @param files
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    61
     * @throws IOException
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    62
     */
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    63
    public static void compileFiles(List<File> files) throws IOException {
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    64
        JavaCompiler compiler = ToolProvider.getSystemJavaCompiler();
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    65
        try (StandardJavaFileManager fileManager = compiler.
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    66
                getStandardFileManager(null, null, null)) {
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    67
            Iterable<? extends JavaFileObject> compilationUnit
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    68
                    = fileManager.getJavaFileObjectsFromFiles(files);
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    69
            compiler.getTask(null, fileManager, null, null, null,
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    70
                    compilationUnit).call();
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    71
        }
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    72
    }
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    73
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    74
    /**
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    75
     * Create a jar file using the list of files provided.
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    76
     *
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    77
     * @param jar
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    78
     * @param files
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    79
     * @throws IOException
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    80
     */
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    81
    public static void createJar(File jar, List<File> files)
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    82
            throws IOException {
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    83
        Manifest manifest = new Manifest();
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    84
        manifest.getMainAttributes().put(Attributes.Name.MANIFEST_VERSION,
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    85
                "1.0");
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    86
        try (JarOutputStream target = new JarOutputStream(
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    87
                new FileOutputStream(jar), manifest)) {
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    88
            for (File file : files) {
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    89
                add(file, target);
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    90
            }
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    91
        }
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    92
    }
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    93
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    94
    private static void add(File source, JarOutputStream target)
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    95
            throws IOException {
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    96
        Objects.requireNonNull(source, "source cannot be null");
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    97
        Objects.requireNonNull(target, "target cannot be null");
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    98
        // not tested against directories and from different path.
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
    99
        String name = source.getName();
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   100
        if (source.isDirectory()) {
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   101
            if (!name.isEmpty()) {
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   102
                if (!name.endsWith("/")) {
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   103
                    name += "/";
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   104
                }
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   105
                JarEntry entry = new JarEntry(name);
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   106
                entry.setTime(source.lastModified());
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   107
                target.putNextEntry(entry);
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   108
                target.closeEntry();
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   109
            }
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   110
            for (File nestedFile : source.listFiles()) {
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   111
                add(nestedFile, target);
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   112
            }
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   113
            return;
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   114
        }
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   115
        System.out.println("Adding entry " + name);
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   116
        JarEntry entry = new JarEntry(name);
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   117
        entry.setTime(source.lastModified());
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   118
        target.putNextEntry(entry);
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   119
        Files.copy(source.toPath(), target);
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   120
        target.closeEntry();
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   121
    }
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   122
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   123
    /**
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   124
     * Runs java command with provided arguments. Caller should not pass java
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   125
     * command in the argument list.
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   126
     *
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   127
     * @param commands
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   128
     * @param waitTime time to wait for the command to exit in milli seconds
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   129
     * @return
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   130
     * @throws Exception
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   131
     */
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   132
    public static int runJava(List<String> commands,long waitTime)
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   133
            throws Exception {
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   134
        String java = System.getProperty("java.home") + "/bin/java";
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   135
        commands.add(0, java);
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   136
        String command = commands.toString().replace(",", " ");
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   137
        System.out.println("Executing the following command \n" + command);
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   138
        ProcessBuilder processBuilder = new ProcessBuilder(commands);
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   139
        final Process process = processBuilder.start();
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   140
        BufferedReader errorStream = new BufferedReader(
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   141
                new InputStreamReader(process.getErrorStream()));
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   142
        BufferedReader outStream = new BufferedReader(
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   143
                new InputStreamReader(process.getInputStream()));
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   144
        String errorLine;
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   145
        StringBuilder errors = new StringBuilder();
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   146
        String outLines;
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   147
        while ((errorLine = errorStream.readLine()) != null) {
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   148
            errors.append(errorLine).append("\n");
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   149
        }
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   150
        while ((outLines = outStream.readLine()) != null) {
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   151
            System.out.println(outLines);
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   152
        }
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   153
        errorLine = errors.toString();
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   154
        System.err.println(errorLine);
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   155
        process.waitFor(waitTime, TimeUnit.MILLISECONDS);
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   156
        int exitStatus = process.exitValue();
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   157
        if (exitStatus != 0 && errorLine != null && errorLine.isEmpty()) {
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   158
            throw new RuntimeException(errorLine);
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   159
        }
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   160
        return exitStatus;
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   161
    }
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   162
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   163
    /**
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   164
     * Runs java command with provided arguments. Caller should not pass java
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   165
     * command in the argument list.
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   166
     *
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   167
     * @param commands
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   168
     * @return
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   169
     * @throws Exception
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   170
     */
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   171
    public static int runJava(List<String> commands) throws Exception {
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   172
        return runJava(commands, DEFAULT_WAIT_TIME);
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   173
    }
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   174
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   175
    /**
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   176
     * Run any command
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   177
     * @param commands
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   178
     * @return
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   179
     * @throws Exception
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   180
     */
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   181
    public static int runCommand(List<String> commands) throws Exception {
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   182
        String command = commands.toString().replace(",", " ");
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   183
        System.out.println("Executing the following command \n" + command);
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   184
        ProcessBuilder processBuilder = new ProcessBuilder(commands);
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   185
        final Process process = processBuilder.start();
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   186
        BufferedReader errorStream = new BufferedReader(
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   187
                new InputStreamReader(process.getErrorStream()));
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   188
        BufferedReader outStream = new BufferedReader(
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   189
                new InputStreamReader(process.getInputStream()));
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   190
        String errorLine;
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   191
        StringBuilder errors = new StringBuilder();
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   192
        String outLines;
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   193
        while ((errorLine = errorStream.readLine()) != null) {
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   194
            errors.append(errorLine).append("\n");
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   195
        }
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   196
        while ((outLines = outStream.readLine()) != null) {
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   197
            System.out.println(outLines);
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   198
        }
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   199
        errorLine = errors.toString();
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   200
        System.err.println(errorLine);
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   201
        int exitStatus = process.exitValue();
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   202
        if (exitStatus != 0 && errorLine != null && errorLine.isEmpty()) {
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   203
            throw new RuntimeException(errorLine);
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   204
        }
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   205
        return exitStatus;
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   206
    }
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   207
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   208
b1e9b551e10a 8048362: Tests for doPrivileged with accomplice
xuelei
parents:
diff changeset
   209
}