/* * 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. */ package jdk.testlibrary; import java.io.IOException; import java.util.regex.Matcher; import java.util.regex.Pattern; public final class OutputAnalyzer { private final String stdout; private final String stderr; private final int exitValue; /** * Create an OutputAnalyzer, a utility class for verifying output and exit * value from a Process * * @param process * Process to analyze * @throws IOException * If an I/O error occurs. */ public OutputAnalyzer(Process process) throws IOException { OutputBuffer output = ProcessTools.getOutput(process); exitValue = process.exitValue(); this.stdout = output.getStdout(); this.stderr = output.getStderr(); } /** * Create an OutputAnalyzer, a utility class for verifying output * * @param buf * String buffer to analyze */ public OutputAnalyzer(String buf) { this(buf, buf); } /** * Create an OutputAnalyzer, a utility class for verifying output * * @param stdout * stdout buffer to analyze * @param stderr * stderr buffer to analyze */ public OutputAnalyzer(String stdout, String stderr) { this.stdout = stdout; this.stderr = stderr; exitValue = -1; } /** * Verify that the stdout and stderr contents of output buffer contains the * string * * @param expectedString * String that buffer should contain * @throws RuntimeException * If the string was not found */ public void shouldContain(String expectedString) { if (!stdout.contains(expectedString) && !stderr.contains(expectedString)) { throw new RuntimeException("'" + expectedString + "' missing from stdout/stderr: [" + stdout + stderr + "]\n"); } } /** * Verify that the stdout contents of output buffer contains the string * * @param expectedString * String that buffer should contain * @throws RuntimeException * If the string was not found */ public void stdoutShouldContain(String expectedString) { if (!stdout.contains(expectedString)) { throw new RuntimeException("'" + expectedString + "' missing from stdout: [" + stdout + "]\n"); } } /** * Verify that the stderr contents of output buffer contains the string * * @param expectedString * String that buffer should contain * @throws RuntimeException * If the string was not found */ public void stderrShouldContain(String expectedString) { if (!stderr.contains(expectedString)) { throw new RuntimeException("'" + expectedString + "' missing from stderr: [" + stderr + "]\n"); } } /** * Verify that the stdout and stderr contents of output buffer does not * contain the string * * @param expectedString * String that the buffer should not contain * @throws RuntimeException * If the string was found */ public void shouldNotContain(String notExpectedString) { if (stdout.contains(notExpectedString)) { throw new RuntimeException("'" + notExpectedString + "' found in stdout: [" + stdout + "]\n"); } if (stderr.contains(notExpectedString)) { throw new RuntimeException("'" + notExpectedString + "' found in stderr: [" + stderr + "]\n"); } } /** * Verify that the stdout contents of output buffer does not contain the * string * * @param expectedString * String that the buffer should not contain * @throws RuntimeException * If the string was found */ public void stdoutShouldNotContain(String notExpectedString) { if (stdout.contains(notExpectedString)) { throw new RuntimeException("'" + notExpectedString + "' found in stdout: [" + stdout + "]\n"); } } /** * Verify that the stderr contents of output buffer does not contain the * string * * @param expectedString * String that the buffer should not contain * @throws RuntimeException * If the string was found */ public void stderrShouldNotContain(String notExpectedString) { if (stderr.contains(notExpectedString)) { throw new RuntimeException("'" + notExpectedString + "' found in stderr: [" + stderr + "]\n"); } } /** * Verify that the stdout and stderr contents of output buffer matches * the pattern * * @param pattern * @throws RuntimeException If the pattern was not found */ public void shouldMatch(String pattern) { Matcher stdoutMatcher = Pattern.compile(pattern, Pattern.MULTILINE).matcher(stdout); Matcher stderrMatcher = Pattern.compile(pattern, Pattern.MULTILINE).matcher(stderr); if (!stdoutMatcher.find() && !stderrMatcher.find()) { throw new RuntimeException("'" + pattern + "' missing from stdout/stderr: [" + stdout + stderr + "]\n"); } } /** * Verify that the stdout contents of output buffer matches the * pattern * * @param pattern * @throws RuntimeException If the pattern was not found */ public void stdoutShouldMatch(String pattern) { Matcher matcher = Pattern.compile(pattern, Pattern.MULTILINE).matcher(stdout); if (!matcher.find()) { throw new RuntimeException("'" + pattern + "' missing from stdout: [" + stdout + "]\n"); } } /** * Verify that the stderr contents of output buffer matches the * pattern * * @param pattern * @throws RuntimeException If the pattern was not found */ public void stderrShouldMatch(String pattern) { Matcher matcher = Pattern.compile(pattern, Pattern.MULTILINE).matcher(stderr); if (!matcher.find()) { throw new RuntimeException("'" + pattern + "' missing from stderr: [" + stderr + "]\n"); } } /** * Verify that the stdout and stderr contents of output buffer does not * match the pattern * * @param pattern * @throws RuntimeException If the pattern was found */ public void shouldNotMatch(String pattern) { Matcher matcher = Pattern.compile(pattern, Pattern.MULTILINE).matcher(stdout); if (matcher.find()) { throw new RuntimeException("'" + pattern + "' found in stdout: [" + stdout + "]\n"); } matcher = Pattern.compile(pattern, Pattern.MULTILINE).matcher(stderr); if (matcher.find()) { throw new RuntimeException("'" + pattern + "' found in stderr: [" + stderr + "]\n"); } } /** * Verify that the stdout contents of output buffer does not match the * pattern * * @param pattern * @throws RuntimeException If the pattern was found */ public void stdoutShouldNotMatch(String pattern) { Matcher matcher = Pattern.compile(pattern, Pattern.MULTILINE).matcher(stdout); if (matcher.find()) { throw new RuntimeException("'" + pattern + "' found in stdout: [" + stdout + "]\n"); } } /** * Verify that the stderr contents of output buffer does not match the * pattern * * @param pattern * @throws RuntimeException If the pattern was found */ public void stderrShouldNotMatch(String pattern) { Matcher matcher = Pattern.compile(pattern, Pattern.MULTILINE).matcher(stderr); if (matcher.find()) { throw new RuntimeException("'" + pattern + "' found in stderr: [" + stderr + "]\n"); } } /** * Verifiy the exit value of the process * * @param expectedExitValue * Expected exit value from process * @throws RuntimeException * If the exit value from the process did not match the expected * value */ public void shouldHaveExitValue(int expectedExitValue) { if (getExitValue() != expectedExitValue) { throw new RuntimeException("Exit value " + getExitValue() + " , expected to get " + expectedExitValue); } } /** * Get the contents of the output buffer (stdout and stderr) * * @return Content of the output buffer */ public String getOutput() { return stdout + stderr; } /** * Get the contents of the stdout buffer * * @return Content of the stdout buffer */ public String getStdout() { return stdout; } /** * Get the contents of the stderr buffer * * @return Content of the stderr buffer */ public String getStderr() { return stderr; } /** * Get the process exit value * * @return Process exit value */ public int getExitValue() { return exitValue; } }