작성
·
174
답변 1
0
안녕하세요. km54277님, 공식 서포터즈 OMG입니다.
말씀하신 테스트가 이 테스트 맞죠 ?
해당 테스트를 보면 사용하는 데이터 저장소인 itemRepository를 3번(저장, 변경, 조회) 사용합니다.
save()부터 보면 save의 리턴 객체를 사용해서 itemId를 가져옵니다. 왜 item의 id를 사용해서 가져오지 않고 반환 객체(savedItem)를 이용하냐면 save 하기 전 Item item = new Item(~) 의 인스턴스에는 아직 저장소에서의 id를 부여받지 못한 상태입니다. save()를 호출해야 id값이 set 되는 것이지요. 그리고 부여 받은 Id를 가지고(key) item(value)이 저장소에 저장됩니다.
이후 핵심 로직인 update가 일어나는데 이 동작을 논리적이게 설계하려면 저장한 아이템의 id와 변경할 데이터로 update가 발생하고 해당 id로 findById()을 이용하여 데이터를 조회해야 합니다.
JPA를 알고 계신지 모르시는지 몰라 JPA와 연관 지어 설명드리지 못하였는데 JPA를 가볍게(?) 알고 계신다면 아래의 내용을 알고 계시면 도움이 되시리라 생각합니다.
https://minkukjo.github.io/framework/2020/07/05/Spring-130/
설명이 이해가 안되거나 틀렸다고 생각하는 경우 댓글남겨주세요.
감사합니다.