아임포트 토큰 요청 정보를 정의하는 클래스입니다.
        public async Task GetTokenAsync_throws_UnauthorizedAccessException_with_invalid_key_and_secret()
        {
            // arrange
            var client = GetMockClient();
            var sut = new UsersApi(client);
            var request = new IamportTokenRequest
            {
                ApiKey = "invalid",
                ApiSecret = "invalid"
            };

            // act/assert
            await Assert.ThrowsAsync<UnauthorizedAccessException>(
                () => sut.GetTokenAsync(request));
        }
        public async Task GetTokenAsync_throws_UnauthorizedAccessException_with_empty_or_null(string key, string secret)
        {
            // arrange
            var client = GetMockClient();
            var sut = new UsersApi(client);
            var request = new IamportTokenRequest
            {
                ApiKey = key,
                ApiSecret = secret
            };

            // act/assert
            await Assert.ThrowsAsync<UnauthorizedAccessException>(
                () => sut.GetTokenAsync(request));
        }
 /// <summary>
 /// 주어진 아임포트 토큰 요청을 인증하고 결과 토큰을 반환합니다.
 /// 인증에 실패하거나 입력 정보에 문제가 있을 경우 예외를 발생시킵니다.
 /// 이 API 호출은 내부 HttpClient의 Authorization 헤더를 설정하지 않습니다.
 /// 단지 요청한 토큰 정보에 대한 응답을 반환할 뿐입니다.
 /// </summary>
 /// <param name="request">아임포트 토큰 요청</param>
 /// <seealso>https://api.iamport.kr/#!/authenticate/getToken</seealso>
 /// <returns>인증된 아임포트 토큰</returns>
 public virtual async Task<IamportToken> GetTokenAsync(IamportTokenRequest request)
 {
     var iamportRequest = new IamportRequest<IamportTokenRequest>
     {
         RequireAuthorization = false,
         ApiPathAndQueryString = $"{BasePath}/{UsersGetTokenPath}",
         Content = request,
         Method = HttpMethod.Post,
     };
     var response = await client.RequestAsync<IamportTokenRequest, IamportToken>(iamportRequest);
     if (response.Code != 0)
     {
         throw new IamportResponseException(response.Code, response.Message);
     }
     return response.Content;
 }
        public async Task GetTokenAsync_returns_token()
        {
            // arrange
            var client = GetMockClient();
            var sut = new UsersApi(client);
            var request = new IamportTokenRequest
            {
                ApiKey = "key",
                ApiSecret = "secret"
            };

            // act
            var result = await sut.GetTokenAsync(request);

            // assert
            Assert.False(string.IsNullOrEmpty(result.AccessToken));
            Assert.True(result.ExpiredAt >= DateTime.UtcNow);
        }