設計が不十分で標準出力に大量のエラー メッセージを書き込む古いアプリケーションに対して 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 の原因です。