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

김동현님의 프로필 이미지
김동현

작성한 질문수

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

회원 기능 테스트

rollback(false) 로 회원 추가 후, rollback(false) 없애고 다시 동일한 회원 추가 시

작성

·

356

·

수정됨

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
위의 회원가입 함수를 처음에 rollback(false)로 실행하면 데이터베이스에 Name이 "kim"인 데이터가 들어가는걸 확인했습니다.

 

질문1

이후에 rollback(false)를 제거하고 다시 회원가입 함수를 실행하면 join에서 기존에 db에 "kim" 이라는 회원이 존재하기 때문에 예외가 발생해야 하는 것 아닌가요? 그런데 왜 정상적으로 join되었다가 롤백되는건지 궁금합니다.

질문2

예외가 발생한다고 예상했지만 오히려 기존의 "kim" 회원 또한 사라졌습니다. 기존의 데이터조차 사라지는 이유가 무엇인가요?. 테스트 하기 전 기존에 데이터베이스에 있던 데이터들은 롤백되어도 그대로 있어야 하는것 아닌가요?

 

*혹시 테스트 메서드를 실행할때, 기본적으로 데이터베이스를 비우고 시작하는 건가요? 그렇다면 다시 롤백했을때 비어있는 데이터베이스로 돌아오게 되고, 그러면 위 궁금증이 해소되긴 합니다.

 

 

답변 1

0

안녕하세요. 김동현님, 공식 서포터즈 OMG입니다.

테스트에서 동작하고 있는 application.yml에 어떤 설정이 적용되어 있는지 확인을 해봐야 알 것 같습니다.

아마 관련되어 동작하는 설정은 ddl-auto 설정이 create로 되어있어 적용되고 있을 것 같은데요, 그렇게 예상한 이유는 두번째 질문에서 kim 회원조차 사라졌다고 하는 부분에서 table이 drop 되고 새로 create된게 아닐까 싶습니다.

동일하게 상황을 재현해보시고, kim이 사라지는 상황에서 create table member... 쿼리가 발생하는지 확인 부탁드립니다 ^^

아마 전체 테이블이 삭제되고, 재 생성되는 쿼리가 발생한다면 Ddl-auto 옵션으로 인해 발생한게 맞을 것 같아요

  • application.yml이 src/main/resources에만 있는지

    • yml설정파일이 존재한다면 전체 설정이 어떻게 작성되어 있는지

  • application.yml이 src/test/resources에도 있는지

    • yml설정파일이 존재한다면 전체 설정이 어떻게 작성되어 있는지

이렇게 main과 test경로에 yml 설정파일 유무와 작성내용을 댓글로 남겨주시면 확인에 큰 도움이 됩니다 :)

감사합니다.

김동현님의 프로필 이미지
김동현
질문자

test 폴더의 yml 파일을 생략했을때, in-memory 방식으로 동작한다고 yml 파일의 내용을 생략했었습니다.

아마 생략했을때 기본적으로 ddl-auto: create 으로 설정되는것인가 싶습니다. 감사합니다 :)

김동현님의 프로필 이미지
김동현

작성한 질문수

질문하기