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

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

작성한 질문수

실전! 스프링 데이터 JPA

Auditing

findById 동시성 테스트 실패

해결된 질문

작성

·

367

·

수정됨

0

MemberRepository는 jpaRepository인 상태이고,

findById관련해서 동시성 테스트를 하고 있는데, 해당 테스트가 통과를 하지 않아 그 이유가 궁금합니다.

 

단순하게 여러 스레드에서 findById하는 테스트 코드인데 왜 통과를 못하는지 잘 이해가 가지 않습니다.


@SpringBootTest
@Transactional
public class Test{


    @Autowired
    MemberRepository memberRepository;

    Member member;

    @BeforeEach
    void setUp() {

        member = Member.builder().name("testMember").build();
        memberRepository.save(member);
  
    }

    @Test
    public void test() throws Exception
    {
        int threadCount = 10;
        ExecutorService executorService = Executors.newFixedThreadPool(threadCount);
        CountDownLatch latch = new CountDownLatch(threadCount);

        AtomicInteger failCount = new AtomicInteger();
        AtomicInteger successCount = new AtomicInteger();

        for (int i = 0; i < threadCount; i++) {
            executorService.submit(
                    () -> {
                        try {
                            memberRepository.findById(member.getId()).get();
                            successCount.addAndGet(1);
                        } catch (Exception e) {
                            System.out.println(e.getMessage());
                            failCount.addAndGet(1);
                        }finally {
                            latch.countDown();
                        }
                    }
            );
        }
        latch.await();

        assertThat(successCount.get()).isEqualTo(threadCount);
        assertThat(failCount.get()).isEqualTo(0);
    }
}

 

 

답변 1

0

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

https://velog.io/@chullll/JPA-Transactional-%EA%B3%BC-%EB%8F%99%EC%8B%9C%EC%84%B1

트랜잭션은 싱글스레드에서 작동하기 때문에 멀티 스레드 환경에서는 처리가 필요하네용

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

작성한 질문수

질문하기