System.out.println()的JUnit测试

问题:

我需要为设计不佳的旧应用程序编写JUnit测试,并且将大量错误消息写入标准输出。当getResponse(String request)方法行为正确时,它返回一个XML响应:

@BeforeClass
public static void setUpClass() throws Exception {
    Properties queries = loadPropertiesFile("requests.properties");
    Properties responses = loadPropertiesFile("responses.properties");
    instance = new ResponseGenerator(queries, responses);
}

@Test
public void testGetResponse() {
    String request = "<some>request</some>";
    String expResult = "<some>response</some>";
    String result = instance.getResponse(request);
    assertEquals(expResult, result);
}

但是,当它收到格式不正确的XML或者不了解请求时,返回null并将一些东西写入标准输出。
有没有办法在JUnit中声明控制台输出?抓住这样的情况:

System.out.println("match found: " + strExpr);
System.out.println("xml not well formed: " + e.getMessage());

回答:

使用ByteArrayOutputStream和System.setXXX很简单:

private final ByteArrayOutputStream outContent = new ByteArrayOutputStream();
private final ByteArrayOutputStream errContent = new ByteArrayOutputStream();

@Before
public void setUpStreams() {
    System.setOut(new PrintStream(outContent));
    System.setErr(new PrintStream(errContent));
}

@After
public void cleanUpStreams() {
    System.setOut(null);
    System.setErr(null);
}

样本测试用例:

@Test
public void out() {
    System.out.print("hello");
    assertEquals("hello", outContent.toString());
}

@Test
public void err() {
    System.err.print("hello again");
    assertEquals("hello again", errContent.toString());
}

我使用这个代码测试命令行选项(断言-version输出版本字符串等)

 
 
Code问答: http://codewenda.com/topics/python/
Stackoverflow: JUnit test for System.out.println()

*转载请注明本文链接以及stackoverflow的英文链接

发表评论

电子邮件地址不会被公开。 必填项已用*标注

45 − 41 =