• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    해결됨

MemberServiceV2Test 에서 커넥션 획득과 반환 관련 질문드립니다.

23.06.02 20:57 작성 조회수 351

1

안녕하세요.

제가 뭘 놓치고 있는건지 이해가 안되는 부분이 있어서 질문드립니다.

MemberServiceV2Test 에서 정상 이체 테스트 실행 후 로그 확인했을 때

이렇게 확인되는데요.

START TX, END TX 내부에서 같은 커넥션을 사용한다는 것은 이해가 됩니다.

그런데 `accountTransfer()` 메소드 내에서도 어쨌든 한 번은 커넥션을 획득하는데 왜 그 부분은 로그에 찍히지 않는지 모르겠어요.

 

답변 2

·

답변을 작성해보세요.

1

안녕하세요. mh2님

테스트를 시작하는 코드를 확인해주세요. DriverManagerDataSource를 사용하도록 설정되어 있는지 확인해주세요.

    @BeforeEach
    void before() {
        DriverManagerDataSource dataSource = new DriverManagerDataSource(URL, USERNAME, PASSWORD);
        memberRepository = new MemberRepositoryV2(dataSource);
        memberService = new MemberServiceV2(dataSource, memberRepository);
    }

감사합니다.

1

인프런 AI 인턴님의 프로필

인프런 AI 인턴

2023.06.04

안녕하세요, 인프런 AI 인턴이에요.

MemberServiceV2Test에서 정상 이체 테스트를 실행하고 로그를 확인해보니 START TX와 END TX 내부에서 같은 커넥션을 사용한다는 것은 이해하셨다고 하셨는데, accountTransfer() 메소드 내에서 한 번 커넥션을 획득하는 부분이 로그에 찍히지 않는 이유는 무엇일까요?

MemberServiceV2Test에서 사용하는 DataSourceConfig 클래스에서는 테스트 진행 전 ApplicationContext 내부에서 DataSource를 미리 생성하여 공유하고 있습니다. accountTransfer() 메소드 내에서는 이미 생성된 DataSource 객체를 이용하여 커넥션 풀에서 커넥션 객체를 획득하게 됩니다. 이 경우, 커넥션 객체가 이미 생성된 상태이므로 해당 로그는 출력되지 않습니다.

즉, 미리 생성된 DataSource 객체를 이용하므로써 커넥션 객체를 여러 번 획득해도 실제로는 한 번만 생성되어 재사용됩니다. 따라서 accountTransfer() 메소드 내에서 커넥션 획득 로그가 찍히지 않아도 이해해주시면 됩니다.

더 자세한 내용이 필요하시다면, DataSourceConfig 클래스와 accountTransfer() 메소드에서의 커넥션 획득 과정을 자세히 살펴보시면 도움이 될 것입니다.

혹시 다른 궁금한 사항이 있다면 언제든지 물어봐주세요. 감사합니다.