Testing your Cloud IAM Credentials application with googlemock

This document describes how to test your own Cloud IAM application using the Cloud IAM C++ client library, Google Test and the Google Test Mocking Framework.

Mocking a Successful IAMCredentialsClient::SignJwt() call

First include the headers for the Cloud IAM Credentials Client, the mocking class, and the Google Mock framework:

#include "google/cloud/iam/credentials/v1/iam_credentials_client.h" #include "google/cloud/iam/credentials/v1/mocks/mock_iam_credentials_connection.h" #include <gmock/gmock.h> 

The example uses a number of aliases to save typing and improve readability:

using ::google::cloud::iam_credentials_v1_mocks::MockIAMCredentialsConnection; namespace iam = ::google::cloud::iam_credentials_v1; 

Create a mocking object for google::cloud::iam_credentials_v1::IAMCredentialsConnection:

 auto mock = std::make_shared<MockIAMCredentialsConnection>(); 

It is customary to first setup the expectations for your mock, and then write the rest of the code:

 EXPECT_CALL(*mock, SignJwt) .WillOnce( [&](google::iam::credentials::v1::SignJwtRequest const& request) { EXPECT_EQ("projects/-/serviceAccounts/test-account-unique-id", request.name()); google::iam::credentials::v1::SignJwtResponse response; response.set_key_id("test-key-id"); return google::cloud::StatusOr< google::iam::credentials::v1::SignJwtResponse>(response); }); 

With the expectations in place, create a google::cloud::iam_credentials_v1::IAMCredentialsClient object:

 iam::IAMCredentialsClient iam_credentials_client(mock); 

And then make calls on the client as usual:

 std::string payload; auto response = iam_credentials_client.SignJwt( "projects/-/serviceAccounts/test-account-unique-id", {}, payload); 

And then verify the results meet your expectations:

 EXPECT_TRUE(response.ok()); EXPECT_EQ("test-key-id", response->key_id()); 

Full Listing

Finally we present the full code for this example:

#include "google/cloud/iam/credentials/v1/iam_credentials_client.h" #include "google/cloud/iam/credentials/v1/mocks/mock_iam_credentials_connection.h" #include <gmock/gmock.h> namespace { using ::google::cloud::iam_credentials_v1_mocks::MockIAMCredentialsConnection; namespace iam = ::google::cloud::iam_credentials_v1; TEST(MockSignJwtExample, SignJwt) { auto mock = std::make_shared<MockIAMCredentialsConnection>(); EXPECT_CALL(*mock, SignJwt) .WillOnce( [&](google::iam::credentials::v1::SignJwtRequest const& request) { EXPECT_EQ("projects/-/serviceAccounts/test-account-unique-id", request.name()); google::iam::credentials::v1::SignJwtResponse response; response.set_key_id("test-key-id"); return google::cloud::StatusOr< google::iam::credentials::v1::SignJwtResponse>(response); }); iam::IAMCredentialsClient iam_credentials_client(mock); std::string payload; auto response = iam_credentials_client.SignJwt( "projects/-/serviceAccounts/test-account-unique-id", {}, payload); EXPECT_TRUE(response.ok()); EXPECT_EQ("test-key-id", response->key_id()); } } // namespace