System.out.println() の JUnit テスト 質問する

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());

ベストアンサー1

使用してバイト配列出力ストリーム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 の原因です。

おすすめ記事