inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

회원 기능 테스트

테스트 트랜잭션 전파

213

bae jewoo

작성한 질문수 20

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로 붙는데 이 또한 같이 같은 원리로 전파된다가 맞을까요?






java spring 웹앱 spring-boot jpa

답변 1

1

인프런 AI 인턴

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

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

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

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

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

OrderServiceTest 상문주문 테스트 시 update 쿼리 문의

0

27

1

sdk 설정 오류

0

68

2

오탈자 - @Transactional

0

63

1

src/test/resources 테스트 경로 문제

0

60

1

상품 등록후 H2 db 출력 순서 바꿀 수 있나요?

0

70

1

MemberRepositoryTest 실행오류

0

90

1

boot 4.x >>> trasasction rolled back log & p6spy(영한님, 수업 자료 업데이트 해주시면 감사하겠습니다!!)

1

197

2

강의 마지막 QueryDSL 사용 부분 질문있습니다

1

154

2

클라이언트에서 isbn과 author 수정 요청을 한 경우에 대해 질문드립니다.

0

57

1

도메인 모델 패턴 vs 트랜잭션 스크립트 패턴

0

80

1

기본 생성자

0

67

1

h2 DB 연결시 jdbc url 변경 이유가 궁금합니다.

0

107

1

멤버서비스테스트 부분에서 막힙니다.

0

174

4

실무에서도 EntityManager를 이용해서 많이 작업하는 편일까요?

0

124

1

초반에 h2 다운로드 과정 꼭 필요한가요?

0

129

2

자신 필드에도 get으로 접근하는 이유가 있을까요?

0

122

1

24분 27초 연관관계 편의 메서드 위치

0

118

1

단건 주문만 가능하게 한건 의도한 부분이신가요?

0

114

2

빌드 툴, Gradle

0

65

1

h2연결은 된 것 같은데 엔티티 테이블까지 작성 후 확인해보아도 테이블이 안보입니다

0

82

2

Repository에서 EntityManager 주입 방식 차이

0

97

1

롬복과 사용자 정의 setter 메서드

0

78

1

주문 목록 조회 fetch join 질문드립니다

0

91

1

dirty checking 질문드립니다.

0

87

1