TIL
20230203 TIL 테스트는 거짓말을 하지 않는다
jiwoosmile
2023. 2. 3. 17:32
어제는 아임포트 API를 서버에서 연결을 했고,
오늘은 웹 클라이언트에서 내 서버의 API를 통해 아임포트 API를 활용할 수 있도록 API를 작업하고 있었다.
@SpringBootTest
@ActiveProfiles("test")
class VerifyAccountServiceTest {
private VerifyAccountService verifyAccountService;
private UserRepository userRepository;
@SpyBean
private IamPort iamPort;
@BeforeEach
void setup() {
userRepository = mock(UserRepository.class);
verifyAccountService = new VerifyAccountService(userRepository, iamPort);
}
@Test
void verify() {
given(userRepository.findById(any()))
.willReturn(Optional.of(User.fake()));
given(iamPort.getBankHolder(any(), any()))
.willReturn("홍길동");
assertThat(verifyAccountService.verify(1L, new Bank("우리은행"), new AccountNumber("11111111"))).isNotNull();
}
}
그런데 왜인지 모르게 위의 스프링 테스트에서 아래와 같은 에러가 발생하였다.
IamPortError org.springframework.web.client.HttpClientErrorException$Unauthorized: 401 Unauthorized: [no body]
생성자를 직접 호출해서 테스트를 했을 때는 분명히 문제가 없었기 때문에
일단 @SpyBean을 @MockBean으로 수정을 해서 테스트는 통과를 시켰다.
그런데 불안했기 때문에 IamPort도 @Autowired를 통해 테스트를 해보았다.
@SpringBootTest
@ActiveProfiles("test")
class IamPortTest {
@Autowired
private IamPort iamPort;
@Test
void issueAccessToken() {
assertThat(iamPort.issueAccessToken()).isNotNull();
}
}
그런데 동일한 에러가 발생하는 것이었다.
IamPort는 아래와 같이 api키와 secret을 생성자 주입을 받고 있는데,
public IamPort(String apiKey, String apiSecret) {
this.apiKey = apiKey;
this.apiSecret = apiSecret;
this.setBankCodes();
}
확인을 해보니 apiKey값은 application.properties에 넣어둔 값을 잘 가져오는데,
apiSecret값이 {iamport.api-secret} 이었다.
확인을 해보니 아래 코드에서 $ 표시를 놓쳤던 것이었다.
@Value("${iamport.api-secret}")
오늘 몇 시간 동안 디버깅을 하면서 느낀 점은 외부 API를 사용하는 부분도 테스트를 작성하도록 하고,
{application.properties key값}으로 값이 나온다면 $를 제대로 붙였는지 꼭 확인하자.