작성
·
468
0
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)
[질문 내용]
package jpabook.jpashop.service;
import org.assertj.core.api.Assertions;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.annotation.Rollback;
import org.springframework.transaction.annotation.Transactional;
import jpabook.jpashop.domain.Member;
@SpringBootTest
@Transactional
public class MemberServiceTest {
@Autowired
private jpabook.jpashop.repository.MemberRepository memberRepository;
@Autowired
private MemberService memberService;
// @Test
//// @Rollback(false)
// public void 회원가입() throws Exception {
// // given
// Member member = new Member();
// member.setName("kim");
//
// // when
// Long savedId = memberService.join(member);
//
// // then
// Assertions.assertThat(member).isEqualTo(memberRepository.findOne(savedId));
// }
@Test
// @Rollback(false)
public void 중복_회원_예외() throws Exception {
// given
Member member1 = new Member();
member1.setName("kim");
Member member2 = new Member();
member2.setName("kim");
// when
memberService.join(member1);
try {
memberService.join(member2);
} catch (IllegalStateException e) {
return;
}
// then
Assertions.fail("예외가 발생해야 한다.");
}
}
저는 JUnit5를 사용헀기 때문에 위와 같이 코드를 작성했는데요
주석 처리한 회원가입() 메서드를 실행할 때는 강사님처럼 INSERT 쿼리가 실행되지 않는 것을 확인했지만, 중복_회원_예외() 메서드를 실행할 때는 INSERT 쿼리가 실행되는 것을 확인했습니다.
2024-04-02T00:01:22.883+09:00 DEBUG 26044 --- [jpashop] [ main] org.hibernate.SQL :
insert
into
member
(city, street, zipcode, name, member_id)
values
(?, ?, ?, ?, ?)
2024-04-02T00:01:22.885+09:00 TRACE 26044 --- [jpashop] [ main] org.hibernate.orm.jdbc.bind : binding parameter (1:VARCHAR) <- [null]
2024-04-02T00:01:22.885+09:00 TRACE 26044 --- [jpashop] [ main] org.hibernate.orm.jdbc.bind : binding parameter (2:VARCHAR) <- [null]
2024-04-02T00:01:22.885+09:00 TRACE 26044 --- [jpashop] [ main] org.hibernate.orm.jdbc.bind : binding parameter (3:VARCHAR) <- [null]
2024-04-02T00:01:22.885+09:00 TRACE 26044 --- [jpashop] [ main] org.hibernate.orm.jdbc.bind : binding parameter (4:VARCHAR) <- [kim]
2024-04-02T00:01:22.885+09:00 TRACE 26044 --- [jpashop] [ main] org.hibernate.orm.jdbc.bind : binding parameter (5:BIGINT) <- [1]
2024-04-02T00:01:22.886+09:00 INFO 26044 --- [jpashop] [ main] p6spy : #1711983682886 | took 0ms | statement | connection 4| url jdbc:h2:tcp://localhost/~/jpashop
insert into member (city,street,zipcode,name,member_id) values (?,?,?,?,?)
insert into member (city,street,zipcode,name,member_id) values (NULL,NULL,NULL,'kim',1);
위 로그는 해당 로그인데 혹시 이유를 알 수 있을까요?
답변 2
0
안녕하세요, 인프런 AI 인턴입니다.
todrkrwndgg님께서 질문하신 내용과 관련하여, JUnit 테스트에서의 트랜잭션 동작과 @Transactional
및 @Rollback
어노테이션의 역할에 대해 설명드리겠습니다.
@Transactional
어노테이션은 해당 테스트 혹은 서비스 메서드를 하나의 트랜잭션으로 처리하도록 합니다. 기본적으로, 스프링의 테스트 컨텍스트는 각 테스트 메서드 실행 후 트랜잭션을 롤백(데이터를 DB에 실제로 반영하지 않음)시키도록 설정되어 있습니다. 따라서, 보통은 데이터가 실제로 DB에 저장되지 않는 것으로 예상됩니다.
그러나, @Rollback
어노테이션을 사용하여 이 기본 동작을 변경할 수 있습니다. @Rollback(false)
를 사용하면, 테스트 실행 후에도 트랜잭션이 롤백되지 않고 데이터가 실제로 DB에 저장됩니다.
질문하신 내용에서 “주석 처리한 회원가입() 메서드를 실행할 때는 INSERT 쿼리가 실행되지 않는 것”과 “중복_회원_예외() 메서드를 실행할 때는 INSERT 쿼리가 실행됨”에 대해, @Rollback
어노테이션의 설정이 관련이 있을 수 있습니다. 하지만, 제공하신 코드에는 @Rollback
어노테이션이 주석 처리되어 있고, 그 외의 설정이 명시되지 않아 정확한 원인을 파악하기 어렵습니다.
이와 관련하여 유사한 상황을 설명하고 있는 기존 질문 & 답변 링크는 아래와 같습니다. 여기서는 트랜잭션과 관련된 처리와 JUnit 테스트에서 기대하는 동작을 조정하는 방법에 대해 논의됩니다.
단, 제공된 링크는 질문자님의 상황과 직접적으로 일치하지 않을 수 있습니다. 트랜잭션과 롤백의 동작 방식을 이해하고, @Transactional
및 @Rollback
어노테이션 사용에 주의하여 코드를 검토하시기 바랍니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.