inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

토비의 스프링 부트 - 이해와 원리

스프링 부트의 자동 구성과 테스트로 전환

DataSourceTest 테스트 실행 시 transaction 로그가 출력되지 않는 문제

해결된 질문

561

jiun koo

작성한 질문수 2

0

 1. 문제

DataSourceTest 테스트 실행 시 transaction 로그가 출력되지 않음

INFO o.s.t.c.transaction.TransactionContext : Began transaction (1) for...(생략)
INFO o.s.t.c.transaction.TransactionContext : Rolled back transaction for...(생략)

 

2. 강의 정보

 

3. 내 프로젝트 상태

repositories {
	mavenCentral()
	maven {
		url 'https://repo.clojars.org'
		name 'Clojars'
	}
}

dependencies {
	implementation ('org.springframework.boot:spring-boot-starter-web')
	implementation 'org.springframework:spring-jdbc'
	runtimeOnly('com.h2database:h2:2.2.220')
	implementation 'hikari-cp:hikari-cp:3.0.1'

	testImplementation 'org.springframework.boot:spring-boot-starter-test'
}
@JdbcTest
public class DataSourceTest {

	@Autowired
	DataSource dataSource;

	@Test
	void connect() throws SQLException {
		Connection connection = dataSource.getConnection();
		connection.close();
	}
}

 

4. 해결 과정

application.properties에 로그 단계를 정의

logging.level.ROOT=DEBUG
logging.level.org.springframework.transaction=DEBUG

 

5. 결과

단계를 DEBUG -> TRACE로 다양하게 바꾸고 테스트를 실행했으나 transaction은 출력되지 않음

 

6. 질문

  1. 강의 중간에 로깅 단계를 바꾸는 작업이 있었는데 제가 그 부분을 놓친 것인지

  2. 스프링 부트의 버전이 올라가며 transaction 로그를 출력하지 않도록 바뀐 것인지

  3. 아니면 다른 방식으로 접근해야 하는 것인지

궁금합니다!

spring spring-boot spring-jdbc

답변 2

0

토비

JDBC 자동 구성에 트랜잭션 매니저가 등록되기는 할텐데요. 그게 사용되어서 트랜잭션이 관리되고 로그가 남으려면 트랜잭션 경계설정(서비스 클래스에 붙이는 @Transactional 등의 적용)이 필요합니다. @JdbcTest를 붙였다고 해서 자동으로 트랜잭션 시작과 종료를 해주지 않을 겁니다.

게다가 DataSourceTest는 DB를 사용하는 기능이 전혀 없어서 트랜잭션이 만들어질 이유가 없네요.

이번 강의는 DB 기술을 다루는 게 목적은 아니어서 트랜잭션 관련 부분은 따로 언급하거나 설명드리지 않았습니다. 자동 구성에 의해서 만들어지는 트랜잭션 매니저의 동작을 확인해보고 싶으시면 DB 기능이 사용되도록 코드를 만들고 테스트든 애플리케이션 코드에서든 트랜잭션이 시작되도록 명시적인 설정을 넣어주셔야 합니다.

 

내년에 JPA를 비롯한 스프링 부트에서 지원하는 데이터 액세스 기술을 다루는 강의를 기획하고 있는데, 그때 좀 더 자세히 설명드려보겠습니다.

0

jiun koo

아하~친절한 답변 감사합니다!
열심히 공부하며 강의 기다리겠습니다!

 

+) 스프링 강의도 제작할 예정이라는 답변을 봤었는데...계획이 있으신가요?

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다.

질문하신 부분과 관련하여 트랜잭션 로그가 출력되지 않는 문제를 다룬 비슷한 질문과 강사님의 답변이 있어 공유드립니다. DataSourceConfig에서 @EnableTransactionManagement를 사용하면 DataSourceTest가 실행되지 않는 문제에 대한 질문에서, 트랜잭션과 관련하여 강사님의 답변이 도움이 될 것 같습니다.

강의를 들으시면서 로깅 단계를 변경하는 부분을 놓치지 않으셨는지 확인해보시고, 스프링 부트 버전의 변경으로 트랜잭션 로그 출력 설정에 변화가 생겼는지에 대해 알아보시려면 아래 강사님의 답변 참조가 도움이 될 수 있습니다.

감사합니다.

11강에서 cmd에서 spring shell에 $ init 하면 Fail 메세지

0

75

2

TestRestTemplate 을 통해 테스트 실행시 웹 요청 정보가 콘솔에 표시되지 않습니다.

0

85

1

섹션7. 자동구성 정보파일분리 강의 질문(@MyAutoConfiguration 붙힌 이유)

0

201

2

WebApplicationContext를 DispatcherServlet에 this로 넘기는 것

0

279

2

인프라 빈 구성 정보의 분리에서 EnableMyAutoConfiguration 질문드립니다.

0

210

2

질문드립니다.

0

232

2

spring boot 3.3.7로 학습중입니다.

0

369

2

Serverproperties 객체 생성 후 @Impor 어노테이션 사용 이유 용도

0

162

2

spring start io 에서 이제더이상 2.x버전은 지원하지 않는 것 같습니다.

1

295

2

Springboot 3.2 이상에서 파라미터 추론관련

0

913

4

binding error

0

220

3

Arrays.copyOf 메서드의 타입 세이프

1

155

2

MyOnClassCondition에 있는 matches method의 Invoke 횟수

1

233

3

인용구의 출처가 궁금합니다.

0

259

1

프로퍼티 빈의 후처리기 도입 AnnotationUtils의 사용

0

236

2

SimpleCacheConfiguration과 빈 등록

0

168

2

MyAutoConfigImportSelector 에서 생성자로 ClassLoader를 주입받을 수 있는 점

0

244

1

IntelliJ project jenerator spring initailizr

0

150

1

강의 자료 레퍼지토리에 업로드

0

216

1

강의자료

0

388

1

Hikari 라이브러리가 없으면 오류가 나는거 아닌가요

0

314

2

Tomcat 포트 프로퍼티 미설정시 랜덤 포트 설정 문의

0

476

5

@Import 로 Bean을 등록해야하는 기준이 뭔지 궁금합니다.

0

340

2

application.properties파일내 프로퍼티 이름

0

210

1