Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/openjdk-multiarch-jdk8u
Path: blob/aarch64-shenandoah-jdk8u272-b10/jdk/test/tools/launcher/Arrrghs.java
38833 views
1
/*
2
* Copyright (c) 2007, 2013, Oracle and/or its affiliates. All rights reserved.
3
* 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
*
19
* 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.
22
*/
23
24
/**
25
* @test
26
* @bug 5030233 6214916 6356475 6571029 6684582 6742159 4459600 6758881 6753938
27
* 6894719 6968053 7151434 7146424 8007333 8077822 8143640
28
* @summary Argument parsing validation.
29
* @compile -XDignore.symbol.file Arrrghs.java
30
* @run main/othervm Arrrghs
31
*/
32
33
import java.io.BufferedReader;
34
import java.io.File;
35
import java.io.FileNotFoundException;
36
import java.io.IOException;
37
import java.io.InputStream;
38
import java.io.InputStreamReader;
39
import java.util.ArrayList;
40
import java.util.Arrays;
41
import java.util.HashMap;
42
import java.util.List;
43
import java.util.Map;
44
import java.util.regex.Matcher;
45
import java.util.regex.Pattern;
46
47
public class Arrrghs extends TestHelper {
48
private Arrrghs(){}
49
/**
50
* This class provides various tests for arguments processing.
51
* A group of tests to ensure that arguments are passed correctly to
52
* a child java process upon a re-exec, this typically happens when
53
* a version other than the one being executed is requested by the user.
54
*
55
* History: these set of tests were part of Arrrghs.sh. The MKS shell
56
* implementations were notoriously buggy. Implementing these tests purely
57
* in Java is not only portable but also robust.
58
*
59
*/
60
61
// The version string to force a re-exec
62
final static String VersionStr = "-version:1.1+";
63
64
// The Cookie or the pattern we match in the debug output.
65
final static String Cookie = "ReExec Args: ";
66
67
/*
68
* SIGH, On Windows all strings are quoted, we need to unwrap it
69
*/
70
private static String removeExtraQuotes(String in) {
71
if (isWindows) {
72
// Trim the string and remove the enclosed quotes if any.
73
in = in.trim();
74
if (in.startsWith("\"") && in.endsWith("\"")) {
75
return in.substring(1, in.length()-1);
76
}
77
}
78
return in;
79
}
80
81
/*
82
* This method detects the cookie in the output stream of the process.
83
*/
84
private boolean detectCookie(InputStream istream,
85
String expectedArguments) throws IOException {
86
BufferedReader rd = new BufferedReader(new InputStreamReader(istream));
87
boolean retval = false;
88
89
String in = rd.readLine();
90
while (in != null) {
91
if (debug) System.out.println(in);
92
if (in.startsWith(Cookie)) {
93
String detectedArgument = removeExtraQuotes(in.substring(Cookie.length()));
94
if (expectedArguments.equals(detectedArgument)) {
95
retval = true;
96
} else {
97
System.out.println("Error: Expected Arguments\t:'" +
98
expectedArguments + "'");
99
System.out.println(" Detected Arguments\t:'" +
100
detectedArgument + "'");
101
}
102
// Return the value asap if not in debug mode.
103
if (!debug) {
104
rd.close();
105
istream.close();
106
return retval;
107
}
108
}
109
in = rd.readLine();
110
}
111
return retval;
112
}
113
114
private boolean doReExecTest0(ProcessBuilder pb, String expectedArguments) {
115
boolean retval = false;
116
try {
117
pb.redirectErrorStream(true);
118
Process p = pb.start();
119
retval = detectCookie(p.getInputStream(), expectedArguments);
120
p.waitFor();
121
p.destroy();
122
} catch (Exception ex) {
123
ex.printStackTrace();
124
throw new RuntimeException(ex.getMessage());
125
}
126
return retval;
127
}
128
129
/**
130
* This method returns true if the expected and detected arguments are the same.
131
* Quoting could cause dissimilar testArguments and expected arguments.
132
*/
133
int doReExecTest(String testArguments, String expectedPattern) {
134
ProcessBuilder pb = new ProcessBuilder(javaCmd,
135
VersionStr, testArguments);
136
137
Map<String, String> env = pb.environment();
138
env.put(JLDEBUG_KEY, "true");
139
return doReExecTest0(pb, testArguments) ? 0 : 1;
140
}
141
142
/**
143
* A convenience method for identical test pattern and expected arguments
144
*/
145
int doReExecTest(String testPattern) {
146
return doReExecTest(testPattern, testPattern);
147
}
148
149
@Test
150
void testQuoteParsingThroughReExec() {
151
/*
152
* Tests for 6214916
153
* These tests require that a JVM (any JVM) be installed in the system registry.
154
* If none is installed, skip this test.
155
*/
156
TestResult tr = doExec(javaCmd, VersionStr, "-version");
157
if (!tr.isOK()) {
158
System.err.println("Warning:Argument Passing Tests were skipped, " +
159
"no java found in system registry.");
160
return;
161
}
162
163
// Basic test
164
testExitValue += doReExecTest("-a -b -c -d");
165
166
// Basic test with many spaces
167
testExitValue += doReExecTest("-a -b -c -d");
168
169
// Quoted whitespace does matter ?
170
testExitValue += doReExecTest("-a \"\"-b -c\"\" -d");
171
172
173
// Escaped quotes outside of quotes as literals
174
testExitValue += doReExecTest("-a \\\"-b -c\\\" -d");
175
176
// Check for escaped quotes inside of quotes as literal
177
testExitValue += doReExecTest("-a \"-b \\\"stuff\\\"\" -c -d");
178
179
// A quote preceeded by an odd number of slashes is a literal quote
180
testExitValue += doReExecTest("-a -b\\\\\\\" -c -d");
181
182
// A quote preceeded by an even number of slashes is a literal quote
183
// see 6214916.
184
testExitValue += doReExecTest("-a -b\\\\\\\\\" -c -d");
185
186
// Make sure that whitespace doesn't interfere with the removal of the
187
// appropriate tokens. (space-tab-space preceeds -jre-restict-search).
188
testExitValue += doReExecTest("-a -b \t -jre-restrict-search -c -d", "-a -b -c -d");
189
190
// Make sure that the mJRE tokens being stripped, aren't stripped if
191
// they happen to appear as arguments to the main class.
192
testExitValue += doReExecTest("foo -version:1.1+");
193
194
System.out.println("Completed arguments quoting tests with "
195
+ testExitValue + " errors");
196
}
197
// the pattern we hope to see in the output
198
static final Pattern ArgPattern = Pattern.compile("\\s*argv\\[[0-9]*\\].*=.*");
199
200
void checkArgumentParsing(String inArgs, String... expArgs) throws IOException {
201
List<String> scratchpad = new ArrayList<>();
202
scratchpad.add("set " + JLDEBUG_KEY + "=true");
203
// GAK, -version needs to be added so that windows can flush its stderr
204
// exiting the process prematurely can terminate the stderr.
205
scratchpad.add(javaCmd + " -version " + inArgs);
206
File batFile = new File("atest.bat");
207
createAFile(batFile, scratchpad);
208
209
TestResult tr = doExec(batFile.getName());
210
211
ArrayList<String> expList = new ArrayList<>();
212
expList.add(javaCmd);
213
expList.add("-version");
214
expList.addAll(Arrays.asList(expArgs));
215
216
List<String> gotList = new ArrayList<>();
217
for (String x : tr.testOutput) {
218
Matcher m = ArgPattern.matcher(x);
219
if (m.matches()) {
220
String a[] = x.split("=");
221
gotList.add(a[a.length - 1].trim());
222
}
223
}
224
if (!gotList.equals(expList)) {
225
System.out.println(tr);
226
System.out.println("Expected args:");
227
System.out.println(expList);
228
System.out.println("Obtained args:");
229
System.out.println(gotList);
230
throw new RuntimeException("Error: args do not match");
231
}
232
System.out.println("\'" + inArgs + "\'" + " - Test passed");
233
}
234
235
/*
236
* This tests general quoting and are specific to Windows, *nixes
237
* need not worry about this, these have been tested with Windows
238
* implementation and those that are known to work are used against
239
* the java implementation. Note that the ProcessBuilder gets in the
240
* way when testing some of these arguments, therefore we need to
241
* create and execute a .bat file containing the arguments.
242
*/
243
@Test
244
void testArgumentParsing() throws IOException {
245
if (!isWindows)
246
return;
247
// no quotes
248
checkArgumentParsing("a b c d", "a", "b", "c", "d");
249
250
// single quotes
251
checkArgumentParsing("\"a b c d\"", "a b c d");
252
253
//double quotes
254
checkArgumentParsing("\"\"a b c d\"\"", "a", "b", "c", "d");
255
256
// triple quotes
257
checkArgumentParsing("\"\"\"a b c d\"\"\"", "\"a b c d\"");
258
259
// a literal within single quotes
260
checkArgumentParsing("\"a\"b c d\"e\"", "ab", "c", "de");
261
262
// a literal within double quotes
263
checkArgumentParsing("\"\"a\"b c d\"e\"\"", "ab c de");
264
265
// a literal quote
266
checkArgumentParsing("a\\\"b", "a\"b");
267
268
// double back-slash
269
checkArgumentParsing("\"a b c d\\\\\"", "a b c d\\");
270
271
// triple back-slash
272
checkArgumentParsing("a\\\\\\\"b", "a\\\"b");
273
274
// dangling quote
275
checkArgumentParsing("\"a b c\"\"", "a b c\"");
276
277
// expansions of white space separators
278
checkArgumentParsing("a b", "a", "b");
279
checkArgumentParsing("a\tb", "a", "b");
280
checkArgumentParsing("a \t b", "a", "b");
281
282
checkArgumentParsing("\"C:\\TEST A\\\\\"", "C:\\TEST A\\");
283
checkArgumentParsing("\"\"C:\\TEST A\\\\\"\"", "C:\\TEST", "A\\");
284
285
// MS Windows tests
286
// triple back-slash
287
checkArgumentParsing("a\\\\\\d", "a\\\\\\d");
288
289
// triple back-slash in quotes
290
checkArgumentParsing("\"a\\\\\\d\"", "a\\\\\\d");
291
292
// slashes separating characters
293
checkArgumentParsing("X\\Y\\Z", "X\\Y\\Z");
294
checkArgumentParsing("\\X\\Y\\Z", "\\X\\Y\\Z");
295
296
// literals within dangling quotes, etc.
297
checkArgumentParsing("\"a b c\" d e", "a b c", "d", "e");
298
checkArgumentParsing("\"ab\\\"c\" \"\\\\\" d", "ab\"c", "\\", "d");
299
checkArgumentParsing("a\\\\\\c d\"e f\"g h", "a\\\\\\c", "de fg", "h");
300
checkArgumentParsing("a\\\\\\\"b c d", "a\\\"b", "c", "d");
301
checkArgumentParsing("a\\\\\\\\\"g c\" d e", "a\\\\g c", "d", "e");
302
303
// treatment of back-slashes
304
checkArgumentParsing("*\\", "*\\");
305
checkArgumentParsing("*/", "*/");
306
checkArgumentParsing(".\\*", ".\\*");
307
checkArgumentParsing("./*", "./*");
308
checkArgumentParsing("..\\..\\*", "..\\..\\*");
309
checkArgumentParsing("../../*", "../../*");
310
checkArgumentParsing("..\\..\\", "..\\..\\");
311
checkArgumentParsing("../../", "../../");
312
checkArgumentParsing("a b\\ c", "a", "b\\", "c");
313
// 2 back-slashes
314
checkArgumentParsing("\\\\?", "\\\\?");
315
// 3 back-slashes
316
checkArgumentParsing("\\\\\\?", "\\\\\\?");
317
// 4 back-slashes
318
checkArgumentParsing("\\\\\\\\?", "\\\\\\\\?");
319
// 5 back-slashes
320
checkArgumentParsing("\\\\\\\\\\?", "\\\\\\\\\\?");
321
// 6 back-slashes
322
checkArgumentParsing("\\\\\\\\\\\\?", "\\\\\\\\\\\\?");
323
324
// more treatment of mixed slashes
325
checkArgumentParsing("f1/ f3\\ f4/", "f1/", "f3\\", "f4/");
326
checkArgumentParsing("f1/ f2\' ' f3/ f4/", "f1/", "f2\'", "'", "f3/", "f4/");
327
328
checkArgumentParsing("a\\*\\b", "a\\*\\b");
329
}
330
331
private void initEmptyDir(File emptyDir) throws IOException {
332
if (emptyDir.exists()) {
333
recursiveDelete(emptyDir);
334
}
335
emptyDir.mkdir();
336
}
337
338
private void initDirWithJavaFiles(File libDir) throws IOException {
339
340
if (libDir.exists()) {
341
recursiveDelete(libDir);
342
}
343
libDir.mkdirs();
344
ArrayList<String> scratchpad = new ArrayList<>();
345
scratchpad.add("package lib;");
346
scratchpad.add("public class Fbo {");
347
scratchpad.add("public static void main(String... args){Foo.f();}");
348
scratchpad.add("public static void f(){}");
349
scratchpad.add("}");
350
createFile(new File(libDir, "Fbo.java"), scratchpad);
351
352
scratchpad.clear();
353
scratchpad.add("package lib;");
354
scratchpad.add("public class Foo {");
355
scratchpad.add("public static void main(String... args){");
356
scratchpad.add("for (String x : args) {");
357
scratchpad.add("System.out.println(x);");
358
scratchpad.add("}");
359
scratchpad.add("Fbo.f();");
360
scratchpad.add("}");
361
scratchpad.add("public static void f(){}");
362
scratchpad.add("}");
363
createFile(new File(libDir, "Foo.java"), scratchpad);
364
}
365
366
void checkArgumentWildcard(String inArgs, String... expArgs) throws IOException {
367
String[] in = {inArgs};
368
checkArgumentWildcard(in, expArgs);
369
370
// now add arbitrary arguments before and after
371
String[] outInArgs = { "-Q", inArgs, "-R"};
372
373
String[] outExpArgs = new String[expArgs.length + 2];
374
outExpArgs[0] = "-Q";
375
System.arraycopy(expArgs, 0, outExpArgs, 1, expArgs.length);
376
outExpArgs[expArgs.length + 1] = "-R";
377
checkArgumentWildcard(outInArgs, outExpArgs);
378
}
379
380
void checkArgumentWildcard(String[] inArgs, String[] expArgs) throws IOException {
381
ArrayList<String> argList = new ArrayList<>();
382
argList.add(javaCmd);
383
argList.add("-cp");
384
argList.add("lib" + File.separator + "*");
385
argList.add("lib.Foo");
386
argList.addAll(Arrays.asList(inArgs));
387
String[] cmds = new String[argList.size()];
388
argList.toArray(cmds);
389
TestResult tr = doExec(cmds);
390
if (!tr.isOK()) {
391
System.out.println(tr);
392
throw new RuntimeException("Error: classpath single entry wildcard entry");
393
}
394
395
ArrayList<String> expList = new ArrayList<>();
396
expList.addAll(Arrays.asList(expArgs));
397
398
List<String> gotList = new ArrayList<>();
399
for (String x : tr.testOutput) {
400
gotList.add(x.trim());
401
}
402
if (!gotList.equals(expList)) {
403
System.out.println(tr);
404
System.out.println("Expected args:");
405
System.out.println(expList);
406
System.out.println("Obtained args:");
407
System.out.println(gotList);
408
throw new RuntimeException("Error: args do not match");
409
}
410
System.out.print("\'");
411
for (String x : inArgs) {
412
System.out.print(x + " ");
413
}
414
System.out.println("\'" + " - Test passed");
415
}
416
417
/*
418
* These tests are not expected to work on *nixes, and are ignored.
419
*/
420
@Test
421
void testWildCardArgumentProcessing() throws IOException {
422
if (!isWindows)
423
return;
424
File cwd = new File(".");
425
File libDir = new File(cwd, "lib");
426
initDirWithJavaFiles(libDir);
427
initEmptyDir(new File(cwd, "empty"));
428
429
// test if javac (the command) can compile *.java
430
TestResult tr = doExec(javacCmd, libDir.getName() + File.separator + "*.java");
431
if (!tr.isOK()) {
432
System.out.println(tr);
433
throw new RuntimeException("Error: compiling java wildcards");
434
}
435
436
// test if javac (the command) can compile *.java with a vmoption
437
tr = doExec(javacCmd, "-cp", ".",
438
"-J-showversion", "-J-Dsomeproperty=foo",
439
libDir.getName() + File.separator + "*.java");
440
if (!tr.isOK()) {
441
System.out.println(tr);
442
throw new RuntimeException("Error: compiling java wildcards with vmoptions");
443
}
444
445
446
// use the jar cmd to create jars using the ? wildcard
447
File jarFoo = new File(libDir, "Foo.jar");
448
tr = doExec(jarCmd, "cvf", jarFoo.getAbsolutePath(), "lib" + File.separator + "F?o.class");
449
if (!tr.isOK()) {
450
System.out.println(tr);
451
throw new RuntimeException("Error: creating jar with wildcards");
452
}
453
454
// now the litmus test!, this should work
455
checkArgumentWildcard("a", "a");
456
457
// test for basic expansion
458
checkArgumentWildcard("lib\\F*java", "lib\\Fbo.java", "lib\\Foo.java");
459
460
// basic expansion in quotes
461
checkArgumentWildcard("\"lib\\F*java\"", "lib\\F*java");
462
463
checkArgumentWildcard("lib\\**", "lib\\Fbo.class", "lib\\Fbo.java",
464
"lib\\Foo.class", "lib\\Foo.jar", "lib\\Foo.java");
465
466
checkArgumentWildcard("lib\\*?", "lib\\Fbo.class", "lib\\Fbo.java",
467
"lib\\Foo.class", "lib\\Foo.jar", "lib\\Foo.java");
468
469
checkArgumentWildcard("lib\\?*", "lib\\Fbo.class", "lib\\Fbo.java",
470
"lib\\Foo.class", "lib\\Foo.jar", "lib\\Foo.java");
471
472
checkArgumentWildcard("lib\\?", "lib\\?");
473
474
// test for basic expansion
475
checkArgumentWildcard("lib\\*java", "lib\\Fbo.java", "lib\\Foo.java");
476
477
// basic expansion in quotes
478
checkArgumentWildcard("\"lib\\*.java\"", "lib\\*.java");
479
480
// suffix expansion
481
checkArgumentWildcard("lib\\*.class", "lib\\Fbo.class", "lib\\Foo.class");
482
483
// suffix expansion in quotes
484
checkArgumentWildcard("\"lib\\*.class\"", "lib\\*.class");
485
486
// check for ? expansion now
487
checkArgumentWildcard("lib\\F?o.java", "lib\\Fbo.java", "lib\\Foo.java");
488
489
// check ? in quotes
490
checkArgumentWildcard("\"lib\\F?o.java\"", "lib\\F?o.java");
491
492
// check ? as suffixes
493
checkArgumentWildcard("lib\\F?o.????", "lib\\Fbo.java", "lib\\Foo.java");
494
495
// check ? in a leading role
496
checkArgumentWildcard("lib\\???.java", "lib\\Fbo.java", "lib\\Foo.java");
497
checkArgumentWildcard("\"lib\\???.java\"", "lib\\???.java");
498
499
// check ? prefixed with -
500
checkArgumentWildcard("-?", "-?");
501
502
// check * prefixed with -
503
checkArgumentWildcard("-*", "-*");
504
505
// check on empty directory
506
checkArgumentWildcard("empty\\*", "empty\\*");
507
checkArgumentWildcard("empty\\**", "empty\\**");
508
checkArgumentWildcard("empty\\?", "empty\\?");
509
checkArgumentWildcard("empty\\??", "empty\\??");
510
checkArgumentWildcard("empty\\*?", "empty\\*?");
511
checkArgumentWildcard("empty\\?*", "empty\\?*");
512
513
}
514
515
void doArgumentCheck(String inArgs, String... expArgs) {
516
Map<String, String> env = new HashMap<>();
517
env.put(JLDEBUG_KEY, "true");
518
TestResult tr = doExec(env, javaCmd, inArgs);
519
System.out.println(tr);
520
int sindex = tr.testOutput.indexOf("Command line args:");
521
if (sindex < 0) {
522
System.out.println(tr);
523
throw new RuntimeException("Error: no output");
524
}
525
sindex++; // skip over the tag
526
List<String> gotList = new ArrayList<>();
527
for (String x : tr.testOutput.subList(sindex, sindex + expArgs.length)) {
528
String a[] = x.split("=");
529
gotList.add(a[a.length - 1].trim());
530
}
531
List<String> expList = Arrays.asList(expArgs);
532
if (!gotList.equals(expList)) {
533
System.out.println(tr);
534
System.out.println("Expected args:");
535
System.out.println(expList);
536
System.out.println("Obtained args:");
537
System.out.println(gotList);
538
throw new RuntimeException("Error: args do not match");
539
}
540
}
541
542
543
/*
544
* These tests are usually run on non-existent targets to check error results
545
*/
546
@Test
547
void testBasicErrorMessages() {
548
// Tests for 5030233
549
TestResult tr = doExec(javaCmd, "-cp");
550
tr.checkNegative();
551
tr.isNotZeroOutput();
552
if (!tr.testStatus)
553
System.out.println(tr);
554
555
tr = doExec(javaCmd, "-classpath");
556
tr.checkNegative();
557
tr.isNotZeroOutput();
558
if (!tr.testStatus)
559
System.out.println(tr);
560
561
tr = doExec(javaCmd, "-jar");
562
tr.checkNegative();
563
tr.isNotZeroOutput();
564
if (!tr.testStatus)
565
System.out.println(tr);
566
567
tr = doExec(javacCmd, "-cp");
568
tr.checkNegative();
569
tr.isNotZeroOutput();
570
if (!tr.testStatus)
571
System.out.println(tr);
572
573
// Test for 6356475 "REGRESSION:"java -X" from cmdline fails"
574
tr = doExec(javaCmd, "-X");
575
tr.checkPositive();
576
tr.isNotZeroOutput();
577
if (!tr.testStatus)
578
System.out.println(tr);
579
580
tr = doExec(javaCmd, "-help");
581
tr.checkPositive();
582
tr.isNotZeroOutput();
583
if (!tr.testStatus)
584
System.out.println(tr);
585
586
// 6753938, test for non-negative exit value for an incorrectly formed
587
// command line, '% java'
588
tr = doExec(javaCmd);
589
tr.checkNegative();
590
tr.isNotZeroOutput();
591
if (!tr.testStatus)
592
System.out.println(tr);
593
594
// 6753938, test for non-negative exit value for an incorrectly formed
595
// command line, '% java -Xcomp'
596
tr = doExec(javaCmd, "-Xcomp");
597
tr.checkNegative();
598
tr.isNotZeroOutput();
599
if (!tr.testStatus)
600
System.out.println(tr);
601
602
// 7151434, test for non-negative exit value for an incorrectly formed
603
// command line, '% java -jar -W', note the bogus -W
604
tr = doExec(javaCmd, "-jar", "-W");
605
tr.checkNegative();
606
tr.contains("Unrecognized option: -W");
607
if (!tr.testStatus)
608
System.out.println(tr);
609
}
610
611
/*
612
* Tests various dispositions of the main method, these tests are limited
613
* to English locales as they check for error messages that are localized.
614
*/
615
@Test
616
void testMainMethod() throws FileNotFoundException {
617
if (!isEnglishLocale()) {
618
return;
619
}
620
621
TestResult tr = null;
622
623
// a missing class
624
createJar("MIA", new File("some.jar"), new File("Foo"),
625
(String[])null);
626
tr = doExec(javaCmd, "-jar", "some.jar");
627
tr.contains("Error: Could not find or load main class MIA");
628
if (!tr.testStatus)
629
System.out.println(tr);
630
// use classpath to check
631
tr = doExec(javaCmd, "-cp", "some.jar", "MIA");
632
tr.contains("Error: Could not find or load main class MIA");
633
if (!tr.testStatus)
634
System.out.println(tr);
635
636
// incorrect method access
637
createJar(new File("some.jar"), new File("Foo"),
638
"private static void main(String[] args){}");
639
tr = doExec(javaCmd, "-jar", "some.jar");
640
tr.contains("Error: Main method not found in class Foo");
641
if (!tr.testStatus)
642
System.out.println(tr);
643
// use classpath to check
644
tr = doExec(javaCmd, "-cp", "some.jar", "Foo");
645
tr.contains("Error: Main method not found in class Foo");
646
if (!tr.testStatus)
647
System.out.println(tr);
648
649
// incorrect return type
650
createJar(new File("some.jar"), new File("Foo"),
651
"public static int main(String[] args){return 1;}");
652
tr = doExec(javaCmd, "-jar", "some.jar");
653
tr.contains("Error: Main method must return a value of type void in class Foo");
654
if (!tr.testStatus)
655
System.out.println(tr);
656
// use classpath to check
657
tr = doExec(javaCmd, "-cp", "some.jar", "Foo");
658
tr.contains("Error: Main method must return a value of type void in class Foo");
659
if (!tr.testStatus)
660
System.out.println(tr);
661
662
// incorrect parameter type
663
createJar(new File("some.jar"), new File("Foo"),
664
"public static void main(Object[] args){}");
665
tr = doExec(javaCmd, "-jar", "some.jar");
666
tr.contains("Error: Main method not found in class Foo");
667
if (!tr.testStatus)
668
System.out.println(tr);
669
// use classpath to check
670
tr = doExec(javaCmd, "-cp", "some.jar", "Foo");
671
tr.contains("Error: Main method not found in class Foo");
672
if (!tr.testStatus)
673
System.out.println(tr);
674
675
// incorrect method type - non-static
676
createJar(new File("some.jar"), new File("Foo"),
677
"public void main(String[] args){}");
678
tr = doExec(javaCmd, "-jar", "some.jar");
679
tr.contains("Error: Main method is not static in class Foo");
680
if (!tr.testStatus)
681
System.out.println(tr);
682
// use classpath to check
683
tr = doExec(javaCmd, "-cp", "some.jar", "Foo");
684
tr.contains("Error: Main method is not static in class Foo");
685
if (!tr.testStatus)
686
System.out.println(tr);
687
688
// amongst a potpourri of kindred main methods, is the right one chosen ?
689
createJar(new File("some.jar"), new File("Foo"),
690
"void main(Object[] args){}",
691
"int main(Float[] args){return 1;}",
692
"private void main() {}",
693
"private static void main(int x) {}",
694
"public int main(int argc, String[] argv) {return 1;}",
695
"public static void main(String[] args) {System.out.println(\"THE_CHOSEN_ONE\");}");
696
tr = doExec(javaCmd, "-jar", "some.jar");
697
tr.contains("THE_CHOSEN_ONE");
698
if (!tr.testStatus)
699
System.out.println(tr);
700
// use classpath to check
701
tr = doExec(javaCmd, "-cp", "some.jar", "Foo");
702
tr.contains("THE_CHOSEN_ONE");
703
if (!tr.testStatus)
704
System.out.println(tr);
705
706
// test for extraneous whitespace in the Main-Class attribute
707
createJar(" Foo ", new File("some.jar"), new File("Foo"),
708
"public static void main(String... args){}");
709
tr = doExec(javaCmd, "-jar", "some.jar");
710
tr.checkPositive();
711
if (!tr.testStatus)
712
System.out.println(tr);
713
}
714
/*
715
* tests 6968053, ie. we turn on the -Xdiag (for now) flag and check if
716
* the suppressed stack traces are exposed, ignore these tests for localized
717
* locales, limiting to English only.
718
*/
719
@Test
720
void testDiagOptions() throws FileNotFoundException {
721
if (!isEnglishLocale()) { // only english version
722
return;
723
}
724
TestResult tr = null;
725
// a missing class
726
createJar("MIA", new File("some.jar"), new File("Foo"),
727
(String[])null);
728
tr = doExec(javaCmd, "-Xdiag", "-jar", "some.jar");
729
tr.contains("Error: Could not find or load main class MIA");
730
tr.contains("java.lang.ClassNotFoundException: MIA");
731
if (!tr.testStatus)
732
System.out.println(tr);
733
734
// use classpath to check
735
tr = doExec(javaCmd, "-Xdiag", "-cp", "some.jar", "MIA");
736
tr.contains("Error: Could not find or load main class MIA");
737
tr.contains("java.lang.ClassNotFoundException: MIA");
738
if (!tr.testStatus)
739
System.out.println(tr);
740
741
// a missing class on the classpath
742
tr = doExec(javaCmd, "-Xdiag", "NonExistentClass");
743
tr.contains("Error: Could not find or load main class NonExistentClass");
744
tr.contains("java.lang.ClassNotFoundException: NonExistentClass");
745
if (!tr.testStatus)
746
System.out.println(tr);
747
}
748
749
@Test
750
static void testJreRestrictSearchFlag() {
751
// test both arguments to ensure they exist
752
TestResult tr = null;
753
tr = doExec(javaCmd,
754
"-no-jre-restrict-search", "-version");
755
tr.checkPositive();
756
if (!tr.testStatus)
757
System.out.println(tr);
758
759
tr = doExec(javaCmd,
760
"-jre-restrict-search", "-version");
761
tr.checkPositive();
762
if (!tr.testStatus)
763
System.out.println(tr);
764
}
765
766
/**
767
* @param args the command line arguments
768
* @throws java.io.FileNotFoundException
769
*/
770
public static void main(String[] args) throws Exception {
771
if (debug) {
772
System.out.println("Starting Arrrghs tests");
773
}
774
Arrrghs a = new Arrrghs();
775
a.run(args);
776
if (testExitValue > 0) {
777
System.out.println("Total of " + testExitValue + " failed");
778
System.exit(1);
779
} else {
780
System.out.println("All tests pass");
781
}
782
}
783
}
784
785