1. ホーム

[解決済み】System.out.println()のJUnitテスト)

2022-03-24 08:27:01

質問

古いアプリケーションの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();
private final PrintStream originalOut = System.out;
private final PrintStream originalErr = System.err;

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

@After
public void restoreStreams() {
    System.setOut(originalOut);
    System.setErr(originalErr);
}

サンプルテストケースです。

@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がバージョン文字列を出力することを保証する、などなど)。

編集する この回答の以前のバージョンでは System.setOut(null) これが、コメントで言われているNullPointerExceptionsの原因です。