inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

회원 기능 테스트

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

554

todrkrwndgg

작성한 질문수 6

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);

위 로그는 해당 로그인데 혹시 이유를 알 수 있을까요?

java spring 웹앱 spring-boot jpa

답변 2

0

김영한

안녕하세요. todrkrwndgg님

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

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

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

https://bit.ly/3fX6ygx


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

 

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

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

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

 

링크: 공식 서포터즈

링크: 자주하는 질문

감사합니다.

0

인프런 AI 인턴

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

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

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

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

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

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

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

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

sdk 설정 오류

0

53

2

오탈자 - @Transactional

0

56

1

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

0

50

1

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

0

64

1

MemberRepositoryTest 실행오류

0

81

1

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

1

183

2

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

1

142

2

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

0

51

1

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

0

71

1

기본 생성자

0

60

1

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

0

103

1

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

0

165

4

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

0

116

1

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

0

120

2

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

0

114

1

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

0

113

1

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

0

109

2

빌드 툴, Gradle

0

59

1

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

0

77

2

Repository에서 EntityManager 주입 방식 차이

0

90

1

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

0

72

1

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

0

82

1

dirty checking 질문드립니다.

0

83

1

동시성 관련 질문입니다

0

75

1