/*
* 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.*;
/**
* 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() {
return err;
}
/**
* 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);
}
}
}
}