From 5cd79594c5e300abb101b5dc4682337bd5958a9b Mon Sep 17 00:00:00 2001 From: Andrey Nazarov Date: Thu, 5 Apr 2018 17:04:16 -0700 Subject: [PATCH] 8196750: [Testbug] tools/launcher tests need to tolerate unrelated warnings Reviewed-by: ksrini, dholmes --- test/jdk/tools/launcher/InfoStreams.java | 30 ++++++++++++++---------- test/jdk/tools/launcher/ToolsOpts.java | 22 +++++++++++------ 2 files changed, 33 insertions(+), 19 deletions(-) diff --git a/test/jdk/tools/launcher/InfoStreams.java b/test/jdk/tools/launcher/InfoStreams.java index dc0e2da00b9..3102d91336b 100644 --- a/test/jdk/tools/launcher/InfoStreams.java +++ b/test/jdk/tools/launcher/InfoStreams.java @@ -52,27 +52,33 @@ public class InfoStreams { String classPath = System.getProperty("java.class.path"); - run("-help").stderrShouldMatch(USAGE).stdoutShouldNotMatch("."); - run("--help").stdoutShouldMatch(USAGE).stderrShouldNotMatch("."); + run("-help").stderrShouldMatch(USAGE).stdoutShouldNotMatch(USAGE); + run("--help").stdoutShouldMatch(USAGE).stderrShouldNotMatch(USAGE); - run("-version").stderrShouldMatch(VERSION_ERR).stdoutShouldNotMatch("."); - run("--version").stdoutShouldMatch(VERSION_OUT).stderrShouldNotMatch("."); + run("-version").stderrShouldMatch(VERSION_ERR) + .stdoutShouldNotMatch(VERSION_ERR) + .stdoutShouldNotMatch(VERSION_OUT); + run("--version").stdoutShouldMatch(VERSION_OUT) + .stderrShouldNotMatch(VERSION_OUT) + .stderrShouldNotMatch(VERSION_ERR); run("-showversion", "--dry-run", "-cp", classPath, "InfoStreams") .stderrShouldMatch(VERSION_ERR) - .stdoutShouldNotMatch("."); + .stdoutShouldNotMatch(VERSION_ERR) + .stdoutShouldNotMatch(VERSION_OUT); run("--show-version", "--dry-run", "-cp", classPath, "InfoStreams") .stdoutShouldMatch(VERSION_OUT) - .stderrShouldNotMatch("."); + .stderrShouldNotMatch(VERSION_OUT) + .stderrShouldNotMatch(VERSION_ERR); run("-fullversion").stderrShouldMatch(FULLVERSION_ERR) - .stdoutShouldNotMatch("."); + .stdoutShouldNotMatch(FULLVERSION_ERR) + .stdoutShouldNotMatch(FULLVERSION_OUT); run("--full-version").stdoutShouldMatch(FULLVERSION_OUT) - .stderrShouldNotMatch("."); - - run("-X").stderrShouldMatch(NONSTD).stdoutShouldNotMatch("."); - run("--help-extra").stdoutShouldMatch(NONSTD).stderrShouldNotMatch("."); + .stderrShouldNotMatch(FULLVERSION_OUT) + .stderrShouldNotMatch(FULLVERSION_ERR); + run("-X").stderrShouldMatch(NONSTD).stdoutShouldNotMatch(NONSTD); + run("--help-extra").stdoutShouldMatch(NONSTD).stderrShouldNotMatch(NONSTD); } - } diff --git a/test/jdk/tools/launcher/ToolsOpts.java b/test/jdk/tools/launcher/ToolsOpts.java index 1a9ee7a9388..858ba89775b 100644 --- a/test/jdk/tools/launcher/ToolsOpts.java +++ b/test/jdk/tools/launcher/ToolsOpts.java @@ -184,7 +184,6 @@ public class ToolsOpts extends TestHelper { break; } - String[] output = tr.testOutput.toArray(new String[tr.testOutput.size()]); //-Joptions should not be passed to tool if (jpos > -1) { checkJoptionOutput(tr, arg); @@ -194,14 +193,23 @@ public class ToolsOpts extends TestHelper { + "CMD: " + cmdString); } } else { - //check that each non -J option was passed to tool. + // check that each non -J option was passed to tool. It looks for each arg in the output. + // Irrelevant lines in the output are skipped. Arguments order is checked as well. + int j = 0; + List output = tr.testOutput; for (int i = 0; i < arg.length; i++) { - if (output[i].compareTo(arg[i]) != 0) { + boolean found = false; + for (; j < output.size(); j++) { + if (output.get(j).equals(arg[i])) { + pass("check " + output.get(j) + " == " + arg[i]); + found = true; + break; + } + } + if (!found) { throw new RuntimeException( - "failed! CMD: " + cmdString + "\n case:" + - output[i] + " != " + arg[i]); - } else { - pass("check " + output[i] + " == " + arg[i]); + "failed! Should have passed non -J option [" + arg[i] + "] to tool.\n" + + "CMD: " + cmdString); } } }