This library provides tools to help write tests for code that uses the following gcloud-java services:
- [Datastore] (#testing-code-that-uses-datastore)
- [Storage] (#testing-code-that-uses-storage)
- [Resource Manager] (#testing-code-that-uses-resource-manager)
- [BigQuery] (#testing-code-that-uses-bigquery)
You can test against a temporary local Datastore by following these steps:
- Start the local Datastore emulator before running your tests using
LocalDatastoreHelper
'screate
andstart
methods. This will create a temporary folder on your computer and bind a port for communication with the local Datastore. There is an optional argument forcreate
: consistency. The consistency setting controls the fraction of Datastore writes that are immediately visible in global queries.
// Use the default consistency setting of 0.9
LocalDatastoreHelper helper = LocalDatastoreHelper.create();
// or explicitly set the consistency
helper = LocalDatastoreHelper.create(0.6);
helper.start(); // Starts the local Datastore emulator in a separate process
- Create and use a
Datastore
object with the options given by theLocalDatastoreHelper
instance. For example:
Datastore localDatastore = helper.options().service();
-
Run your tests.
-
Stop the local datastore emulator by calling the
stop()
method, like so:
helper.stop();
You can test against a remote Datastore emulator as well. To do this, set the DatastoreOptions
project endpoint to the hostname of the remote machine, like the example below.
DatastoreOptions options = DatastoreOptions.builder()
.projectId("my-project-id") // must match project ID specified on remote machine
.host("http://<hostname of machine>:<port>")
.authCredentials(AuthCredentials.noAuth())
.build();
Datastore localDatastore = options.service();
We recommend that you start the emulator on the remote machine using the Google Cloud SDK from command line, as shown below:
gcloud beta emulators datastore start --host-port <hostname of machine>:<port>
You can test against an in-memory local DNS by following these steps:
- Before running your testing code, start the DNS emulator
LocalDnsHelper
. This can be done as follows:
long delay = 0;
LocalDnsHelper helper = LocalDnsHelper.create(delay);
helper.start();
This will spawn a server thread that listens to localhost
at an ephemeral port for DNS requests.
The delay
parameter determines if change requests should be processed synchronously
(value 0
) or in a separate thread with a minimum of delay of delay
milliseconds.
- In your program, create the DNS service by using the helper's
options()
method. For example:
Dns dns = LocalDnsHelper.options().service();
-
Run your tests.
-
Stop the DNS emulator.
helper.stop();
This method will block until the server thread has been terminated.
Currently, there isn't an emulator for Google Cloud Storage, so an alternative is to create a test project. RemoteStorageHelper
contains convenience methods to make setting up and cleaning up the test project easier. To use this class, follow the steps below:
-
Create a test Google Cloud project.
-
Download a JSON service account credentials file from the Google Developer's Console. See more about this on the Google Cloud Platform Storage Authentication page.
-
Create a
RemoteStorageHelper
object using your project ID and JSON key. Here is an example that uses theRemoteStorageHelper
to create a bucket.
RemoteStorageHelper helper =
RemoteStorageHelper.create(PROJECT_ID, new FileInputStream("/path/to/my/JSON/key.json"));
Storage storage = helper.options().service();
String bucket = RemoteStorageHelper.generateBucketName();
storage.create(BucketInfo.of(bucket));
-
Run your tests.
-
Clean up the test project by using
forceDelete
to clear any buckets used. Here is an example that clears the bucket created in Step 3 with a timeout of 5 seconds.
RemoteStorageHelper.forceDelete(storage, bucket, 5, TimeUnit.SECONDS);
You can test against an in-memory local Resource Manager by following these steps:
- Before running your testing code, start the Resource Manager emulator
LocalResourceManagerHelper
. This can be done as follows:
LocalResourceManagerHelper helper = LocalResourceManagerHelper.create();
helper.start();
This will spawn a server thread that listens to localhost
at an ephemeral port for Resource Manager requests.
- In your program, create and use a Resource Manager service object whose host is set to
localhost
at the appropriate port. For example:
ResourceManager resourceManager = LocalResourceManagerHelper.options().service();
-
Run your tests.
-
Stop the Resource Manager emulator.
helper.stop();
This method will block until the server thread has been terminated.
Currently, there isn't an emulator for Google BigQuery, so an alternative is to create a test
project. RemoteBigQueryHelper
contains convenience methods to make setting up and cleaning up the
test project easier. To use this class, follow the steps below:
-
Create a test Google Cloud project.
-
Download a JSON service account credentials file from the Google Developer's Console.
-
Create a
RemoteBigQueryHelper
object using your project ID and JSON key. Here is an example that uses theRemoteBigQueryHelper
to create a dataset.
RemoteBigQueryHelper bigqueryHelper =
RemoteBigQueryHelper.create(PROJECT_ID, new FileInputStream("/path/to/my/JSON/key.json"));
BigQuery bigquery = bigqueryHelper.options().service();
String dataset = RemoteBigQueryHelper.generateDatasetName();
bigquery.create(DatasetInfo.builder(dataset).build());
-
Run your tests.
-
Clean up the test project by using
forceDelete
to clear any datasets used. Here is an example that clears the dataset created in Step 3.
RemoteBigQueryHelper.forceDelete(bigquery, dataset);