Inflearn brand logo image

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

조동휘님의 프로필 이미지
조동휘

작성한 질문수

스프링 입문 - 코드로 배우는 스프링 부트, 웹 MVC, DB 접근 기술

스프링 통합 테스트

@Transactional 어노테이션을 썻지만, h2 DB가 롤백이 되지 않습니다.

작성

·

67

·

수정됨

1

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

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

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

[질문 내용]

***문제해결****

JDBCRepository 구현시

image

이걸 안 붙혀넣고

image.png

이렇게 써서 생긴 오류인 것 같습니다.. 다른 질문글에서 보고 알았습니다 하하..

***************
@Transactional 어노테이션을 썻지만, h2 DB에서 롤백이 되지 않습니다.
롤백이 되지 않은 이유가 스프링 버전과 h2 버전이 바뀌어서 그런건가요?
테이블을 초기화하고 스프링통합memberServiceTest 를 진행하니 회원가입한 정보가 테스트가 끝난 후 DB에 고스란히 남아있었습니다.

#스프링 환경
Java-> 17
spring->3.4.3
h2 : 2.3.232
-> 서버모드 접근함(jdbc:h2:tcp://localhost/~/test)

#알아본것
h2에 서버모드로 접근하면, spring->네트워크->h2
이렇게 접근이 되어서 외부에 있는 DB는 롤백을 안한다고 들었습니다.
다른 곳에서도 접근해서 고칠 수 있기 때문에,,
그래서 대신 메모리모드를 사용하라고 답변을 들었습니다.


답변 1

0

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

조동휘님, @Transactional 어노테이션을 사용했음에도 불구하고 H2 데이터베이스에서 롤백이 되지 않는 문제에 대해 질문해 주셨습니다. 다음에서 이 문제의 원인과 해결 방법을 살펴보겠습니다.

문제의 원인

  1. H2 데이터베이스 모드: 서버 모드로 H2를 사용하고 계시군요. 서버 모드에서는 여러 애플리케이션이 동시에 데이터베이스에 접근할 수 있는데, 이러한 경우 트랜잭션의 범위가 동일하게 관리되지 않을 수 있습니다. 이는 네트워크를 통해 외부로 연결되기 때문에 내부 인메모리 모드와 다르게 동작할 수 있습니다.

해결 방법

  1. 인메모리 모드 사용:

    • 테스트 시에는 jdbc:h2:mem:testdb와 같은 방식으로 인메모리 모드를 사용하시길 추천드립니다. 이는 애플리케이션 내에서 실행되고, 테스트 종료 시마다 개별 애플리케이션 실행에 따라 데이터베이스가 초기화됩니다.
  2. 테스트 환경 구성:

    • @SpringBootTest@ActiveProfiles("test")를 사용하여 별도의 테스트 설정을 적용해 주세요.
    • application-test.yml과 같은 테스트 설정 파일을 작성하여 인메모리용 데이터베이스 설정을 구성하세요.

추가 정보

  • 스프링과 H2 버전 확인: 언급하신 대로 스프링과 H2의 버전이 변경됨에 따라 트랜잭션의 동작 방식이 조금씩 달라질 수 있습니다. 항상 최신 문서를 참고하여 버전 간의 호환성을 고려해 주세요.
  • 네트워크 모드의 주의점: 여러 접근 방식에서 데이터베이스를 공유하게 되면, 트랜잭션 관리가 복잡하고 예측이 어려워질 수 있습니다. 따라서 테스트에서 분리된 로컬 환경을 구성하도록 권장됩니다.

아래 유사한 질문 및 답변을 참고하여 보다 구체적인 해결책을 찾아보시기 바랍니다:

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

조동휘님의 프로필 이미지
조동휘

작성한 질문수

질문하기