작성
·
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 으로 설정되는것인가 싶습니다. 감사합니다 :)