mirror of
https://github.com/openjdk/jdk.git
synced 2026-02-21 07:45:11 +00:00
Add a few utility classes to test/testlibrary to support multi process testing in jtreg tests. Added a test case for one of the utility classes. Also reviewed by Vitaly Davidovich Reviewed-by: brutisso, dholmes, vlivanov, nloodin, mgerdin
192 lines
6.0 KiB
Java
192 lines
6.0 KiB
Java
/*
|
|
* 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 com.oracle.java.testlibrary;
|
|
|
|
import java.io.IOException;
|
|
|
|
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");
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 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;
|
|
}
|
|
}
|