Утверждение правильного вывода консоли в JUnit

Я пытаюсь написать базовое руководство по JUnit и демонстрирую это на простом примере Hello World с использованием базового сервисного уровня. Моя проблема в том, что, хотя выходные данные теста совпадают с моими контрольными данными, assertEquals по-прежнему возвращает false. Можете ли вы объяснить, почему assertEquals не работает, и показать, как я могу это исправить?

Ошибка JUnit

org.junit.ComparisonFailure: expected:<Hello World[]> but was:<Hello World[
]>

И мой тестовый образец кода

package com.springtutorial.mavenhelloworld.service;

import static org.junit.Assert.*;

import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Rule;
import org.junit.Test;
import org.junit.contrib.java.lang.system.StandardOutputStreamLog;

import com.springtutorial.junitandmavenhelloworld.service.HelloWorldMessage;
import com.springtutorial.junitandmavenhelloworld.service.HelloWorldMessageImplementation;
import com.springtutorial.junitandmavenhelloworld.service.HelloWorldMessageService;
import com.springtutorial.junitandmavenhelloworld.service.HelloWorldMessageServiceImplementation;

public class HelloWorldMessageServiceImplementationTest
{
    static String controlMessageContent;
    static HelloWorldMessage controlMessage;

    HelloWorldMessage testMessage;
    HelloWorldMessageService testMessageService;

    @Rule
    public final StandardOutputStreamLog testLog = new StandardOutputStreamLog();

    @BeforeClass
    public static void setUpBeforeClass() throws Exception
    {
    controlMessageContent = new String("Hello World");
    controlMessage = new HelloWorldMessageImplementation(controlMessageContent);
    }

    @Before
    public void setUp() throws Exception
    {
    testMessage = new HelloWorldMessageImplementation("Hello World");
    testMessageService = new HelloWorldMessageServiceImplementation(testMessage);
    }

    @Test
    public void testGetMessage()
    {
    assertEquals(testMessage, testMessageService.getMessage());
    }

    @Test
    public void testSetMessage()
    {
    testMessageService.setMessage(new HelloWorldMessageImplementation("Test Message"));
    assertEquals("Test Message", testMessageService.getMessage().getMessageAsString());
    }

    @Test
    public void testPrintMessageToConsole()
    {
    testMessageService.printMessageToConsole();
    assertEquals(controlMessageContent, testLog.getLog());
    }
}

Мой код реализации HelloWorldMessageServiceImplementation

package com.springtutorial.junitandmavenhelloworld.service;

public class HelloWorldMessageServiceImplementation implements
    HelloWorldMessageService
{
    HelloWorldMessage message;

    public HelloWorldMessageServiceImplementation(HelloWorldMessage newMessage)
    {
    super();
    this.setMessage(newMessage);
    }

    public HelloWorldMessage getMessage()
    {
    return this.message;
    }

    public void setMessage(HelloWorldMessage newMessage)
    {
    this.message = newMessage;
    }

    public void printMessageToConsole()
    {
    System.out.println(this.message.getMessageAsString());
    }

}

person cyotee doge    schedule 21.03.2013    source источник


Ответы (1)


Проблема заключается в использовании println() в классе HelloWorldMessageServiceImplemenation. Эта функция добавляет в конец строки символ возврата каретки \n, из-за чего выходные данные не совпадают с управляющими данными. Либо измените это на метод print(), либо добавьте возврат каретки в конец тестовой строки.

Ниже приведен правильный способ добавления возврата каретки к контрольным данным тестирования.

controlMessageContent = new String("Hello World\n");
person cyotee doge    schedule 21.03.2013