From c6e305a880af68c6dfc244aba998aa4911ebfad9 Mon Sep 17 00:00:00 2001 From: Steven Meyer <108885656+meyertst-aws@users.noreply.github.com> Date: Thu, 15 Feb 2024 12:52:51 -0500 Subject: [PATCH] CPP: Fix testing false negatives (#6108) Adding some code to mock credentials request. --- .../tests/MediaConvert_gtests.cpp | 56 ++++++++++++++----- 1 file changed, 43 insertions(+), 13 deletions(-) diff --git a/cpp/example_code/mediaconvert/tests/MediaConvert_gtests.cpp b/cpp/example_code/mediaconvert/tests/MediaConvert_gtests.cpp index da521e376f0..9b89990b0da 100644 --- a/cpp/example_code/mediaconvert/tests/MediaConvert_gtests.cpp +++ b/cpp/example_code/mediaconvert/tests/MediaConvert_gtests.cpp @@ -10,29 +10,59 @@ // Debug testing framework start. #include +static const char ALLOCATION_TAG[] = "RDS_GTEST"; + class DebugMockHTTPClient : public MockHttpClient { public: - DebugMockHTTPClient() {} + explicit DebugMockHTTPClient( + const std::shared_ptr &requestTmp) { + std::shared_ptr goodResponse = Aws::MakeShared( + ALLOCATION_TAG, requestTmp); + goodResponse->AddHeader("Content-Type", "text/json"); + goodResponse->SetResponseCode(Aws::Http::HttpResponseCode::OK); + Aws::Utils::DateTime expiration = + Aws::Utils::DateTime::Now() + std::chrono::milliseconds(60000); + + std::stringstream stringStream; + stringStream << R"({ +"RoleArn":"arn:aws:iam::123456789012:role/MockRole", +"AccessKeyId":"ABCDEFGHIJK", +"SecretAccessKey":"ABCDEFGHIJK", +"Token":"ABCDEFGHIJK==", +"Expiration":")" + << expiration.ToGmtString(Aws::Utils::DateFormat::ISO_8601) + << R"(" + })"; + std::cerr << "Credentials response\n" << stringStream.str() << std::endl; + goodResponse->GetResponseBody() << stringStream.rdbuf(); + this->AddResponseToReturn(goodResponse); + + mCredentialsResponse = MockHttpClient::MakeRequest(requestTmp); + } std::shared_ptr MakeRequest(const std::shared_ptr &request, Aws::Utils::RateLimits::RateLimiterInterface *readLimiter, Aws::Utils::RateLimits::RateLimiterInterface *writeLimiter) const override { - auto result = MockHttpClient::MakeRequest(request, readLimiter, writeLimiter); - - std::cout << "DebugMockHTTPClient::MakeRequest URI " << request->GetURIString() - << ", query " << request->GetQueryString() - << ", result " << result.get() << "." << std::endl; - - return result; + // Do not use stored responses for a credentials request. + if (request->GetURIString().find("/credentials/") != std::string::npos) { + std::cout << "DebugMockHTTPClient returning credentials request." + << std::endl; + return mCredentialsResponse; + } + else { + return MockHttpClient::MakeRequest(request, readLimiter, writeLimiter); + } } + +private: + std::shared_ptr mCredentialsResponse; }; // Debug testing framework end. Aws::SDKOptions AwsDocTest::MediaConvert_GTests::s_options; std::unique_ptr AwsDocTest::MediaConvert_GTests::s_clientConfig; -static const char ALLOCATION_TAG[] = "RDS_GTEST"; void AwsDocTest::MediaConvert_GTests::SetUpTestSuite() { // Debug testing framework start. @@ -113,14 +143,14 @@ int AwsDocTest::MyStringBuffer::underflow() { } AwsDocTest::MockHTTP::MockHTTP() { + requestTmp = CreateHttpRequest(Aws::Http::URI("https://test.com/"), + Aws::Http::HttpMethod::HTTP_GET, + Aws::Utils::Stream::DefaultResponseStreamFactoryMethod); mockHttpClient = Aws::MakeShared( - ALLOCATION_TAG); // Debug testing framework. + ALLOCATION_TAG, requestTmp); // Debug testing framework. mockHttpClientFactory = Aws::MakeShared(ALLOCATION_TAG); mockHttpClientFactory->SetClient(mockHttpClient); SetHttpClientFactory(mockHttpClientFactory); - requestTmp = CreateHttpRequest(Aws::Http::URI("https://test.com/"), - Aws::Http::HttpMethod::HTTP_GET, - Aws::Utils::Stream::DefaultResponseStreamFactoryMethod); std::cout << "AwsDocTest::MockHTTP::MockHTTP called." << std::endl; // Debug testing framework.