конфигурация log4j для Maven для отображения журналов тестов

#maven #intellij-idea #junit #log4j #stdout

#maven #intellij-idea #junit #log4j #стандартный вывод

Вопрос:

Мы используем следующий log4j.xml файл конфигурации:

 <?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/" debug="false">
    <appender name="STDOUT" class="org.apache.log4j.ConsoleAppender">
        <param name="target" value="System.out"/>
        <layout class="org.apache.log4j.PatternLayout">
            <param name="conversionPattern" value="[%d{ISO8601}] %-5p [%c{1}]#[%t] %m %n"/>
        </layout>
    </appender>

    <category name="some.internal.enterprise.custom.library">
        <priority value="DEBUG"/>
    </category>

    <!-- Removing the useless logging of "Invalid JavaBean property" -->
    <logger name="org.springframework.beans.GenericTypeAwarePropertyDescriptor">
        <level value="ERROR"/>
    </logger>

    <logger name="org.springframework">
        <level value="WARN"/>
    </logger>

    <root>
        <priority value="INFO"/>
        <appender-ref ref="STDOUT"/>
    </root>

</log4j:configuration>
  

И мы настроили тестовый класс JUnit для ведения журнала таким образом:

 import org.apache.log4j.LogManager;
import org.apache.log4j.Logger;
// more imports...

@RunWith(JUnitParamsRunner.class)
@ContextConfiguration(locations = {ProxyConfiguration.SPRING_CONTEXT_CONFIGURATION_LOCATIONS})
@Category(Integration.class)
@FixMethodOrder(MethodSorters.JVM)
public class MyTest {
    private final Logger log = LogManager.getLogger(MyTest.class);

    @Test
    public void test() {
        log.info("Blah blah");
    }
}
  

Я бы ожидал, что Maven Console Output отобразит этот журнал, но это не так. Тем не менее, он появляется, когда я запускаю тест локально в IntelliJ с конфигурацией запуска типа JUnit .

Что я должен сделать, чтобы мои журналы отображались в Console Output ?

В ответах, которые я нахожу в Интернете, упоминается, что я хочу видеть ведение журнала, даже когда тесты завершаются успешно: это также было бы моим требованием. Однако их вопросы подразумевали, что он уже регистрировался, когда их тесты терпели неудачу, но это не то, что здесь происходит. Единственное, что я получаю из своего теста, — это трассировка стека при возникновении исключения.

Ответ №1:

Коллега заставил меня понять, что журналы выводятся target/surefire-reports/my.package.TestClassName-output.txt .

Оказывается redirectTestOutputToFile , для нашего флага maven-surefire-plugin было установлено значение true . Я узнал об этом, прочитав вывод mvn clean verify --debug .

Таким pom.xml образом, в конечном итоге выглядит примерно так (я удалил целую кучу ненужных вещей):

 <project>
    <properties>
        <slf4j.version>1.7.28</slf4j.version>
    </properties>

    <dependencies>
        <!-- Make sure you exclude any conflicting versions from your other dependencies -->
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-log4j12</artifactId>
            <version>${slf4j.version}</version>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-api</artifactId>
            <version>${slf4j.version}</version>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-surefire-plugin</artifactId>
                <configuration>
                    <redirectTestOutputToFile>${logToFile}</redirectTestOutputToFile>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>
  

И теперь вы можете использовать logToFile аргумент JVM для управления тем, куда идет ведение журнала. Если не указывать какое-либо значение для этой переменной, оно будет иметь значение по умолчанию false , чего мы и хотели. В качестве альтернативы у нас есть возможность вывода в файл отчета mvn clean verify -DlogToFile=true .

Документация, касающаяся флагов surefire, есть: https://maven.apache.org/surefire/maven-surefire-plugin/test-mojo.html#redirectTestOutputToFile