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

김태형님의 프로필 이미지

작성한 질문수

실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발

회원 서비스 개발

CQS 관련 질문

해결된 질문

22.04.07 20:01 작성

·

221

0

안녕하세요 선생님 강의 정말 재밌게 듣고 있습니다

다름이 아니라 Service에 join메서드에서 id(Long) 값을 반환해주고 있는데 선생님께서 앞서 질문에서 CQS라고 말씀해주셨습니다.

서비스에서는 테스트의 용이성 등등 여러 장점때문에 Id값을 반환하는게 좋다고 말씀해주셨는데

컨트롤러에서는 join 이나 혹은 다른 Command쿼리를 날리는 메서드들에서 반환값은 어떤게 좋을까요.. id를 반환해 줄 수도 있는거고 void를 반환할 수 도 있는데 어떤게 best practice 인지 궁금합니다.

답변 1

0

David님의 프로필 이미지

2022. 04. 07. 20:06

안녕하세요. 김태형님, 공식 서포터즈 David입니다.

상황에 따라서 다릅니다. join의 경우처럼 id를 반환함으로써 얻는 용이성이 아무것도 반환하지 않는 것보다 더 나은 상황이라면 id를 반환하게 작성하는 것입니다.

감사합니다.

김태형님의 프로필 이미지
김태형
질문자

2022. 04. 10. 14:01

더 나은 상황이 어떤 상황인지 궁금합니다 그 반환된 id를 프론트에서 쓸일이 없으면 더 나은 상황인가요??

id를 사용할 일이 없는데 void를 반환한다면 이는 좋은 방법인 건가요?? 저는 아무래도 Command쿼리들은 정상적으로 수행됐는지를 status code들로 부족하다 판단하여 정상적으로 수행이 됐으면 데이터들까지 내려주는 편인데 이러한 방법은 어떻게 생각하시나요!!?

David님의 프로필 이미지

2022. 04. 10. 14:17

강의에서 언급된 것처럼 id를 반환하게 되므로써 손쉽게 테스트를 작성할 수 있 수 있습니다.

id를 바탕으로 데이터를 불러와 검증해야 하는 테스트에서 특정 메서드가 id를 반환하지 않는다면 조금 전 생성되어 저장된 데이터를 어떠한 형태로든 불러올 수 있어야 합니다.

id를 사용할 일이 없는데 void를 반환하는 건 적절한 것이죠.

정상적으로 수행된 것에 대해 데이터까지 내려주신다고 하셨는데, 그 데이터를 내려서 무엇을하시나요? 그냥 내려준걸로 끝인가요?

김태형님의 프로필 이미지
김태형
질문자

2022. 04. 10. 16:35

넵 제가 위에서 질문드린 내용은 컨트롤러에서 id라도 반환하는게 좋냐 였는데 컨트롤러에서는 response status code로 정상적으로 수행됬는지 판단할 수 있잖아요 하지만 response status code만 내려 주면 뭔가.. response body에 데이터가 없어서 허전하다는 느낌이 들어서 id라도 반환하려 했는데 이 id를 사용할 일이 없는거죠

이런 경우를 질문드린겁니다!

David님의 프로필 이미지

2022. 04. 10. 18:12

허전한 느낌이 들어서 id를 body에 넣어주는 경우는 없습니다..

김태형님의 프로필 이미지
김태형
질문자

2022. 04. 10. 18:20

넵 감사합니다! response body가 비어있으면 뭔가 정상적으로 성공했어도

api를 사용하는 사람들이 보기에는 data부분이 비어있으니 id라도 내려줬는데

다음부터는 사용할 일이 있으면 내려주는게 맞겠네요!! 감사합니다