inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 DB 2편 - 데이터 접근 활용 기술

트랜잭션 전파 활용6 - 복구 REQUIRED

테스트 recoverException_fail메서드 UnexpectedRollbackException

해결된 질문

646

박준일

작성한 질문수 6

0

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

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

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

[질문 내용]
여기에 질문 내용을 남겨주세요.

안녕하세요.

테스트케이스 recoverException_fail 를 실행했을때 테스트가 실패하여 질문 남깁니다.

 

해당 테스트 케이스를 실행하면 실패 로그가 나오고

java.lang.Exception: exception just for purpose of providing stack trace

at org.hibernate.resource.transaction.backend.jdbc.internal.JdbcResourceLocalTransactionCoordinatorImpl$TransactionDriverControlImpl.markRollbackOnly(JdbcResourceLocalTransactionCoordinatorImpl.java:310) ~[hibernate-core-6.3.1.Final.jar:6.3.1.Final]

 

java.lang.AssertionError:

Expecting actual throwable to be an instance of:

org.springframework.transaction.UnexpectedRollbackException

but was:

java.lang.RuntimeException

at hello.springtx.propagation.LogRepository.save(LogRepository.java:26)

at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)

at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)

...(108 remaining lines not displayed - this can be changed with Assertions.setMaxStackTraceElementsDisplayed)

at hello.springtx.propagation.MemberServiceTest.recoverException_fail(MemberServiceTest.java:135)

at java.base/java.lang.reflect.Method.invoke(Method.java:568)

at java.base/java.util.ArrayList.forEach(ArrayList.java:1511)

at java.base/java.util.ArrayList.forEach(ArrayList.java:1511)

 

UnexpectedRollbackException 을 기대하지만 RuntimeException가 나온다고 메세지가 나오는데

 

설명 해주신 대로면 UnexpectedRollbackException 예외가 나오는게 맞는거 아닌가요..?

 

 

 

 

 

 

spring mvc jpa querydsl spring-data-mybatis spring-jpa

답변 2

0

박준일

https://drive.google.com/file/d/1YbrL5TD5CJFG31ZaYIk3Dh1kOqV2LB5x/view?usp=sharing

 

감사합니다.

 

MemberServiceTest.java 에서

recoverException_fail() 테스트케이스랑

/**
 * MemberService @Transactional:ON
 * MemberRepository @Transactional:ON
 * LogRepository @Transactional:ON Exception
 */
//테스트케이스 실패..?
@Test
void recoverException_fail() {
    //given
    String username = "로그예외_recoverException_fail";
    //when
    //try - catch 걸려있는 joinV2
    assertThatThrownBy(() -> memberService.joinV2(username))
            .isInstanceOf(UnexpectedRollbackException.class);
    //then: 모든 데이터가 롤백된다.
    assertTrue(memberRepository.find(username).isEmpty());
    assertTrue(logRepository.find(username).isEmpty());
}

 

recoverException_success() 테스트케이스가 실패됩니다..!

/**
 * MemberService @Transactional:ON
 * MemberRepository @Transactional:ON
 * LogRepository @Transactional(REQUIRES_NEW) Exception
 */
//테스트케이스 실패..?
@Test
void recoverException_success() {
    //given
    String username = "로그예외_recoverException_success";
    //when
    memberService.joinV2(username);
    //then: member 저장, log 롤백
    assertTrue(memberRepository.find(username).isPresent());
    assertTrue(logRepository.find(username).isEmpty());
}

 

2

y2gcoder

보내주신 코드 살펴보았습니다!
imagelogRepository.save()가 강의에서와는 달리 try-catch 문 밖에 하나 더 존재합니다!

해당 부분을 삭제하신 후 전파옵션을 강의와 같이 각 테스트마다 바꿔서 테스트해보시면 정상적으로 진행하실 수 있습니다!

imageimage

2

박준일

답변 너무 감사합니다...!

0

y2gcoder

안녕하세요. 박준일님, 공식 서포터즈 y2gcoder입니다.

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

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

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

https://bit.ly/3fX6ygx


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


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

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

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


링크: 공식 서포터즈

링크: 자주하는 질문

감사합니다.

RepositoryTest의 패키지 위치가 domain인 이유

0

29

2

REQUIRES_NEW 해결 방법에 대해서 질문있습니다!!

0

29

1

update()에 사용하는 setter 질문드립니다.

0

47

1

SQL 중심적 개발의 문제점에 대한 질문

0

72

1

혹시 Containing 을 안쓰신 이유가 있을까요?

0

83

2

[공유] 스프링부트 4.x 버전 mybatis 연동

0

173

1

@repository 어노테이션

0

89

3

ItemService

0

58

1

논리 커밋, 물리 커밋 질문드립니다.

0

54

1

내부 트랜잭션 커밋은 필수인가요?

0

57

1

프록시 커넥션 객체를 반환할 때 생성하는건가요?

0

54

1

Transaction readOnly 성능 개선 (김영한님의 대한 감사인사)

2

178

2

JPQL 대신 네이티브 쿼리를 사용해야 하는 경우

0

77

1

@EventListener(ApplicationReadyEvent.class) 관련

0

88

1

트랜잭션 동기화 매니저와 데이터 소스

0

76

1

DB 관련 강의 개설 계획은 없으신건가요?

0

133

2

물리 트랜잭션 과 논리트랜잭션 용어를 맞게 이해한걸까요

0

94

1

스프링 3 버전 이상 rollbackFor 변경된듯요

1

112

1

트랜잭션 전파 질문.

0

87

1

프로젝트 오픈 에러

0

126

1

외부 트랜잭션에서 isNewTransaction이 false로 나오는거에 대해 질문드립니다

0

83

2

같은 스레드를 사용하면 트랜잭션 동기화 매니저는 같은 커넥션을 반환

0

72

1

h2 인메모리 테스트중 예약어 충돌날 경우 대처방법

0

102

1

커스텀aop와 트랜잭션을 같이 사용할때 우선순위에 관한 질문

0

98

2