inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! 스프링 데이터 JPA

Auditing

JpaEventBaseEntity test

해결된 질문

428

모깅

작성한 질문수 55

0

@Test
    public void JpaEventBaseEntity() throws InterruptedException {
        Member member = new Member("member1");
        memberRepository.save(member); //@Prepersist

        Thread.sleep(100);
        member.setUsername("member2");

        em.flush();
        em.clear();

        Member findMember = memberRepository.findById(member.getId()).get();

        System.out.println("findMember.getCreateDate() = " + findMember.getCreateDate());
        System.out.println("findMember.getUpdateDate() = " + findMember.getUpdateDate());
    }

Thread.sleep을 해준 이유가 무엇인가요??

java spring spring-boot jpa

답변 1

1

y2gcoder

안녕하세요. 유선목님, 공식 서포터즈 y2gcoder입니다.

Auditing 기능으로 입력된 생성일시와 수정일시의 시간 차이를 보여드리기 위해서입니다!
sleep을 넣어주지 않는다면 테스트코드는 빠른 시간 내에 엔티티를 저장후 값을 바꾼후 flush 하기 때문에 생성일시와 수정일시의 차이가 나지 않을 수 있습니다! 그래서 임의로 sleep을 줘서 @PrePersist 와 @PreUpdate의 실행 시간 차이가 유의미하게 나는 것을 볼 수 있습니다!
10분 30초 경부터 테스트 결과에 대해 말씀해주시고 계신게 그 부분입니다!

감사합니다.

1

모깅

이해했습니다 감사합니다 ㅎㅎ!

existsByUserIdAndProjectId vs existsByUserAndProject 중 어떤 방식이 적절할까요?

0

68

1

existsByUserIdAndProjectId vs existsByUserAndProject 중 어떤 방식이 적절할까요?

0

107

3

MemberRepository 구현체

0

56

1

pdf 표현 질문드립니다.

0

60

1

로그가 남지 않는 문제.

0

79

1

테스트 라이브러리가 강의는 junit4가 맞나요??

0

70

2

pdf 파일과 차이점이 있는 것같은데 문제 없나요?

0

72

2

@PrePersist, @PreUpdate 호출 시점 질문드립니다.

0

91

2

Sort 인터페이스는 잘 사용 안하나요?

0

52

1

스캔대상 질문드립니다.

0

45

1

하이버네이트6에서의 최적화에 이은 질문

0

83

1

save() vs saveAndFlush DB 통신 횟수

0

53

1

순수 JPA 리포지토리 코드 수정부분

0

86

2

bulk연산 후 flush하는 이유를 모르겠어요

0

151

3

bulk insert 질문입니다.

0

176

2

교만했던 것 같아요.

0

147

1

RESTful 강의는 안하시는 건지 궁금합니다.

0

146

2

동적 테이블에 대한 질문

0

85

1

영속성 전이와 연관관계

0

130

2

강의 10:25 질문

0

73

1

단건 update 질문

0

95

2

엔티티 와 도메인의 경계

0

127

1

UsernameOnlyDto 타입 type mismatch 오류

0

119

1

Projection 개념과 데이터 전달과정에 대해 질문 있습니다.

0

136

1