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

LetsGoHigh님의 프로필 이미지

작성한 질문수

Practical Testing: 실용적인 테스트 가이드

Presentation Layer 테스트 (2)

컨트롤러에서 @Valid로 필드를 검증을 한 이후 질문

23.08.01 00:09 작성

·

526

0

안녕하세요~ 좋은 강의 잘 듣고 있습니다.

질문이 하나 있는데요.

컨트롤러에서 @Valid로 필드를 검증이 되지 않으면 공통 예외처리에 걸려서 응답처리가 되고, 정상적으로 필드가 검증이 됐다면 서비스단에 로직을 처리할텐데요~

서비스단에서는 다시 필드를 검증할 필요가 없을까요?

컨트롤러, 서비스를 나눠서 테스트를 작성하다보니 서비스 단에서도 검증을 해야하나 궁금합니다.

실무에서는 어떻게 보통 어떻게 진행되나요?

답변 2

0

박우빈님의 프로필 이미지
박우빈
지식공유자

2023. 08. 06. 16:07

안녕하세요, John J님! :)

네네 사실 가장 이상적으로 생각하면 레이어별로 검증하는 것이 가장 좋겠지만, 반대로 개발 비용을 고려했을 때는 너무 비효율적이기도 합니다.

강의에서 말씀드린 내용 중에, 레이어별 아키텍처를 사용하는 가장 큰 이유가 관심사의 분리 라고 말씀드렸는데요!
'외부에서 들어오는 값에 대한 검증을 어디서 할 것인가'를 이야기할 때, (그 검증이 비즈니스 로직과 강하게 연관된 검증이 아니라면) 저는 가장 외부에 있는 Controller가 그 역할을 감당해야 한다고 말씀 드렸습니다.
Presentation Layer가 기본적인 검증을 담당해주기 때문에, Business Layer는 마음 놓고 비즈니스 로직을 전개할 수 있게 되는 것이죠. ㅎㅎ

도움이 되셨기를 바랍니다.
감사합니다. :)

0

인프런 AI 인턴님의 프로필 이미지

2023. 08. 03. 00:11

안녕하세요, 인프런 AI 인턴이에요. 컨트롤러에서 @Valid 어노테이션을 사용하여 필드를 검증하는 것은 좋은 방법입니다.

서비스 단에서 필드를 다시 검증해야하는지에 대해서는 상황에 따라 다릅니다. 일반적으로 컨트롤러에서 검증된 필드가 서비스 단까지 전달된다면, 서비스 단에서 다시 검증할 필요는 없을 수 있습니다. 하지만 데이터의 완전성과 보안을 위해 추가적인 검증이 필요한 경우도 있을 수 있습니다.

따라서 실무에서는 특정한 상황에 따라 다르게 진행될 수 있습니다. 일반적으로요, 필드의 검증은 컨트롤러에서 처리하고, 서비스 단에서는 데이터를 가공하고 비즈니스 로직을 처리합니다. 필요한 경우 서비스 단에서도 유효성 검사를 수행할 수 있지만, 중복된 검증이 발생하지 않도록 주의해야 합니다.

따라서, 컨트롤러에서의 검증까지 이미 완료된 상태라면, 서비스 단에서는 중복된 검증이 필요하지 않을 수 있다는 점을 참고하시면 좋을 것 같아요.
더 궁금한 점이 있으시면 언제든지 물어보세요! 좋은 하루 되세요~요.