• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

access token의 경우 테스트 코드에서 어떻게 처리해야되나요?

24.05.21 00:36 작성 24.05.21 01:15 수정 조회수 178

0

안녕하세요. 현재 강의 잘 수강하고 있습니다.

현재 거의 모든 controller에서 access token을 받아서 사용하고 있습니다.

토큰의 경우 만료시간 등이 있는데 테스트 코드에서 어떻게 처리되는지 궁금합니다.

저 같은 경우는 spring security 사용하지 않고, 직접 API로 Token을 발급하였습니다.

예시라던지 레퍼런스가 있다면 공유 좀 부탁드려요~

감사합니다.

답변 2

·

답변을 작성해보세요.

0

안녕하세요, jay 님! :)

access token을 어떤 식으로 사용하고 검증하시는지, 작성하려는 테스트 코드가 어떤 레이어의 테스트인지, 단위/통합/인수 테스트 중 어떤 종류의 테스트인지에 따라 검증 방법은 달라질 것 같습니다.
작성중이신 코드를 말씀주셔야 그에 맞는 답변을 드릴 수 있을 것 같은데요. ㅎㅎ

몇 가지 가능한 방법을 떠오르는대로 말씀드리자면, 테스트용 토큰을 발급하여 사용하시거나, 토큰을 검증하는 부분을 mocking 처리하여 검증을 통과하도록 반환값을 조작하는 방법 등이 있을 것 같아요.

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

0

인프런 AI 인턴님의 프로필

인프런 AI 인턴

2024.05.23

안녕하세요, 인프런 AI 인턴입니다.

jay님, 문의하신 테스트 코드에서의 access token 처리에 대해 답변 드립니다.

Spring Boot에서는 테스팅을 위해 다양한 유틸리티와 지원 클래스를 포함하고 있으며, 특히 Spring Security와 관련해 테스트 환경을 구성하는 데 필요한 몇 가지 방법이 제공됩니다. 하지만 질문하신 내용은 직접 API로 토큰을 발급받는 경우와 관련되어 있어 Spring Boot의 공식 문서에서 정확히 일치하는 정보를 찾기는 어려울 수 있습니다.

토큰 기반 인증을 직접 구현한 경우, 테스트 코드에서는 일반적으로 다음과 같은 방법들을 고려할 수 있습니다:

  1. 테스트용 토큰 발급: 테스트 실행 전에 유효기간이 긴 토큰을 미리 발급하여, 테스트 코드에서 이를 사용하는 방법입니다. 테스트 환경에서만 사용될 특별한 토큰을 생성하여 관리합니다.

  2. Mock 객체 사용: Spring의 @MockBean을 활용해 Token을 검증하는 부분을 Mocking하여 실제 토큰 검증 과정을 생략하고, 테스트 대상 코드의 실행 경로를 확인하는 방법입니다.

  3. 리플렉션을 통한 Token 처리: 리플렉션을 사용해 직접 토큰 처리 로직을 조작하거나, 테스트 중에만 특정 값을 반환하도록 구현하는 방법입니다.

  4. 테스트 프로파일 설정: application-test.yml과 같이 테스트 전용 프로파일을 설정하여, 테스트 환경에서는 토큰 검증을 생략하거나, 항상 정상적인 값이 반환되도록 하여 테스트의 복잡성을 줄이는 방법입니다.

정확한 구현 방법이나 예시는 프로젝트의 구체적인 설정이나 요구 사항에 따라 달라질 수 있으므로, 주로 프로젝트 내부 로직이나 사용하고 있는 기술 스택에 적합한 방법을 선택하여 적용해야 합니다. 또한, Spring 관련 커뮤니티나 Stackoverflow에서 유사한 사례를 검색해 보는 것도 좋습니다.

참고하시기 바랍니다. 감사합니다.

채널톡 아이콘