blob: 9038507df9094237bc23a2d27f3dcbf6dfa03464 [file] [log] [blame]
duke6e45e102007-12-01 00:00:00 +00001/*
ohair2283b9d2010-05-25 15:58:33 -07002 * Copyright (c) 2004, 2007, Oracle and/or its affiliates. All rights reserved.
duke6e45e102007-12-01 00:00:00 +00003 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 *
5 * This code is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License version 2 only, as
7 * published by the Free Software Foundation.
8 *
9 * This code is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
12 * version 2 for more details (a copy is included in the LICENSE file that
13 * accompanied this code).
14 *
15 * You should have received a copy of the GNU General Public License version
16 * 2 along with this work; if not, write to the Free Software Foundation,
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18 *
ohair2283b9d2010-05-25 15:58:33 -070019 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20 * or visit www.oracle.com if you need additional information or have any
21 * questions.
duke6e45e102007-12-01 00:00:00 +000022 */
23
24
25/* DemoRun:
26 *
27 * Support classes for java jvmti demo tests
28 *
29 */
30
31import java.io.InputStream;
32import java.io.IOException;
33import java.io.File;
34import java.io.BufferedInputStream;
35import java.io.PrintStream;
36
37/*
38 * Helper class to direct process output to a StringBuffer
39 */
40class MyInputStream implements Runnable {
41 private String name;
42 private BufferedInputStream in;
43 private StringBuffer buffer;
44
45 /* Create MyInputStream that saves all output to a StringBuffer */
46 MyInputStream(String name, InputStream in) {
47 this.name = name;
48 this.in = new BufferedInputStream(in);
49 buffer = new StringBuffer(4096);
50 Thread thr = new Thread(this);
51 thr.setDaemon(true);
52 thr.start();
53 }
54
55 /* Dump the buffer */
56 void dump(PrintStream x) {
57 String str = buffer.toString();
58 x.println("<beginning of " + name + " buffer>");
59 x.println(str);
60 x.println("<end of buffer>");
61 }
62
63 /* Check to see if a pattern is inside the output. */
64 boolean contains(String pattern) {
65 String str = buffer.toString();
66 return str.contains(pattern);
67 }
68
69 /* Runs as a separate thread capturing all output in a StringBuffer */
70 public void run() {
71 try {
72 byte b[] = new byte[100];
73 for (;;) {
74 int n = in.read(b);
75 String str;
76 if (n < 0) {
77 break;
78 }
79 str = new String(b, 0, n);
80 buffer.append(str);
81 System.out.print(str);
82 }
83 } catch (IOException ioe) { /* skip */ }
84 }
85}
86
87/*
88 * Main JVMTI Demo Run class.
89 */
90public class DemoRun {
91
92 private String demo_name;
93 private String demo_options;
94 private MyInputStream output;
95 private MyInputStream error;
96
97 /* Create a Demo run process */
98 public DemoRun(String name, String options)
99 {
100 demo_name = name;
101 demo_options = options;
102 }
103
104 /*
105 * Execute a process with an -agentpath or -agentlib command option
106 */
107 public void runit(String class_name)
108 {
109 runit(class_name, null);
110 }
111
112 /*
113 * Execute a process with an -agentpath or -agentlib command option
114 * plus any set of other java options.
115 */
116 public void runit(String class_name, String vm_options[])
117 {
118 String jre_home = System.getProperty("java.home");
119 String sdk_home = (jre_home.endsWith("jre") ?
120 (jre_home + File.separator + "..") :
121 jre_home );
122 String cdir = System.getProperty("test.classes", ".");
123 String os_arch = System.getProperty("os.arch");
124 String os_name = System.getProperty("os.name");
125 String libprefix = os_name.contains("Windows")?"":"lib";
michaelm5ac8c152012-03-06 20:34:38 +0000126 String libsuffix = os_name.contains("Windows")?".dll":
127 os_name.startsWith("Mac OS")?".dylib":".so";
duke6e45e102007-12-01 00:00:00 +0000128 boolean d64 = ( os_name.contains("Solaris") ||
129 os_name.contains("SunOS") )
130 && ( os_arch.equals("sparcv9") ||
131 os_arch.equals("amd64"));
132 boolean hprof = demo_name.equals("hprof");
133 String isa_dir = d64?(File.separator+os_arch):"";
134 String java = jre_home
135 + File.separator + "bin" + isa_dir
136 + File.separator + "java";
137 /* Array of strings to be passed in for exec:
138 * 1. java
139 * 2. -Dtest.classes=.
140 * 3. -d64 (optional)
141 * 4. -Xcheck:jni (Just because it finds bugs)
142 * 5. -Xverify:all (Make sure verification is on full blast)
143 * 6. -agent
144 * vm_options
145 * 7+i. classname
146 */
147 int nvm_options = 0;
148 if ( vm_options != null ) nvm_options = vm_options.length;
ohaire8801042009-11-09 12:38:32 -0800149 String cmd[] = new String[1 + (d64?1:0) + 7 + nvm_options];
duke6e45e102007-12-01 00:00:00 +0000150 String cmdLine;
151 int exitStatus;
152 int i,j;
153
154 i = 0;
155 cmdLine = "";
156 cmdLine += (cmd[i++] = java);
157 cmdLine += " ";
ohaire8801042009-11-09 12:38:32 -0800158 cmdLine += (cmd[i++] = "-cp");
159 cmdLine += " ";
160 cmdLine += (cmd[i++] = cdir);
161 cmdLine += " ";
duke6e45e102007-12-01 00:00:00 +0000162 cmdLine += (cmd[i++] = "-Dtest.classes=" + cdir);
163 if ( d64 ) {
164 cmdLine += " ";
165 cmdLine += (cmd[i++] = "-d64");
166 }
167 cmdLine += " ";
168 cmdLine += (cmd[i++] = "-Xcheck:jni");
169 cmdLine += " ";
170 cmdLine += (cmd[i++] = "-Xverify:all");
171 if ( hprof ) {
172 /* Load hprof with -agentlib since it's part of jre */
173 cmdLine += " ";
174 cmdLine += (cmd[i++] = "-agentlib:" + demo_name
175 + (demo_options.equals("")?"":("="+demo_options)));
176 } else {
177 String libname = sdk_home
178 + File.separator + "demo"
179 + File.separator + "jvmti"
180 + File.separator + demo_name
181 + File.separator + "lib" + isa_dir
182 + File.separator + libprefix + demo_name + libsuffix;
183 cmdLine += " ";
184 cmdLine += (cmd[i++] = "-agentpath:" + libname
185 + (demo_options.equals("")?"":("="+demo_options)));
186 }
187 /* Add any special VM options */
188 for ( j = 0; j < nvm_options; j++ ) {
189 cmdLine += " ";
190 cmdLine += (cmd[i++] = vm_options[j]);
191 }
192 /* Add classname */
193 cmdLine += " ";
194 cmdLine += (cmd[i++] = class_name);
195
196 /* Begin process */
197 Process p;
198
199 System.out.println("Starting: " + cmdLine);
200 try {
201 p = Runtime.getRuntime().exec(cmd);
202 } catch ( IOException e ) {
203 throw new RuntimeException("Test failed - exec got IO exception");
204 }
205
206 /* Save process output in StringBuffers */
207 output = new MyInputStream("Input Stream", p.getInputStream());
208 error = new MyInputStream("Error Stream", p.getErrorStream());
209
210 /* Wait for process to complete, and if exit code is non-zero we fail */
211 try {
212 exitStatus = p.waitFor();
213 if ( exitStatus != 0) {
214 System.out.println("Exit code is " + exitStatus);
215 error.dump(System.out);
216 output.dump(System.out);
217 throw new RuntimeException("Test failed - " +
218 "exit return code non-zero " +
219 "(exitStatus==" + exitStatus + ")");
220 }
221 } catch ( InterruptedException e ) {
222 throw new RuntimeException("Test failed - process interrupted");
223 }
224 System.out.println("Completed: " + cmdLine);
225 }
226
227 /* Does the pattern appear in the output of this process */
228 public boolean output_contains(String pattern)
229 {
230 return output.contains(pattern) || error.contains(pattern);
231 }
232}