Rev 2306 |
Blame |
Compare with Previous |
Last modification |
View Log
| RSS feed
/*
* Copyright (C) 2008 Steve Ratcliffe
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation.
*
* This program 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 for more details.
*
*
* Author: Steve Ratcliffe
* Create date: 11-Jan-2009
*/
package func.lib;
import static org.junit.Assert.assertEquals;
import java.util.Arrays;
import java.util.stream.Collectors;
/**
* Standard output and error as produced during a run.
*
* @author Steve Ratcliffe
*/
public class Outputs
{
private final String out
;
private final String err
;
public Outputs
(String out,
String err
) {
this.
out = out
;
this.
err = err
;
}
protected String getOut
() {
return out
;
}
protected String getErr
() {
// filter possible lines added by set JRE option _JAVA_OPTIONS=... which cases
// a line "Picked up _JAVA_OPTIONS:" in stderr
return Arrays.
stream(err.
split("\n"))
.
filter(line -
> !line.
contains("_JAVA_OPTIONS"))
.
collect(Collectors.
joining("\n"));
}
/**
* Check that the standard error is empty.
*/
public void checkNoError
() {
assertEquals
("no error output",
"", getErr
());
}
/**
* Check that the output contains the given strings. You can specify
* any number of strings.
* @param strings The list of strings to check.
*/
public void checkOutput
(String...
strings) {
String out = getOut
();
for (String s : strings
) {
if (!out.
contains(s
)) {
// Test has failed. Construct an assertion that will print
// something that is useful to show the problem.
assertEquals
("contains '" + s +
"'",
"..." + s +
"...",
out
);
}
}
}
/**
* Check that the output contains the given strings. You can specify
* any number of strings.
* @param strings The list of strings to check.
*/
public void checkError
(String...
strings) {
String err = getErr
();
for (String s : strings
) {
if (!err.
contains(s
)) {
// Test has failed. Construct an assertion that will print
// something that is useful to show the problem.
assertEquals
("contains '" + s +
"'",
"..." + s +
"...",
err
);
}
}
}
}