JUnit에서 로그 메시지를 어설션하는 방법은 무엇입니까?
JUnit에서 로그 메시지를 확인하는 방법
소개:
외부와 통신하는 코드 동작 테스트 시스템에는 생성된 메시지의 내용과 형식을 확인하는 작업이 포함되는 경우가 많습니다. Java에서 로깅은 이러한 메시지를 기록하는 일반적인 방법입니다. 이 문서에서는 JUnit 프레임워크를 사용하여 로그 항목에 대해 단위 테스트를 수행하는 방법을 살펴봅니다.
로그 메시지에 대한 JUnit 어설션:
질문에 제공된 코드 조각은 다음을 주장하는 것을 목표로 합니다. 특정 수준(예: INFO) 및 메시지("x 발생")가 있는 특정 로그 항목이 테스트 중인 코드에 의해 생성되었습니다. 이를 달성하려면 로그 이벤트를 가로채서 저장하는 사용자 정의 로거 또는 핸들러를 사용할 수 있습니다.
사용자 정의 로거/핸들러 접근 방식:
이 접근 방식을 사용하려면 특수 로거를 생성해야 합니다. 또는 로깅 이벤트를 캡처하는 핸들러. 그러면 테스트 중인 코드의 로그 문이 이 사용자 정의 로거로 전달되어 기록된 메시지를 검색하고 검사할 수 있습니다. 그러나 이 접근 방식은 구현하기가 복잡할 수 있으며 테스트 중인 코드를 수정해야 합니다.
로그 수집기 패턴:
보다 편리한 솔루션은 다음과 같은 사용자 정의 어펜더를 사용하는 것입니다. 컬렉션이나 목록에 로깅 이벤트를 기록합니다. 이를 달성할 수 있는 방법은 다음과 같습니다.
-
Appender 만들기:
appender() 메서드를 재정의하여 로깅 이벤트를 데이터 구조에 저장하는 사용자 정의 Appender 하위 클래스를 구현합니다( 예: 목록). -
Logger에 Appender 추가:
원하는 로거에 사용자 정의 Appender 인스턴스를 추가합니다. 이 단계는 테스트 메서드 내에서 수행하거나 @Before 및 @After와 같은 주석을 사용하여 수행할 수 있습니다. -
메시지 어설션 로깅:
테스트 중인 코드를 실행한 후 로그된 메시지 목록을 검색합니다. Appender의 이벤트. 그런 다음 제공된 코드 조각에 설명된 대로 JUnit의 어설션 메서드를 사용하여 로그 항목의 수준, 메시지 및 기타 속성을 확인할 수 있습니다.
샘플 구현:
다음 샘플 코드는 로그 수집기 패턴을 보여줍니다.
<code class="java">import org.apache.log4j.AppenderSkeleton; import org.apache.log4j.Level; import org.apache.log4j.Logger; import org.junit.Test; import java.util.ArrayList; import java.util.List; import static org.junit.Assert.assertThat; import static org.hamcrest.CoreMatchers.is; public class LogCollectorTest { @Test public void testLogMessage() { // Create a custom appender to collect logging events. final TestAppender appender = new TestAppender(); // Add the appender to the logger we wish to test. final Logger logger = Logger.getLogger(LogCollectorTest.class); logger.addAppender(appender); // Execute code under test. logger.info("Test"); // Retrieve the list of logged events. final List<LoggingEvent> logs = appender.getLog(); // Perform assertions on the first log entry. assertThat(logs.get(0).getLevel(), is(Level.INFO)); assertThat(logs.get(0).getMessage(), is("Test")); } private static class TestAppender extends AppenderSkeleton { private final List<LoggingEvent> log = new ArrayList<>(); @Override public boolean requiresLayout() { return false; } @Override protected void append(LoggingEvent loggingEvent) { log.add(loggingEvent); } @Override public void close() { } public List<LoggingEvent> getLog() { return new ArrayList<>(log); } } }</code>
결론:
로그 수집기 패턴은 재사용 가능하고 편리한 어설션 방법을 제공합니다. JUnit 테스트의 로그 메시지. 기록된 이벤트를 데이터 구조로 캡처하면 해당 내용과 형식을 쉽게 확인하여 코드와 로깅 시스템의 상호 작용의 정확성을 보장할 수 있습니다.
위 내용은 JUnit에서 로그 메시지를 어설션하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

일부 애플리케이션이 제대로 작동하지 않는 회사의 보안 소프트웨어에 대한 문제 해결 및 솔루션. 많은 회사들이 내부 네트워크 보안을 보장하기 위해 보안 소프트웨어를 배포 할 것입니다. ...

많은 응용 프로그램 시나리오에서 정렬을 구현하기 위해 이름으로 이름을 변환하는 솔루션, 사용자는 그룹으로, 특히 하나로 분류해야 할 수도 있습니다.

시스템 도킹의 필드 매핑 처리 시스템 도킹을 수행 할 때 어려운 문제가 발생합니다. 시스템의 인터페이스 필드를 효과적으로 매핑하는 방법 ...

데이터베이스 작업에 MyBatis-Plus 또는 기타 ORM 프레임 워크를 사용하는 경우 엔티티 클래스의 속성 이름을 기반으로 쿼리 조건을 구성해야합니다. 매번 수동으로 ...

IntellijideAultimate 버전을 사용하여 봄을 시작하십시오 ...

Java 객체 및 배열의 변환 : 캐스트 유형 변환의 위험과 올바른 방법에 대한 심층적 인 논의 많은 Java 초보자가 객체를 배열로 변환 할 것입니다 ...

전자 상거래 플랫폼에서 SKU 및 SPU 테이블의 디자인에 대한 자세한 설명이 기사는 전자 상거래 플랫폼에서 SKU 및 SPU의 데이터베이스 설계 문제, 특히 사용자 정의 판매를 처리하는 방법에 대해 논의 할 것입니다 ...

Redis 캐싱 솔루션은 제품 순위 목록의 요구 사항을 어떻게 인식합니까? 개발 과정에서 우리는 종종 a ... 표시와 같은 순위의 요구 사항을 처리해야합니다.
