• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

섹션 4 - 회원 기능 테스트 강의에서 중복_회원_예외()메서드를 실행할 때 INSERT 쿼리가 실행되는 이유

24.04.02 00:05 작성 조회수 158

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

안녕하세요. todrkrwndgg님

도움을 드리고 싶지만 질문 내용만으로는 답변을 드리기 어렵습니다.

실제 동작하는 전체 프로젝트를 압축해서 구글 드라이브로 공유해서 링크를 남겨주세요.

구글 드라이브 업로드 방법은 다음을 참고해주세요.

https://bit.ly/3fX6ygx


주의: 업로드시 링크에 있는 권한 문제 꼭 확인해주세요

 

추가로 다음 내용도 코멘트 부탁드립니다.

1. 문제 영역을 실행할 수 있는 방법

2. 문제가 어떻게 나타나는지에 대한 상세한 설명

 

링크: 공식 서포터즈

링크: 자주하는 질문

감사합니다.

0

인프런 AI 인턴님의 프로필

인프런 AI 인턴

2024.04.02

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

todrkrwndgg님께서 질문하신 내용과 관련하여, JUnit 테스트에서의 트랜잭션 동작과 @Transactional@Rollback 어노테이션의 역할에 대해 설명드리겠습니다.

@Transactional 어노테이션은 해당 테스트 혹은 서비스 메서드를 하나의 트랜잭션으로 처리하도록 합니다. 기본적으로, 스프링의 테스트 컨텍스트는 각 테스트 메서드 실행 후 트랜잭션을 롤백(데이터를 DB에 실제로 반영하지 않음)시키도록 설정되어 있습니다. 따라서, 보통은 데이터가 실제로 DB에 저장되지 않는 것으로 예상됩니다.

그러나, @Rollback 어노테이션을 사용하여 이 기본 동작을 변경할 수 있습니다. @Rollback(false)를 사용하면, 테스트 실행 후에도 트랜잭션이 롤백되지 않고 데이터가 실제로 DB에 저장됩니다.

질문하신 내용에서 “주석 처리한 회원가입() 메서드를 실행할 때는 INSERT 쿼리가 실행되지 않는 것”과 “중복_회원_예외() 메서드를 실행할 때는 INSERT 쿼리가 실행됨”에 대해, @Rollback 어노테이션의 설정이 관련이 있을 수 있습니다. 하지만, 제공하신 코드에는 @Rollback 어노테이션이 주석 처리되어 있고, 그 외의 설정이 명시되지 않아 정확한 원인을 파악하기 어렵습니다.

이와 관련하여 유사한 상황을 설명하고 있는 기존 질문 & 답변 링크는 아래와 같습니다. 여기서는 트랜잭션과 관련된 처리와 JUnit 테스트에서 기대하는 동작을 조정하는 방법에 대해 논의됩니다.

단, 제공된 링크는 질문자님의 상황과 직접적으로 일치하지 않을 수 있습니다. 트랜잭션과 롤백의 동작 방식을 이해하고, @Transactional@Rollback 어노테이션 사용에 주의하여 코드를 검토하시기 바랍니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.