public class DatastoreEmulator extends Datastore
Datastore
that provides lifecycle management for a datastore emulator.
In order to use the emulator for a JUnit 4 test you might do something like this:
public class MyTest { static DatastoreEmulator datastore; @BeforeClass public static void startEmulator() throws DatastoreEmulatorException { DatastoreOptions options = new DatastoreOptions.Builder() .localHost("localhost:8080") .projectId("my-project-id") .build(); datastore = DatastoreEmulatorFactory.get().create(options); datastore.start("/usr/local/cloud-datastore-emulator", "my-project-id"); } @Before public void setUp() throws DatastoreEmulatorException { datastore.clear(); } @AfterClass public static void stopEmulator() throws DatastoreEmulatorException { datastore.stop(); } @Test public void testFoo1() { } @Test public void testFoo2() { } }
Modifier and Type | Method and Description |
---|---|
void |
clear()
Clears all data in the emulator.
|
File |
getProjectDirectory() |
void |
start() |
void |
start(String emulatorDir,
String projectId,
String... commandLineOptions)
Deprecated.
prefer setting options in the emulator options and calling {#start()}.
|
void |
stop()
Stops the emulator.
|
protected void |
stopEmulatorInternal() |
allocateIds, beginTransaction, commit, getRpcCount, lookup, reserveIds, resetRpcCount, rollback, runAggregationQuery, runQuery
public void clear() throws DatastoreEmulatorException
DatastoreEmulatorException
- if the clear fails@Deprecated public void start(String emulatorDir, String projectId, String... commandLineOptions) throws DatastoreEmulatorException
stop()
. Note that
receiving an exception does not indicate that the server did not start. We recommend calling
stop()
to ensure the server is not running regardless of the result of this method.emulatorDir
- The path to the emulator directory, e.g. /usr/local/cloud-datastore-emulatorprojectId
- The project IDcommandLineOptions
- Command line options to pass to the emulator on startupDatastoreEmulatorException
- If start(java.lang.String, java.lang.String, java.lang.String...)
has already been called or the server does
not start successfully.public void start() throws DatastoreEmulatorException
DatastoreEmulatorException
public void stop() throws DatastoreEmulatorException
DatastoreEmulatorException
- if the emulator cannot be stoppedprotected void stopEmulatorInternal() throws DatastoreEmulatorException
DatastoreEmulatorException
public File getProjectDirectory()
Copyright © 2023 Google LLC. All rights reserved.