인프런 커뮤니티 질문&답변

bae jewoo님의 프로필 이미지

작성한 질문수

실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발

회원 기능 테스트

테스트 트랜잭션 전파

작성

·

104

·

수정됨

0

[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)

[질문 내용]

중복_회원_예외() 테스트에서
@Rollback(false)를 적용하고 테스트를 돌리면
member1 & member2 모두 DB에 데이터가 들어가지 않는데

이유를 생각해 보면
테스트에서 시작하는 중복_회원_예외() 메서드에서 2번의 조인 모두 @Rollback 이랑 @Transactional 모두
1개의 물리 트랜잭션에 묶여 있는 것이고
1개의 논리 트랜잭션인 2번째 join이 실패하였으니
첫 번째 논리 트랜잭션은
@Rollback(false)이지만 해당 물리 트랜잭션이 실패 판정되어서 모두 롤백 되는 거겠죠?

서비스 레벨에서 join()을 Propagation.REQUIRES_NEW를 통해 신규 물리 트랜잭션을 만드니까 예상대로 member1만 DB에 적용됩니다

정리하면 테스트에서 붙이는 트랜잭션 또한 트랜잭션 전파 원리는 동일
테스트에 트랜잭션을 붙이면 추가적으로
@Rollback(true)가 default로 붙는데 이 또한 같이 같은 원리로 전파된다가 맞을까요?






답변 1

1

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

네, 맞습니다. 스프링에서 테스트 케이스에 @Transactional 어노테이션을 붙이면 기본적으로 해당 테스트 케이스는 하나의 트랜잭션 내에서 실행되며, 테스트가 끝나면 기본적으로 롤백(@Rollback(true))이 실행됩니다. 이는 테스트 간에 서로 영향을 주지 않기 위해 도입된 메커니즘입니다.

@Rollback(false)로 설정하면 테스트 후에도 데이터가 롤백되지 않고 DB에 남아있어야 합니다만, 여러분이 언급한대로 트랜잭션 전파 특성으로 인해 다른 트랜잭션의 영향을 받을 수 있습니다. 예를 들어, Propagation.REQUIRED는 기본 설정으로, 이미 진행 중인 트랜잭션이 있으면 그 트랜잭션에 참여하게 됩니다. 따라서 첫 번째 트랜잭션에서 롤백이 결정되면, 이 후의 모든 작업이 롤백됩니다.

서비스 레벨에서 Propagation.REQUIRES_NEW를 사용해 명시적으로 새로운 물리 트랜잭션을 시작한다면, 기존 트랜잭션과는 독립적으로 처리되어 하나의 트랜잭션이 실패하더라도 다른 트랜잭션에는 영향을 주지 않습니다. 그 결과로, 실패하지 않은 트랜잭션에 대한 결과는 DB에 반영되게 됩니다.

따라서 테스트에 트랜잭션을 붙이는 경우, 트랜잭션 전파 원리가 동일하게 적용되어 @Rollback(true)의 설정에 따라 테스트 후 롤백 처리가 됩니다. 다만, @Rollback(false)를 사용하더라도 다른 트랜잭션의 결과에 따라 최종적인 롤백 여부가 결정될 수 있음을 인지해야 합니다.