From 659ed06e5eb48921d53027ad9907f921aaa6d0f3 Mon Sep 17 00:00:00 2001 From: DPE bot Date: Wed, 27 Sep 2017 13:54:37 -0700 Subject: [PATCH 01/10] Auto-update dependencies. (#872) --- appengine-java8/analytics/pom.xml | 2 +- appengine-java8/appidentity/pom.xml | 2 +- appengine-java8/cloudsql/pom.xml | 2 +- appengine-java8/endpoints-v2-backend/pom.xml | 2 +- appengine-java8/endpoints-v2-guice/pom.xml | 2 +- appengine-java8/endpoints-v2-migration/pom.xml | 2 +- appengine-java8/images/pom.xml | 2 +- appengine-java8/postgres/pom.xml | 2 +- appengine-java8/spanner/pom.xml | 2 +- appengine-java8/taskqueues-deferred/pom.xml | 2 +- appengine/appidentity/pom.xml | 2 +- appengine/endpoints-frameworks-v2/backend/pom.xml | 2 +- appengine/endpoints-frameworks-v2/guice-example/pom.xml | 2 +- appengine/endpoints-frameworks-v2/migration-example/pom.xml | 2 +- appengine/endpoints-v1-helloworld/pom.xml | 2 +- appengine/firebase-tictactoe/pom.xml | 6 +++--- appengine/gaeinfo/pom.xml | 2 +- appengine/images/pom.xml | 2 +- appengine/pom.xml | 2 +- appengine/pusher-chat/pom.xml | 2 +- compute/cmdline/pom.xml | 2 +- flexible/gaeinfo/pom.xml | 2 +- flexible/pubsub/pom.xml | 4 ++-- kms/pom.xml | 2 +- storage/xml-api/serviceaccount-appengine-sample/pom.xml | 2 +- taskqueue/deferred/pom.xml | 2 +- unittests/pom.xml | 2 +- 27 files changed, 30 insertions(+), 30 deletions(-) diff --git a/appengine-java8/analytics/pom.xml b/appengine-java8/analytics/pom.xml index 43e286d8969..bdb82cbec9e 100644 --- a/appengine-java8/analytics/pom.xml +++ b/appengine-java8/analytics/pom.xml @@ -31,7 +31,7 @@ 1.8 1.8 - 1.9.56 + 1.9.57 diff --git a/appengine-java8/appidentity/pom.xml b/appengine-java8/appidentity/pom.xml index fba51f571da..5bb208d6921 100644 --- a/appengine-java8/appidentity/pom.xml +++ b/appengine-java8/appidentity/pom.xml @@ -30,7 +30,7 @@ 1.8 1.8 - 1.9.56 + 1.9.57 diff --git a/appengine-java8/cloudsql/pom.xml b/appengine-java8/cloudsql/pom.xml index 2dfb7b137a2..1ff842c0db6 100644 --- a/appengine-java8/cloudsql/pom.xml +++ b/appengine-java8/cloudsql/pom.xml @@ -49,7 +49,7 @@ com.google.appengine appengine-api-1.0-sdk - 1.9.56 + 1.9.57 diff --git a/appengine-java8/endpoints-v2-backend/pom.xml b/appengine-java8/endpoints-v2-backend/pom.xml index 14c34a7fc25..a8d40816188 100644 --- a/appengine-java8/endpoints-v2-backend/pom.xml +++ b/appengine-java8/endpoints-v2-backend/pom.xml @@ -55,7 +55,7 @@ com.google.appengine appengine-api-1.0-sdk - 1.9.56 + 1.9.57 javax.servlet diff --git a/appengine-java8/endpoints-v2-guice/pom.xml b/appengine-java8/endpoints-v2-guice/pom.xml index b2057cd2a67..cf500a2eb90 100644 --- a/appengine-java8/endpoints-v2-guice/pom.xml +++ b/appengine-java8/endpoints-v2-guice/pom.xml @@ -60,7 +60,7 @@ com.google.appengine appengine-api-1.0-sdk - 1.9.56 + 1.9.57 javax.servlet diff --git a/appengine-java8/endpoints-v2-migration/pom.xml b/appengine-java8/endpoints-v2-migration/pom.xml index 170c8a3fd26..2519eb031ad 100644 --- a/appengine-java8/endpoints-v2-migration/pom.xml +++ b/appengine-java8/endpoints-v2-migration/pom.xml @@ -47,7 +47,7 @@ limitations under the License. com.google.appengine appengine-api-1.0-sdk - 1.9.56 + 1.9.57 javax.servlet diff --git a/appengine-java8/images/pom.xml b/appengine-java8/images/pom.xml index 5672391db83..43e7ba6decc 100644 --- a/appengine-java8/images/pom.xml +++ b/appengine-java8/images/pom.xml @@ -21,7 +21,7 @@ Copyright 2015 Google Inc. appengine-images-j8 - 1.9.56 + 1.9.57 diff --git a/appengine-java8/postgres/pom.xml b/appengine-java8/postgres/pom.xml index 448af8dc0e9..b68bf51aa2b 100644 --- a/appengine-java8/postgres/pom.xml +++ b/appengine-java8/postgres/pom.xml @@ -49,7 +49,7 @@ com.google.appengine appengine-api-1.0-sdk - 1.9.56 + 1.9.57 diff --git a/appengine-java8/spanner/pom.xml b/appengine-java8/spanner/pom.xml index 8b00494d282..9a0f1c62017 100644 --- a/appengine-java8/spanner/pom.xml +++ b/appengine-java8/spanner/pom.xml @@ -48,7 +48,7 @@ com.google.appengine appengine-api-1.0-sdk - 1.9.56 + 1.9.57 diff --git a/appengine-java8/taskqueues-deferred/pom.xml b/appengine-java8/taskqueues-deferred/pom.xml index 2cb75269c07..a4c71e245f9 100644 --- a/appengine-java8/taskqueues-deferred/pom.xml +++ b/appengine-java8/taskqueues-deferred/pom.xml @@ -31,7 +31,7 @@ 1.8 1.8 - 1.9.56 + 1.9.57 diff --git a/appengine/appidentity/pom.xml b/appengine/appidentity/pom.xml index 754014c6d7e..0a8675f63ff 100644 --- a/appengine/appidentity/pom.xml +++ b/appengine/appidentity/pom.xml @@ -28,7 +28,7 @@ - 1.9.56 + 1.9.57 diff --git a/appengine/endpoints-frameworks-v2/backend/pom.xml b/appengine/endpoints-frameworks-v2/backend/pom.xml index 3d4df8484e7..1de45df6eb7 100644 --- a/appengine/endpoints-frameworks-v2/backend/pom.xml +++ b/appengine/endpoints-frameworks-v2/backend/pom.xml @@ -55,7 +55,7 @@ com.google.appengine appengine-api-1.0-sdk - 1.9.56 + 1.9.57 javax.servlet diff --git a/appengine/endpoints-frameworks-v2/guice-example/pom.xml b/appengine/endpoints-frameworks-v2/guice-example/pom.xml index 36395cd6533..bdff713978e 100644 --- a/appengine/endpoints-frameworks-v2/guice-example/pom.xml +++ b/appengine/endpoints-frameworks-v2/guice-example/pom.xml @@ -60,7 +60,7 @@ com.google.appengine appengine-api-1.0-sdk - 1.9.56 + 1.9.57 javax.servlet diff --git a/appengine/endpoints-frameworks-v2/migration-example/pom.xml b/appengine/endpoints-frameworks-v2/migration-example/pom.xml index c35361451cc..ceafa50923f 100644 --- a/appengine/endpoints-frameworks-v2/migration-example/pom.xml +++ b/appengine/endpoints-frameworks-v2/migration-example/pom.xml @@ -60,7 +60,7 @@ limitations under the License. com.google.appengine appengine-api-1.0-sdk - 1.9.56 + 1.9.57 javax.servlet diff --git a/appengine/endpoints-v1-helloworld/pom.xml b/appengine/endpoints-v1-helloworld/pom.xml index 2a2009665f4..09998c2cc0a 100644 --- a/appengine/endpoints-v1-helloworld/pom.xml +++ b/appengine/endpoints-v1-helloworld/pom.xml @@ -32,7 +32,7 @@ 1 UTF-8 - 1.9.56 + 1.9.57 1.7 1.7 diff --git a/appengine/firebase-tictactoe/pom.xml b/appengine/firebase-tictactoe/pom.xml index b7bd9184757..31607fd2089 100644 --- a/appengine/firebase-tictactoe/pom.xml +++ b/appengine/firebase-tictactoe/pom.xml @@ -34,7 +34,7 @@ com.google.appengine appengine-api-1.0-sdk - 1.9.56 + 1.9.57 com.google.api-client @@ -60,13 +60,13 @@ com.google.appengine appengine-api-stubs - 1.9.56 + 1.9.57 test com.google.appengine appengine-testing - 1.9.56 + 1.9.57 diff --git a/appengine/gaeinfo/pom.xml b/appengine/gaeinfo/pom.xml index e3e291eb4c4..e65da5a0bd0 100644 --- a/appengine/gaeinfo/pom.xml +++ b/appengine/gaeinfo/pom.xml @@ -39,7 +39,7 @@ Copyright 2017 Google Inc. com.google.appengine appengine-api-1.0-sdk - 1.9.56 + 1.9.57 diff --git a/appengine/images/pom.xml b/appengine/images/pom.xml index 6a101577595..295bfe18a87 100644 --- a/appengine/images/pom.xml +++ b/appengine/images/pom.xml @@ -21,7 +21,7 @@ Copyright 2015 Google Inc. appengine-images - 1.9.56 + 1.9.57 diff --git a/appengine/pom.xml b/appengine/pom.xml index 89040c55c3e..d4783e759e9 100644 --- a/appengine/pom.xml +++ b/appengine/pom.xml @@ -30,7 +30,7 @@ - 1.9.56 + 1.9.57 1 1.19.0 diff --git a/appengine/pusher-chat/pom.xml b/appengine/pusher-chat/pom.xml index 259eb80e163..9d7ec100771 100644 --- a/appengine/pusher-chat/pom.xml +++ b/appengine/pusher-chat/pom.xml @@ -57,7 +57,7 @@ Copyright 2017 Google Inc. com.google.appengine appengine-api-1.0-sdk - 1.9.56 + 1.9.57 diff --git a/compute/cmdline/pom.xml b/compute/cmdline/pom.xml index 7a0bfa4dbd5..fca6054b266 100644 --- a/compute/cmdline/pom.xml +++ b/compute/cmdline/pom.xml @@ -84,7 +84,7 @@ limitations under the License. - v1-rev156-1.22.0 + v1-rev157-1.22.0 UTF-8 diff --git a/flexible/gaeinfo/pom.xml b/flexible/gaeinfo/pom.xml index 893a573be90..c920c4296d7 100644 --- a/flexible/gaeinfo/pom.xml +++ b/flexible/gaeinfo/pom.xml @@ -39,7 +39,7 @@ Copyright 2017 Google Inc. com.google.appengine appengine-api-1.0-sdk - 1.9.56 + 1.9.57 diff --git a/flexible/pubsub/pom.xml b/flexible/pubsub/pom.xml index 21adb792d4e..904b902a5bd 100644 --- a/flexible/pubsub/pom.xml +++ b/flexible/pubsub/pom.xml @@ -76,13 +76,13 @@ com.google.appengine appengine-api-stubs - 1.9.56 + 1.9.57 test com.google.appengine appengine-tools-sdk - 1.9.56 + 1.9.57 test diff --git a/kms/pom.xml b/kms/pom.xml index c5193aed442..bc4aff2d29f 100644 --- a/kms/pom.xml +++ b/kms/pom.xml @@ -16,7 +16,7 @@ com.google.apis google-api-services-cloudkms - v1-rev20-1.22.0 + v1-rev21-1.22.0 com.google.guava diff --git a/storage/xml-api/serviceaccount-appengine-sample/pom.xml b/storage/xml-api/serviceaccount-appengine-sample/pom.xml index 8c7264deebf..baddaaa6b12 100644 --- a/storage/xml-api/serviceaccount-appengine-sample/pom.xml +++ b/storage/xml-api/serviceaccount-appengine-sample/pom.xml @@ -33,7 +33,7 @@ 1.7 1.7 - 1.9.56 + 1.9.57 1.22.0 ${project.build.directory}/${project.build.finalName} diff --git a/taskqueue/deferred/pom.xml b/taskqueue/deferred/pom.xml index 92c78cb3071..9da47ae996e 100644 --- a/taskqueue/deferred/pom.xml +++ b/taskqueue/deferred/pom.xml @@ -31,7 +31,7 @@ 1.7 1.7 - 1.9.56 + 1.9.57 2.5 3.1.0 diff --git a/unittests/pom.xml b/unittests/pom.xml index 896f2e170d1..e370b91b7f4 100644 --- a/unittests/pom.xml +++ b/unittests/pom.xml @@ -19,7 +19,7 @@ 1.7 1.7 - 1.9.56 + 1.9.57 UTF-8 3.1.0 2.5.1 From fcc79a45220a955fbd5cd04ce815e71dff66d1f0 Mon Sep 17 00:00:00 2001 From: Noah Negrey Date: Wed, 27 Sep 2017 14:00:15 -0700 Subject: [PATCH 02/10] Update package import to appengine (#870) --- appengine-java8/pubsub/src/main/webapp/index.jsp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/appengine-java8/pubsub/src/main/webapp/index.jsp b/appengine-java8/pubsub/src/main/webapp/index.jsp index fa12f02a14d..9b5bc1cfd85 100644 --- a/appengine-java8/pubsub/src/main/webapp/index.jsp +++ b/appengine-java8/pubsub/src/main/webapp/index.jsp @@ -1,4 +1,4 @@ -<%@ page import="com.example.flexible.pubsub.PubSubHome" %> +<%@ page import="com.example.appengine.pubsub.PubSubHome" %> From f554c480bcecd48b285ceef6f2351542c82d1b9c Mon Sep 17 00:00:00 2001 From: Gus Class Date: Wed, 27 Sep 2017 21:44:10 -0700 Subject: [PATCH 03/10] Updates instructions for jar installation (#869) --- iot/api-client/manager/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/iot/api-client/manager/README.md b/iot/api-client/manager/README.md index daf4c47125a..76859c74809 100644 --- a/iot/api-client/manager/README.md +++ b/iot/api-client/manager/README.md @@ -10,7 +10,7 @@ PubSub topic for Cloud IoT as described in [the parent README](../README.md). Manually install [the provided client library](https://cloud.google.com/iot/resources/java/cloud-iot-core-library.jar) for Cloud IoT Core to Maven: - mvn install:install-file -Dfile=cloud-iot-core-library.jar -DgroupId=com.example.apis \ + mvn install:install-file -Dfile=cloud-iot-core-library.jar -DgroupId=com.google.apis \ -DartifactId=google-api-services-cloudiot -Dversion=v1beta1-rev20170926-1.22.0-SNAPSHOT \ -Dpackaging=jar From 59034828851f0815c56a7431667b6e0d62f93612 Mon Sep 17 00:00:00 2001 From: Gus Class Date: Thu, 28 Sep 2017 09:45:13 -0700 Subject: [PATCH 04/10] Use published artifact for IoT (#874) * Updates instructions for jar installation * Uses published client library --- iot/api-client/manager/README.md | 8 -------- iot/api-client/manager/pom.xml | 2 +- 2 files changed, 1 insertion(+), 9 deletions(-) diff --git a/iot/api-client/manager/README.md b/iot/api-client/manager/README.md index 76859c74809..4a5fdbe4d04 100644 --- a/iot/api-client/manager/README.md +++ b/iot/api-client/manager/README.md @@ -6,14 +6,6 @@ Note that before you can run the sample, you must configure a Google Cloud PubSub topic for Cloud IoT as described in [the parent README](../README.md). ## Setup - -Manually install [the provided client library](https://cloud.google.com/iot/resources/java/cloud-iot-core-library.jar) -for Cloud IoT Core to Maven: - - mvn install:install-file -Dfile=cloud-iot-core-library.jar -DgroupId=com.google.apis \ - -DartifactId=google-api-services-cloudiot -Dversion=v1beta1-rev20170926-1.22.0-SNAPSHOT \ - -Dpackaging=jar - Run the following command to install the libraries and build the sample with Maven: diff --git a/iot/api-client/manager/pom.xml b/iot/api-client/manager/pom.xml index 8c060ff5f91..59f142d84e3 100644 --- a/iot/api-client/manager/pom.xml +++ b/iot/api-client/manager/pom.xml @@ -40,7 +40,7 @@ com.google.apis google-api-services-cloudiot - v1beta1-rev20170926-1.22.0-SNAPSHOT + v1-rev20170922-1.22.0 com.google.cloud From 9eb1f783dd7c8ff17630e690f3ff66631840fd57 Mon Sep 17 00:00:00 2001 From: DPE bot Date: Thu, 28 Sep 2017 10:12:58 -0700 Subject: [PATCH 05/10] Auto-update dependencies. (#875) --- storage/storage-transfer/pom.xml | 2 +- vision/face-detection/pom.xml | 2 +- vision/label/pom.xml | 2 +- vision/landmark-detection/pom.xml | 2 +- vision/text/pom.xml | 2 +- 5 files changed, 5 insertions(+), 5 deletions(-) diff --git a/storage/storage-transfer/pom.xml b/storage/storage-transfer/pom.xml index 2f15f2c1fc8..5d8fa677bac 100644 --- a/storage/storage-transfer/pom.xml +++ b/storage/storage-transfer/pom.xml @@ -38,7 +38,7 @@ com.google.apis google-api-services-storagetransfer - v1-rev24-1.22.0 + v1-rev25-1.22.0 com.google.guava diff --git a/vision/face-detection/pom.xml b/vision/face-detection/pom.xml index 9b03e7fde5d..20689ee96a6 100644 --- a/vision/face-detection/pom.xml +++ b/vision/face-detection/pom.xml @@ -39,7 +39,7 @@ com.google.apis google-api-services-vision - v1-rev361-1.22.0 + v1-rev362-1.22.0 com.google.api-client diff --git a/vision/label/pom.xml b/vision/label/pom.xml index b861b0a9a0b..2a33d98323c 100644 --- a/vision/label/pom.xml +++ b/vision/label/pom.xml @@ -38,7 +38,7 @@ com.google.apis google-api-services-vision - v1-rev361-1.22.0 + v1-rev362-1.22.0 com.google.api-client diff --git a/vision/landmark-detection/pom.xml b/vision/landmark-detection/pom.xml index f6c7445e73f..620a03dca16 100644 --- a/vision/landmark-detection/pom.xml +++ b/vision/landmark-detection/pom.xml @@ -38,7 +38,7 @@ com.google.apis google-api-services-vision - v1-rev361-1.22.0 + v1-rev362-1.22.0 com.google.api-client diff --git a/vision/text/pom.xml b/vision/text/pom.xml index b74b3286e2f..8af3bb2d9de 100644 --- a/vision/text/pom.xml +++ b/vision/text/pom.xml @@ -38,7 +38,7 @@ com.google.apis google-api-services-vision - v1-rev361-1.22.0 + v1-rev362-1.22.0 com.google.api-client From fe135c7e85073255d62b3f8b275270f8c2bbccfb Mon Sep 17 00:00:00 2001 From: DPE bot Date: Sat, 30 Sep 2017 14:45:33 -0700 Subject: [PATCH 06/10] Auto-update dependencies. (#876) --- kms/pom.xml | 2 +- storage/json-api/pom.xml | 2 +- storage/xml-api/cmdline-sample/pom.xml | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/kms/pom.xml b/kms/pom.xml index bc4aff2d29f..e21b3889075 100644 --- a/kms/pom.xml +++ b/kms/pom.xml @@ -16,7 +16,7 @@ com.google.apis google-api-services-cloudkms - v1-rev21-1.22.0 + v1-rev22-1.22.0 com.google.guava diff --git a/storage/json-api/pom.xml b/storage/json-api/pom.xml index 42f2a4ecc1b..2ad785f59bd 100644 --- a/storage/json-api/pom.xml +++ b/storage/json-api/pom.xml @@ -38,7 +38,7 @@ com.google.apis google-api-services-storage - v1-rev111-1.22.0 + v1-rev112-1.22.0 com.google.guava diff --git a/storage/xml-api/cmdline-sample/pom.xml b/storage/xml-api/cmdline-sample/pom.xml index 2b4c6a6943a..e0732e7d3e3 100644 --- a/storage/xml-api/cmdline-sample/pom.xml +++ b/storage/xml-api/cmdline-sample/pom.xml @@ -66,7 +66,7 @@ com.google.apis google-api-services-storage - v1-rev111-1.22.0 + v1-rev112-1.22.0 com.google.guava From 4a15b3663537048c1d7f83fead8a77cd99e518c3 Mon Sep 17 00:00:00 2001 From: Jisha Abubaker Date: Tue, 3 Oct 2017 08:52:50 -0700 Subject: [PATCH 07/10] Adding firestore samples (#877) --- firestore/README.md | 47 ++ firestore/pom.xml | 58 +++ .../com/example/firestore/Quickstart.java | 196 +++++++++ .../snippets/ManageDataSnippets.java | 402 ++++++++++++++++++ .../firestore/snippets/QueryDataSnippets.java | 308 ++++++++++++++ .../firestore/snippets/References.java | 82 ++++ .../snippets/RetrieveDataSnippets.java | 138 ++++++ .../firestore/snippets/model/City.java | 144 +++++++ .../com/example/firestore/QuickstartIT.java | 120 ++++++ .../snippets/ManageDataSnippetsIT.java | 213 ++++++++++ .../snippets/QueryDataSnippetsIT.java | 225 ++++++++++ .../snippets/RetrieveDataSnippetsIT.java | 113 +++++ pom.xml | 2 + 13 files changed, 2048 insertions(+) create mode 100644 firestore/README.md create mode 100644 firestore/pom.xml create mode 100644 firestore/src/main/java/com/example/firestore/Quickstart.java create mode 100644 firestore/src/main/java/com/example/firestore/snippets/ManageDataSnippets.java create mode 100644 firestore/src/main/java/com/example/firestore/snippets/QueryDataSnippets.java create mode 100644 firestore/src/main/java/com/example/firestore/snippets/References.java create mode 100644 firestore/src/main/java/com/example/firestore/snippets/RetrieveDataSnippets.java create mode 100644 firestore/src/main/java/com/example/firestore/snippets/model/City.java create mode 100644 firestore/src/test/java/com/example/firestore/QuickstartIT.java create mode 100644 firestore/src/test/java/com/example/firestore/snippets/ManageDataSnippetsIT.java create mode 100644 firestore/src/test/java/com/example/firestore/snippets/QueryDataSnippetsIT.java create mode 100644 firestore/src/test/java/com/example/firestore/snippets/RetrieveDataSnippetsIT.java diff --git a/firestore/README.md b/firestore/README.md new file mode 100644 index 00000000000..db5d5612582 --- /dev/null +++ b/firestore/README.md @@ -0,0 +1,47 @@ +# Getting started with Google Cloud Firestore +[Google Cloud Firestore](https://cloud.google.com/firestore/docs/) is a hosted NoSQL database built +for automatic scaling, high performance, and ease of application development. + +These code samples demonstrate how to access the Google Cloud Firestore API +using the Beta version of the Firestore Client Libraries. + +Note: You cannot use both Cloud Firestore and Cloud Datastore in the +same project, which might affect apps using App Engine. Try using Cloud Firestore with a different +project. + +## Setup +- Install [Maven](http://maven.apache.org/). +- Open the [Firebase Console](https://console.firebase.com) and click **Add project**. +- Select the option to **Enable Cloud Firestore Beta** for this project. +- Click **Create Project**. + When you create a Cloud Firestore project, it also enables the API in the + [Cloud API Manager](https://console.cloud.google.com/projectselector/apis/api/firestore.googleapis.com/overview). +- [Create a service account](https://cloud.google.com/docs/authentication/) + and set the `GOOGLE_APPLICATION_CREDENTIALS` environment variable to point to the + credentials JSON file. + +## Build +Build your project: + + mvn clean package + + +## Quickstart +[Quickstart.java](src/main/java/com/example/java/com/example/firestore/Quicstart.java) + demonstrates adding and querying documents in a collection in Firestore. +You can run the quickstart with: + + mvn exec:java -Dexec.mainClass=com.example.firestore.Quickstart -Dexec.args="your-firestore-project-id" + +Note: the default project-id will be used if no argument is provided. + +## Snippets +These [code samples](src/main/java/com/example/firestore/snippets) support +the Firestore [documentation](https://cloud.google.com/firestore/docs). + +## Tests +Run all tests: +``` + mvn clean verify +``` + diff --git a/firestore/pom.xml b/firestore/pom.xml new file mode 100644 index 00000000000..1c84ee450aa --- /dev/null +++ b/firestore/pom.xml @@ -0,0 +1,58 @@ + + + + 4.0.0 + com.example.firestore + firestore-samples + 1.0.0 + jar + Google Cloud Firestore Samples + + Quick start and code snippets supporting Firestore documentation + + + + doc-samples + com.google.cloud + 1.0.0 + .. + + + + 1.7 + 1.7 + + + + + + + com.google.cloud + google-cloud-firestore + 0.25.0-beta + + + + + + junit + junit + 4.12 + test + + + diff --git a/firestore/src/main/java/com/example/firestore/Quickstart.java b/firestore/src/main/java/com/example/firestore/Quickstart.java new file mode 100644 index 00000000000..9149dafd61d --- /dev/null +++ b/firestore/src/main/java/com/example/firestore/Quickstart.java @@ -0,0 +1,196 @@ +/* + * Copyright 2017 Google Inc. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except + * in compliance with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under the License + * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express + * or implied. See the License for the specific language governing permissions and limitations under + * the License. + */ + +package com.example.firestore; + +import com.google.api.core.ApiFuture; +import com.google.cloud.firestore.DocumentReference; +import com.google.cloud.firestore.DocumentSnapshot; +// [START fs_include_dependencies] +import com.google.cloud.firestore.Firestore; +import com.google.cloud.firestore.FirestoreOptions; +// [END fs_include_dependencies] +import com.google.cloud.firestore.QuerySnapshot; +import com.google.cloud.firestore.WriteResult; +import com.google.common.collect.ImmutableMap; + +import java.util.HashMap; +import java.util.List; +import java.util.Map; + +/** + * A simple Quick start application demonstrating how to connect to Firestore + * and add and query documents. + */ +public class Quickstart { + + private Firestore db; + + /** + * Initialize Firestore using default project ID. + */ + public Quickstart() { + // [START fs_initialize] + Firestore db = FirestoreOptions.getDefaultInstance().getService(); + // [END fs_initialize] + this.db = db; + } + + public Quickstart(String projectId) { + // [START fs_initialize_project_id] + FirestoreOptions firestoreOptions = + FirestoreOptions.getDefaultInstance().toBuilder() + .setProjectId(projectId) + .build(); + Firestore db = firestoreOptions.getService(); + // [END fs_initialize_project_id] + this.db = db; + } + + Firestore getDb() { + return db; + } + + /** + * Add named test documents with fields first, last, middle (optional), born. + * + * @param docName document name + */ + void addDocument(String docName) throws Exception { + switch (docName) { + case "alovelace": { + // [START fs_add_data_1] + DocumentReference docRef = db.collection("users").document("alovelace"); + // Add document data with id "alovelace" using a hashmap + Map data = new HashMap<>(); + data.put("first", "Ada"); + data.put("last", "Lovelace"); + data.put("born", 1815); + //asynchronously write data + ApiFuture result = docRef.set(data); + // ... + // result.get() blocks on response + System.out.println("Update time : " + result.get().getUpdateTime()); + // [END fs_add_data_1] + break; + } + case "aturing": { + // [START fs_add_data_2] + DocumentReference docRef = db.collection("users").document("aturing"); + // Add document data with an additional field ("middle") + Map data = new HashMap<>(); + data.put("first", "Alan"); + data.put("middle", "Mathison"); + data.put("last", "Turing"); + data.put("born", 1912); + + ApiFuture result = docRef.set(data); + System.out.println("Update time : " + result.get().getUpdateTime()); + // [END fs_add_data_2] + break; + } + case "cbabbage": { + DocumentReference docRef = db.collection("users").document("cbabbage"); + Map data = + new ImmutableMap.Builder() + .put("first", "Charles") + .put("last", "Babbage") + .put("born", 1791) + .build(); + ApiFuture result = docRef.set(data); + System.out.println("Update time : " + result.get().getUpdateTime()); + break; + } + default: + } + } + + void runAQuery() throws Exception { + // [START fs_add_query] + // asynchronously query for all users born before 1900 + ApiFuture query = + db.collection("users").whereLessThan("born", 1900).get(); + // ... + // query.get() blocks on response + QuerySnapshot querySnapshot = query.get(); + List documents = querySnapshot.getDocuments(); + for (DocumentSnapshot document : documents) { + System.out.println("User: " + document.getId()); + System.out.println("First: " + document.getString("first")); + if (document.contains("middle")) { + System.out.println("Middle: " + document.getString("middle")); + } + System.out.println("Last: " + document.getString("last")); + System.out.println("Born: " + document.getLong("born")); + } + // [END fs_add_query] + } + + void retrieveAllDocuments() throws Exception { + // [START fs_get_all] + // asynchronously retrieve all users + ApiFuture query = db.collection("users").get(); + // ... + // query.get() blocks on response + QuerySnapshot querySnapshot = query.get(); + List documents = querySnapshot.getDocuments(); + for (DocumentSnapshot document : documents) { + System.out.println("User: " + document.getId()); + System.out.println("First: " + document.getString("first")); + if (document.contains("middle")) { + System.out.println("Middle: " + document.getString("middle")); + } + System.out.println("Last: " + document.getString("last")); + System.out.println("Born: " + document.getLong("born")); + } + // [END fs_get_all] + } + + void run() throws Exception { + String[] docNames = {"alovelace", "aturing", "cbabbage"}; + + // Adding document 1 + System.out.println("########## Adding document 1 ##########"); + addDocument(docNames[0]); + + // Adding document 2 + System.out.println("########## Adding document 2 ##########"); + addDocument(docNames[1]); + + // Adding document 3 + System.out.println("########## Adding document 3 ##########"); + addDocument(docNames[2]); + + // retrieve all users born before 1900 + System.out.println("########## users born before 1900 ##########"); + runAQuery(); + + // retrieve all users + System.out.println("########## All users ##########"); + retrieveAllDocuments(); + System.out.println("###################################"); + } + + /** + * A quick start application to get started with Firestore. + * + * @param args firestore-project-id (optional) + */ + public static void main(String[] args) throws Exception { + // default project is will be used if project-id argument is not available + String projectId = (args.length == 0) ? null : args[0]; + Quickstart quickStart = (projectId != null) ? new Quickstart(projectId) : new Quickstart(); + quickStart.run(); + } +} diff --git a/firestore/src/main/java/com/example/firestore/snippets/ManageDataSnippets.java b/firestore/src/main/java/com/example/firestore/snippets/ManageDataSnippets.java new file mode 100644 index 00000000000..30427e705c9 --- /dev/null +++ b/firestore/src/main/java/com/example/firestore/snippets/ManageDataSnippets.java @@ -0,0 +1,402 @@ +/* + * Copyright 2017 Google Inc. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except + * in compliance with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under the License + * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express + * or implied. See the License for the specific language governing permissions and limitations under + * the License. + */ + +package com.example.firestore.snippets; + +import com.example.firestore.snippets.model.City; +import com.google.api.core.ApiFuture; +import com.google.cloud.firestore.CollectionReference; +import com.google.cloud.firestore.DocumentReference; +import com.google.cloud.firestore.DocumentSnapshot; +import com.google.cloud.firestore.FieldValue; +import com.google.cloud.firestore.Firestore; +import com.google.cloud.firestore.QuerySnapshot; +import com.google.cloud.firestore.SetOptions; +import com.google.cloud.firestore.Transaction; +import com.google.cloud.firestore.WriteBatch; +import com.google.cloud.firestore.WriteResult; +import java.util.ArrayList; +import java.util.Collections; +import java.util.HashMap; +import java.util.List; +import java.util.Map; + +/** Snippets to demonstrate Firestore add, update and delete operations. */ +class ManageDataSnippets { + + private final Firestore db; + + ManageDataSnippets(Firestore db) { + this.db = db; + } + + /** + * Add a document to a collection using a map. + * + * @return document data + */ + Map addSimpleDocumentAsMap() throws Exception { + // [START fs_add_doc_as_map] + // Create a Map to store the data we want to set + Map docData = new HashMap<>(); + docData.put("name", "Los Angeles"); + docData.put("state", "CA"); + docData.put("country", "USA"); + // Add a new document (asynchronously) in collection "cities" with id "LA" + ApiFuture future = db.collection("cities").document("LA").set(docData); + // ... + // future.get() blocks on response + System.out.println("Update time : " + future.get().getUpdateTime()); + // [END fs_add_doc_as_map] + return docData; + } + + /** + * Add a document to a collection using a map with different supported data types. + * + * @return document data + */ + Map addDocumentWithDifferentDataTypes() throws Exception { + // [START fs_add_doc_data_types] + Map docData = new HashMap<>(); + docData.put("stringExample", "Hello, World"); + docData.put("booleanExample", false); + docData.put("numberExample", 3.14159265); + docData.put("nullExample", null); + + ArrayList arrayExample = new ArrayList<>(); + Collections.addAll(arrayExample, 5L, true, "hello"); + docData.put("arrayExample", arrayExample); + + Map objectExample = new HashMap<>(); + objectExample.put("a", 5L); + objectExample.put("b", true); + + docData.put("objectExample", objectExample); + + ApiFuture future = db.collection("data").document("one").set(docData); + System.out.println("Update time : " + future.get().getUpdateTime()); + // [END fs_add_doc_data_types] + + return docData; + } + + /** + * Add a document to a collection as a custom object. + * + * @return entity added + */ + City addSimpleDocumentAsEntity() throws Exception { + // [START fs_add_simple_doc_as_entity] + City city = new City("Los Angeles", "CA", "USA", false, 3900000L); + ApiFuture future = db.collection("cities").document("LA").set(city); + // block on response if required + System.out.println("Update time : " + future.get().getUpdateTime()); + // [END fs_add_simple_doc_as_entity] + + return city; + } + + /** + * set() providing a document ID. + */ + void setRequiresId(Map data) { + // [START fs_set_requires_id] + db.collection("cities").document("new-city-id").set(data); + // [END fs_set_requires_id] + } + + /** + * Add a document without explicitly providing the document id. The document id gets automatically + * generated. + * + * @return auto generated id + */ + String addDocumentDataWithAutoGeneratedId() throws Exception { + // [START fs_add_doc_data_with_auto_id] + // Add document data with auto-generated id. + Map data = new HashMap<>(); + data.put("name", "Tokyo"); + data.put("country", "Japan"); + ApiFuture addedDocRef = db.collection("cities").add(data); + System.out.println("Added document with ID: " + addedDocRef.get().getId()); + // [END fs_add_doc_data_with_auto_id] + + return addedDocRef.get().getId(); + } + + /** + * Add data to a document after generating the document id. + * + * @return auto generated id + */ + String addDocumentDataAfterAutoGeneratingId() throws Exception { + City data = new City(); + + // [START fs_add_doc_data_after_auto_id] + // Add document data after generating an id. + DocumentReference addedDocRef = db.collection("cities").document(); + System.out.println("Added document with ID: " + addedDocRef.getId()); + + // later... + ApiFuture writeResult = addedDocRef.set(data); + // [END fs_add_doc_data_after_auto_id] + + // writeResult.get() blocks on operation + System.out.println("Update time : " + writeResult.get().getUpdateTime()); + return addedDocRef.getId(); + } + + /** Partially update a document using the .update(field1, value1..) method. */ + void updateSimpleDocument() throws Exception { + db.collection("cities").document("DC").set(new City("Washington D.C.")).get(); + // [START fs_update_doc] + // Update an existing document + DocumentReference docRef = db.collection("cities").document("DC"); + + // (async) Update one field + ApiFuture future = docRef.update("capital", true); + + // ... + WriteResult result = future.get(); + System.out.println("Write result: " + result); + // [END fs_update_doc] + } + + /** Partially update fields of a document using a map (field => value). */ + void updateUsingMap() throws Exception { + db.collection("cities").document("DC").set(new City("Washington D.C.")).get(); + // [START fs_update_doc_map] + // update multiple fields using a map + DocumentReference docRef = db.collection("cities").document("DC"); + + Map updates = new HashMap<>(); + updates.put("name", "Washington D.C."); + updates.put("country", "USA"); + updates.put("capital", true); + + //asynchronously update doc + ApiFuture writeResult = docRef.update(updates); + // ... + System.out.println("Update time : " + writeResult.get().getUpdateTime()); + // [END fs_update_doc_map] + } + + /** Partially update fields of a document using a map (field => value). */ + void updateAndCreateIfMissing() throws Exception { + // [START fs_update_create_if_missing] + //asynchronously update doc, create the document if missing + Map update = new HashMap<>(); + update.put("capital", true); + + ApiFuture writeResult = + db + .collection("cities") + .document("BJ") + .set(update, SetOptions.merge()); + // ... + System.out.println("Update time : " + writeResult.get().getUpdateTime()); + // [END fs_update_create_if_missing] + } + + /** Partial update nested fields of a document. */ + void updateNestedFields() throws Exception { + // [START fs_update_nested_fields] + // Create an initial document to update + DocumentReference frankDocRef = db.collection("users").document("frank"); + Map initialData = new HashMap<>(); + initialData.put("name", "Frank"); + initialData.put("age", 12); + + Map favorites = new HashMap<>(); + favorites.put("food", "Pizza"); + favorites.put("color", "Blue"); + favorites.put("subject", "Recess"); + initialData.put("favorites", favorites); + + ApiFuture initialResult = frankDocRef.set(initialData); + // Confirm that data has been successfully saved by blocking on the operation + initialResult.get(); + + // Update age and favorite color + Map updates = new HashMap<>(); + updates.put("age", 13); + updates.put("favorites.color", "Red"); + + // Async update document + ApiFuture writeResult = frankDocRef.update(updates); + // ... + System.out.println("Update time : " + writeResult.get().getUpdateTime()); + // [END fs_update_nested_fields] + } + + /** Update document with server timestamp. */ + void updateServerTimestamp() throws Exception { + db.collection("objects").document("some-id").set(new HashMap()).get(); + + // [START fs_update_server_timestamp] + DocumentReference docRef = db.collection("objects").document("some-id"); + // Update the timestamp field with the value from the server + ApiFuture writeResult = docRef.update("timestamp", FieldValue.serverTimestamp()); + System.out.println("Update time : " + writeResult.get()); + // [END fs_update_server_timestamp] + } + + /** Delete specific fields when updating a document. */ + void deleteFields() throws Exception { + City city = new City("Beijing"); + city.setCapital(true); + db.collection("cities").document("BJ").set(city).get(); + + // [START fs_delete_fields] + DocumentReference docRef = db.collection("cities").document("BJ"); + Map updates = new HashMap<>(); + updates.put("capital", FieldValue.delete()); + // Update and delete the "capital" field in the document + ApiFuture writeResult = docRef.update(updates); + System.out.println("Update time : " + writeResult.get()); + // [END fs_delete_fields] + } + + /** Delete a document in a collection. */ + void deleteDocument() throws Exception { + db.collection("cities").document("DC").set(new City("Washington, D.C.")).get(); + // [START fs_delete_doc] + // asynchronously delete a document + ApiFuture writeResult = db.collection("cities").document("DC").delete(); + // ... + System.out.println("Update time : " + writeResult.get().getUpdateTime()); + // [END fs_delete_doc] + } + + // [START fs_delete_collection] + /** Delete a collection in batches to avoid out-of-memory errors. + * Batch size may be tuned based on document size (atmost 1MB) and application requirements. + */ + void deleteCollection(CollectionReference collection, int batchSize) { + try { + // retrieve a small batch of documents to avoid out-of-memory errors + ApiFuture future = collection.limit(batchSize).get(); + int deleted = 0; + // future.get() blocks on document retrieval + List documents = future.get().getDocuments(); + for (DocumentSnapshot document : documents) { + document.getReference().delete(); + ++deleted; + } + if (deleted >= batchSize) { + // retrieve and delete another batch + deleteCollection(collection, batchSize); + } + } catch (Exception e) { + System.err.println("Error deleting collection : " + e.getMessage()); + } + } + // [END fs_delete_collection] + + /** Run a simple transaction to perform a field value increment. + * + * @return transaction future + */ + ApiFuture runSimpleTransaction() throws Exception { + // [START fs_run_simple_transaction] + // Initialize doc + final DocumentReference docRef = db.collection("cities").document("SF"); + City city = new City("SF"); + city.setCountry("USA"); + city.setPopulation(860000L); + docRef.set(city).get(); + + // run an asynchronous transaction + ApiFuture transaction = + db.runTransaction( + new Transaction.Function() { + @Override + public Void updateCallback(Transaction transaction) throws Exception { + // retrieve document and increment population field + DocumentSnapshot snapshot = transaction.get(docRef).get(); + long oldPopulation = snapshot.getLong("population"); + transaction.update(docRef, "population", oldPopulation + 1); + return null; + } + }); + // block on transaction operation using transaction.get() + // [END fs_run_simple_transaction] + return transaction; + } + + /** + * Return information from a conditional transaction. + * + * + * @param population : set initial population. + */ + String returnInfoFromTransaction(long population) throws Exception { + Map map = new HashMap<>(); + map.put("population", population); + db.collection("cities").document("SF").set(map); + // [START fs_return_info_transaction] + final DocumentReference docRef = db.collection("cities").document("SF"); + ApiFuture transaction = + db.runTransaction( + new Transaction.Function() { + @Override + public String updateCallback(Transaction transaction) throws Exception { + DocumentSnapshot snapshot = transaction.get(docRef).get(); + Long newPopulation = snapshot.getLong("population") + 1; + // conditionally update based on current population + if (newPopulation <= 1000000L) { + transaction.update(docRef, "population", newPopulation); + return "Population increased to " + newPopulation; + } else { + throw new Exception("Sorry! Population is too big."); + } + } + }); + // Print information retrieved from transaction + System.out.println(transaction.get()); + // [END fs_return_info_transaction] + return transaction.get(); + } + + /** Write documents in a batch. */ + void writeBatch() throws Exception { + db.collection("cities").document("SF").set(new City()).get(); + db.collection("cities").document("LA").set(new City()).get(); + + // [START fs_write_batch] + // Get a new write batch + WriteBatch batch = db.batch(); + // Set the value of 'NYC' + DocumentReference nycRef = db.collection("cities").document("NYC"); + batch.set(nycRef, new City()); + + // Update the population of 'SF' + DocumentReference sfRef = db.collection("cities").document("SF"); + batch.update(sfRef, "population", 1000000L); + + // Delete the city 'LA' + DocumentReference laRef = db.collection("cities").document("LA"); + batch.delete(laRef); + + // asynchronously commit the batch + ApiFuture> future = batch.commit(); + // ... + // future.get() blocks on batch commit operation + for (WriteResult result :future.get()) { + System.out.println("Update time : " + result.getUpdateTime()); + } + // [END fs_write_batch] + } +} diff --git a/firestore/src/main/java/com/example/firestore/snippets/QueryDataSnippets.java b/firestore/src/main/java/com/example/firestore/snippets/QueryDataSnippets.java new file mode 100644 index 00000000000..b3389216232 --- /dev/null +++ b/firestore/src/main/java/com/example/firestore/snippets/QueryDataSnippets.java @@ -0,0 +1,308 @@ +/* + * Copyright 2017 Google Inc. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except + * in compliance with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under the License + * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express + * or implied. See the License for the specific language governing permissions and limitations under + * the License. + */ + +package com.example.firestore.snippets; + +import com.example.firestore.snippets.model.City; + +import com.google.api.core.ApiFuture; +import com.google.api.core.ApiFutures; +import com.google.cloud.firestore.CollectionReference; +import com.google.cloud.firestore.DocumentSnapshot; +import com.google.cloud.firestore.Firestore; +import com.google.cloud.firestore.Query; +import com.google.cloud.firestore.Query.Direction; +import com.google.cloud.firestore.QuerySnapshot; +import com.google.cloud.firestore.WriteResult; + +import java.util.ArrayList; +import java.util.List; + +/** Snippets to support firestore querying data documentation. */ +class QueryDataSnippets { + + private final Firestore db; + + QueryDataSnippets(Firestore db) { + this.db = db; + } + + /** + * Creates cities collection and add sample documents to test queries. + * + * @return collection reference + */ + void prepareExamples() throws Exception { + // [START fs_query_create_examples] + CollectionReference cities = db.collection("cities"); + List> futures = new ArrayList<>(); + futures.add(cities.document("SF").set(new City("San Francisco", "CA", "USA", false, 860000L))); + futures.add(cities.document("LA").set(new City("Los Angeles", "CA", "USA", false, 3900000L))); + futures.add(cities.document("DC").set(new City("Washington D.C.", null, "USA", true, 680000L))); + futures.add(cities.document("TOK").set(new City("Tokyo", null, "Japan", true, 9000000L))); + futures.add(cities.document("BJ").set(new City("Beijing", null, "China", true, 21500000L))); + // (optional) block on documents successfully added + ApiFutures.allAsList(futures).get(); + // [END fs_query_create_examples] + } + + /** + * Creates a sample query. + * + * @return query + */ + Query createAQuery() throws Exception { + // [START fs_create_query] + // Create a reference to the cities collection + CollectionReference cities = db.collection("cities"); + // Create a query against the collection. + Query query = cities.whereEqualTo("capital", true); + // retrieve query results asynchronously using query.get() + ApiFuture querySnapshot = query.get(); + + for (DocumentSnapshot document : querySnapshot.get().getDocuments()) { + System.out.println(document.getId()); + } + // [END fs_create_query] + return query; + } + + /** + * Creates a sample query. + * + * @return query + */ + Query createAQueryAlternate() throws Exception { + // [START fs_create_query_country] + // Create a reference to the cities collection + CollectionReference cities = db.collection("cities"); + // Create a query against the collection. + Query query = cities.whereEqualTo("state", "CA"); + // retrieve query results asynchronously using query.get() + ApiFuture querySnapshot = query.get(); + + for (DocumentSnapshot document : querySnapshot.get().getDocuments()) { + System.out.println(document.getId()); + } + // [END fs_create_query_country] + return query; + } + + /** + * Creates queries with simple where clauses. + * + * @return queries + */ + List createSimpleQueries() { + List querys = new ArrayList<>(); + CollectionReference cities = db.collection("cities"); + + // [START fs_simple_queries] + Query countryQuery = cities.whereEqualTo("state", "CA"); + Query populationQuery = cities.whereLessThan("population", 1000000L); + Query cityQuery = cities.whereGreaterThanOrEqualTo("name", "San Francisco"); + // [END fs_simple_queries] + + querys.add(countryQuery); + querys.add(populationQuery); + querys.add(cityQuery); + return querys; + } + + /** + * Creates chained where clauses. + * + *

Note : equality and inequality clauses over multiple fields cannot be chained. + * + * @return query + */ + Query createChainedQuery() { + CollectionReference cities = db.collection("cities"); + // [START fs_chained_query] + Query chainedQuery1 = cities.whereEqualTo("state", "CO") + .whereEqualTo("name", "Denver"); + // [END fs_chained_query] + return chainedQuery1; + } + + /** + * An instance of a currently unsupported chained query: equality with inequality. + * NOTE : Requires support for creation of composite indices. + * + * @return query + */ + Query createCompositeIndexChainedQuery() { + CollectionReference cities = db.collection("cities"); + // [START fs_composite_index_chained_query] + Query chainedQuery2 = cities.whereEqualTo("state", "CA") + .whereLessThan("population", 1000000L); + // [END fs_composite_index_chained_query] + return chainedQuery2; + } + + /** + * An instance of a valid range/inequality query : range operators are limited to a single field. + * + * @return query + */ + Query createRangeQuery() { + CollectionReference cities = db.collection("cities"); + // [START fs_range_query] + Query validQuery1 = cities.whereGreaterThanOrEqualTo("state", "CA") + .whereLessThanOrEqualTo("state", "IN"); + Query validQuery2 = cities.whereEqualTo("state", "CA") + .whereGreaterThan("population", 1000000); + // [END fs_range_query] + return validQuery1; + } + + /** + * An instance of an invalid range query : range operators are limited to a single field. + * + * @return query + */ + Query createInvalidRangeQuery() { + CollectionReference cities = db.collection("cities"); + // Violates constraint : range operators are limited to a single field + // [START fs_invalid_range_query] + Query invalidRangeQuery = cities.whereGreaterThanOrEqualTo("state", "CA") + .whereGreaterThan("population", 100000); + // [END fs_invalid_range_query] + return invalidRangeQuery; + } + + /** + * Creates a query that combines order by with limit. + * + * @return query + */ + Query createOrderByNameWithLimitQuery() { + CollectionReference cities = db.collection("cities"); + // [START fs_order_by_name_limit_query] + Query query = cities.orderBy("name").limit(3); + // [END fs_order_by_name_limit_query] + return query; + } + + /** + * Creates a query that orders by country and population(descending). + * + * @return query + */ + Query createOrderByCountryAndPopulation() { + CollectionReference cities = db.collection("cities"); + // [START fs_order_by_country_population] + Query query = cities.orderBy("state").orderBy("population", Direction.DESCENDING); + // [END fs_order_by_country_population] + return query; + } + + /** + * Creates a query that combines order by in descending order with the limit operator. + * + * @return query + */ + Query createOrderByNameDescWithLimitQuery() { + CollectionReference cities = db.collection("cities"); + // [START fs_order_by_name_desc_limit_query] + Query query = cities.orderBy("name", Direction.DESCENDING).limit(3); + // [END fs_order_by_name_desc_limit_query] + return query; + } + + /** + * Creates a query that combines where clause with order by and limit operator. + * + * @return query + */ + Query createWhereWithOrderByAndLimitQuery() { + CollectionReference cities = db.collection("cities"); + // [START fs_where_order_by_limit_query] + Query query = cities.whereGreaterThan("population", 2500000L).orderBy("population").limit(2); + // [END fs_where_order_by_limit_query] + return query; + } + + /** + * Creates a query using a range where clause with order by. Order by must be based on the same + * field as the range clause. + * + * @return query + */ + Query createRangeWithOrderByQuery() { + CollectionReference cities = db.collection("cities"); + // [START fs_range_order_by_query] + Query query = cities.whereGreaterThan("population", 2500000L).orderBy("population"); + // [END fs_range_order_by_query] + return query; + } + + /** + * Creates an instance of an invalid range combined with order. Violates the constraint that range + * and order by are required to be on the same field. + * + * @return query + */ + Query createInvalidRangeWithOrderByQuery() { + CollectionReference cities = db.collection("cities"); + // Violates the constraint that range and order by are required to be on the same field + // [START fs_invalid_range_order_by_query] + Query query = cities.whereGreaterThan("population", 2500000L).orderBy("country"); + // [END fs_invalid_range_order_by_query] + return query; + } + + /** + * Create a query defining the start point of a query. + * + * @return query + */ + Query createStartAtFieldQueryCursor() { + CollectionReference cities = db.collection("cities"); + // [START fs_start_at_field_query_cursor] + Query query = cities.orderBy("population").startAt(4921000L); + // [END fs_start_at_field_query_cursor] + return query; + } + + /** + * Create a query defining the start point of a query. + * + * @return query + */ + Query createEndAtFieldQueryCursor() { + CollectionReference cities = db.collection("cities"); + // [START fs_end_at_field_query_cursor] + Query query = cities.orderBy("population").endAt(4921000L); + // [END fs_end_at_field_query_cursor] + return query; + } + + /* Create queries with multiple cursor conditions. */ + void createMultipleCursorConditionsQuery() { + // [START fs_multiple_cursor_conditions] + // Will return all Springfields + Query query1 = db.collection("cities") + .orderBy("name") + .orderBy("state") + .startAt("Springfield"); + + // Will return "Springfield, Missouri" and "Springfield, Wisconsin" + Query query2 = db.collection("cities") + .orderBy("name") + .orderBy("state") + .startAt("Springfield", "Missouri"); + // [END fs_multiple_cursor_conditions] + } +} diff --git a/firestore/src/main/java/com/example/firestore/snippets/References.java b/firestore/src/main/java/com/example/firestore/snippets/References.java new file mode 100644 index 00000000000..52c4df728a0 --- /dev/null +++ b/firestore/src/main/java/com/example/firestore/snippets/References.java @@ -0,0 +1,82 @@ +/* + * Copyright 2017 Google Inc. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except + * in compliance with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under the License + * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express + * or implied. See the License for the specific language governing permissions and limitations under + * the License. + */ + +package com.example.firestore.snippets; + +import com.google.cloud.firestore.CollectionReference; +import com.google.cloud.firestore.DocumentReference; +import com.google.cloud.firestore.Firestore; + +/** Examples of references to a collection, document in a collection and subcollection. */ +public class References { + + private final Firestore db; + + public References(Firestore db) { + this.db = db; + } + + /** + * Return a reference to collection. + * + * @return collection reference + */ + public CollectionReference getACollectionRef() { + // [START fs_collection_ref] + // Reference to the collection "users" + CollectionReference collection = db.collection("users"); + // [END fs_collection_ref] + return collection; + } + + /** + * Return a reference to a document. + * + * @return document reference + */ + public DocumentReference getADocumentRef() { + // [START fs_document_ref] + // Reference to a document with id "alovelace" in the collection "employees" + DocumentReference document = db.collection("users").document("alovelace"); + // [END fs_document_ref] + return document; + } + + /** + * Return a reference to a document using path. + * + * @return document reference + */ + public DocumentReference getADocumentRefUsingPath() { + // [START fs_document_path_ref] + // Reference to a document with id "alovelace" in the collection "employees" + DocumentReference document = db.document("users/alovelace"); + // [END fs_document_path_ref] + return document; + } + + /** + * Return a reference to a document in a sub-collection. + * + * @return document reference in a subcollection + */ + public DocumentReference getASubCollectionDocumentRef() { + // [START fs_subcollection_ref] + // Reference to a document in subcollection "messages" + DocumentReference document = + db.collection("rooms").document("roomA").collection("messages").document("message1"); + // [END fs_subcollection_ref] + return document; + } +} diff --git a/firestore/src/main/java/com/example/firestore/snippets/RetrieveDataSnippets.java b/firestore/src/main/java/com/example/firestore/snippets/RetrieveDataSnippets.java new file mode 100644 index 00000000000..e3c7515f841 --- /dev/null +++ b/firestore/src/main/java/com/example/firestore/snippets/RetrieveDataSnippets.java @@ -0,0 +1,138 @@ +/* + * Copyright 2017 Google Inc. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except + * in compliance with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under the License + * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express + * or implied. See the License for the specific language governing permissions and limitations under + * the License. + */ + +package com.example.firestore.snippets; + +import com.example.firestore.snippets.model.City; + +import com.google.api.core.ApiFuture; +import com.google.api.core.ApiFutures; +import com.google.cloud.firestore.CollectionReference; +import com.google.cloud.firestore.DocumentReference; +import com.google.cloud.firestore.DocumentSnapshot; +import com.google.cloud.firestore.Firestore; +import com.google.cloud.firestore.QuerySnapshot; +import com.google.cloud.firestore.WriteResult; + +import java.util.ArrayList; +import java.util.List; +import java.util.Map; + +/** Snippets to demonstrate Firestore data retrieval operations. */ +public class RetrieveDataSnippets { + + private final Firestore db; + + RetrieveDataSnippets(Firestore db) { + this.db = db; + } + + /** Create cities collection and add sample documents. */ + void prepareExamples() throws Exception { + // [START fs_retrieve_create_examples] + CollectionReference cities = db.collection("cities"); + List> futures = new ArrayList<>(); + futures.add(cities.document("SF").set(new City("San Francisco", "CA", "USA", false, 860000L))); + futures.add(cities.document("LA").set(new City("Los Angeles", "CA", "USA", false, 3900000L))); + futures.add(cities.document("DC").set(new City("Washington D.C.", null, "USA", true, 680000L))); + futures.add(cities.document("TOK").set(new City("Tokyo", null, "Japan", true, 9000000L))); + futures.add(cities.document("BJ").set(new City("Beijing", null, "China", true, 21500000L))); + // (optional) block on operation + ApiFutures.allAsList(futures).get(); + // [END fs_retrieve_create_examples] + } + + /** + * Retrieves document in collection as map. + * + * @return map (string => object) + */ + public Map getDocumentAsMap() throws Exception { + // [START fs_get_doc_as_map] + DocumentReference docRef = db.collection("cities").document("SF"); + // asynchronously retrieve the document + ApiFuture future = docRef.get(); + // ... + // future.get() blocks on response + DocumentSnapshot document = future.get(); + if (document.exists()) { + System.out.println("Document data: " + document.getData()); + } else { + System.out.println("No such document!"); + } + // [END fs_get_doc_as_map] + return (document.exists()) ? document.getData() : null; + } + + /** + * Retrieves document in collection as a custom object. + * + * @return document data as City object + */ + public City getDocumentAsEntity() throws Exception { + // [START fs_get_doc_as_entity] + DocumentReference docRef = db.collection("cities").document("BJ"); + // asynchronously retrieve the document + ApiFuture future = docRef.get(); + // block on response + DocumentSnapshot document = future.get(); + City city = null; + if (document.exists()) { + // convert document to POJO + city = document.toObject(City.class); + System.out.println(city); + } else { + System.out.println("No such document!"); + } + // [END fs_get_doc_as_entity] + return city; + } + + /** + * Return multiple documents from a collection based on a query. + * + * @return list of documents of capital cities. + */ + public List getQueryResults() throws Exception { + // [START fs_get_multiple_docs] + //asynchronously retrieve multiple documents + ApiFuture future = + db.collection("cities").whereEqualTo("capital", true).get(); + // future.get() blocks on response + List documents = future.get().getDocuments(); + for (DocumentSnapshot document : documents) { + System.out.println(document.getId() + " => " + document.toObject(City.class)); + } + // [END fs_get_multiple_docs] + return documents; + } + + /** + * Return all documents in the cities collection. + * + * @return list of documents + */ + public List getAllDocuments() throws Exception { + // [START fs_get_all_docs] + //asynchronously retrieve all documents + ApiFuture future = db.collection("cities").get(); + // future.get() blocks on response + List documents = future.get().getDocuments(); + for (DocumentSnapshot document : documents) { + System.out.println(document.getId() + " => " + document.toObject(City.class)); + } + // [END fs_get_all_docs] + return documents; + } +} diff --git a/firestore/src/main/java/com/example/firestore/snippets/model/City.java b/firestore/src/main/java/com/example/firestore/snippets/model/City.java new file mode 100644 index 00000000000..c3cc3ebcd5e --- /dev/null +++ b/firestore/src/main/java/com/example/firestore/snippets/model/City.java @@ -0,0 +1,144 @@ +/* + * Copyright 2017 Google Inc. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package com.example.firestore.snippets.model; + +import java.util.Objects; + +/** Represents a city : name, weather, population, country, capital, geo coordinates. */ +public class City { + + private String name; + private String state; + private String country; + private Boolean capital; + private Long population; + + // [START fs_class_definition] + public City() { + // Must have a public no-argument constructor + } + + // Initialize all fields of a city + public City(String name, String state, String country, Boolean capital, Long population) { + this.name = name; + this.state = state; + this.country = country; + this.capital = capital; + this.population = population; + } + // [END fs_class_definition] + + public City(String name) { + this.name = name; + } + + public String getName() { + return name; + } + + public void setName(String name) { + this.name = name; + } + + public String getState() { + return state; + } + + public void setState(String state) { + this.state = state; + } + + public String getCountry() { + return country; + } + + public void setCountry(String country) { + this.country = country; + } + + public Boolean getCapital() { + return capital; + } + + public void setCapital(Boolean capital) { + this.capital = capital; + } + + public Long getPopulation() { + return population; + } + + public void setPopulation(Long population) { + this.population = population; + } + + private String getDefinedValue(String s) { + if (s != null) { + return s; + } else { + return ""; + } + } + + @Override + public String toString() { + StringBuilder sb = new StringBuilder(); + if (name != null) { + sb.append(name); + } + if (state != null) { + sb.append(" state : "); + sb.append(state); + sb.append(","); + } + if (country != null) { + sb.append(", "); + sb.append(country); + } + sb.append(" : ["); + if (population != null) { + sb.append(" population : "); + sb.append(population); + sb.append(","); + } + if (capital != null) { + sb.append(" capital : "); + sb.append(capital); + sb.append(","); + } + //remove trailing comma + if (sb.lastIndexOf(",") >= sb.length() - 1) { + sb.deleteCharAt(sb.length() - 1); + } + sb.append(" ]"); + return sb.toString(); + } + + @Override + public boolean equals(Object obj) { + if (!(obj instanceof City)) { + return false; + } + City city = (City) obj; + return Objects.equals(name, city.name) + && Objects.equals(state, city.state) + && Objects.equals(country, city.country) + && Objects.equals(population, city.population) + && Objects.equals(capital, city.capital); + + } +} diff --git a/firestore/src/test/java/com/example/firestore/QuickstartIT.java b/firestore/src/test/java/com/example/firestore/QuickstartIT.java new file mode 100644 index 00000000000..a84d45ce1ad --- /dev/null +++ b/firestore/src/test/java/com/example/firestore/QuickstartIT.java @@ -0,0 +1,120 @@ +/* + * Copyright 2017 Google Inc. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except + * in compliance with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under the License + * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express + * or implied. See the License for the specific language governing permissions and limitations under + * the License. + */ + +package com.example.firestore; + +import static org.junit.Assert.assertTrue; + +import com.google.api.core.ApiFuture; + +import com.google.cloud.firestore.DocumentReference; +import com.google.cloud.firestore.DocumentSnapshot; +import com.google.cloud.firestore.Firestore; +import com.google.cloud.firestore.QuerySnapshot; +import java.io.ByteArrayOutputStream; +import java.io.PrintStream; +import java.util.HashMap; +import java.util.Map; +import java.util.Objects; +import org.junit.After; +import org.junit.Before; +import org.junit.Test; +import org.junit.runner.RunWith; +import org.junit.runners.JUnit4; + +@RunWith(JUnit4.class) +@SuppressWarnings("checkstyle:abbreviationaswordinname") +public class QuickstartIT { + + private Quickstart quickstart; + private Firestore db; + private ByteArrayOutputStream bout; + private PrintStream out; + private String projectId = "java-docs-samples-firestore"; + + @Before + public void setUp() throws Exception { + quickstart = new Quickstart(projectId); + db = quickstart.getDb(); + bout = new ByteArrayOutputStream(); + out = new PrintStream(bout); + System.setOut(out); + deleteAllDocuments(); + } + + @Test + public void testQuickstart() throws Exception { + addData(); + + bout.reset(); + quickstart.runAQuery(); + String output = bout.toString(); + // confirm that results do not contain aturing + assertTrue(output.contains("alovelace")); + assertTrue(output.contains("cbabbage")); + assertTrue(!output.contains("aturing")); + + bout.reset(); + quickstart.retrieveAllDocuments(); + output = bout.toString(); + // confirm that all documents are retrieved + assertTrue(output.contains("alovelace")); + assertTrue(output.contains("aturing")); + assertTrue(output.contains("cbabbage")); + } + + private void validate(DocumentReference docRef, Map data) throws Exception { + DocumentSnapshot documentSnapshot = docRef.get().get(); + assertTrue(Objects.equals(documentSnapshot.getData(), data)); + } + + private void addData() throws Exception { + Map expectedData = new HashMap<>(); + + quickstart.addDocument("alovelace"); + expectedData.put("first", "Ada"); + expectedData.put("last", "Lovelace"); + expectedData.put("born", 1815L); + validate(db.document("users/alovelace"), expectedData); + + expectedData.clear(); + expectedData.put("first", "Alan"); + expectedData.put("middle", "Mathison"); + expectedData.put("last", "Turing"); + expectedData.put("born", 1912L); + quickstart.addDocument("aturing"); + validate(db.document("users/aturing"), expectedData); + + expectedData.clear(); + expectedData.put("first", "Charles"); + expectedData.put("last", "Babbage"); + expectedData.put("born", 1791L); + quickstart.addDocument("cbabbage"); + validate(db.document("users/cbabbage"), expectedData); + } + + private void deleteAllDocuments() throws Exception { + ApiFuture future = db.collection("users").get(); + QuerySnapshot querySnapshot = future.get(); + for (DocumentSnapshot doc : querySnapshot.getDocuments()) { + // block on delete operation + db.document("users/" + doc.getId()).delete().get(); + } + } + + @After + public void tearDown() throws Exception { + deleteAllDocuments(); + } +} diff --git a/firestore/src/test/java/com/example/firestore/snippets/ManageDataSnippetsIT.java b/firestore/src/test/java/com/example/firestore/snippets/ManageDataSnippetsIT.java new file mode 100644 index 00000000000..c0a95fdd651 --- /dev/null +++ b/firestore/src/test/java/com/example/firestore/snippets/ManageDataSnippetsIT.java @@ -0,0 +1,213 @@ +/* + * Copyright 2017 Google Inc. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except + * in compliance with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under the License + * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express + * or implied. See the License for the specific language governing permissions and limitations under + * the License. + */ + +package com.example.firestore.snippets; + +import static junit.framework.TestCase.assertFalse; +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.assertTrue; + +import com.example.firestore.snippets.model.City; +import com.google.api.core.ApiFuture; +import com.google.cloud.firestore.CollectionReference; +import com.google.cloud.firestore.DocumentReference; +import com.google.cloud.firestore.DocumentSnapshot; +import com.google.cloud.firestore.Firestore; +import com.google.cloud.firestore.FirestoreOptions; +import com.google.cloud.firestore.QuerySnapshot; +import java.util.Date; +import java.util.Map; +import java.util.Objects; +import org.junit.AfterClass; +import org.junit.BeforeClass; +import org.junit.Test; +import org.junit.runner.RunWith; +import org.junit.runners.JUnit4; + +@RunWith(JUnit4.class) +@SuppressWarnings("checkstyle:abbreviationaswordinname") +public class ManageDataSnippetsIT { + + private static Firestore db; + private static ManageDataSnippets manageDataSnippets; + private static String projectId = "java-docs-samples-firestore"; + + @BeforeClass + public static void setUpBeforeClass() throws Exception { + FirestoreOptions firestoreOptions = FirestoreOptions.getDefaultInstance().toBuilder() + .setProjectId(projectId) + .build(); + db = firestoreOptions.getService(); + deleteAllDocuments(); + manageDataSnippets = new ManageDataSnippets(db); + } + + @Test + public void testAddDatasMap() throws Exception { + Map expectedData = manageDataSnippets.addSimpleDocumentAsMap(); + DocumentReference docRef = db.collection("cities").document("LA"); + assertTrue(Objects.equals(expectedData, getDocumentDataAsMap(docRef))); + } + + @Test + public void testAddDataWithDifferentDataTypes() throws Exception { + Map expectedData = manageDataSnippets.addDocumentWithDifferentDataTypes(); + DocumentReference docRef = db.collection("data").document("one"); + assertEquals(expectedData, getDocumentDataAsMap(docRef)); + } + + @Test + public void testAddDataAsEntity() throws Exception { + City city = manageDataSnippets.addSimpleDocumentAsEntity(); + DocumentReference docRef = db.collection("cities").document("LA"); + assertTrue(Objects.equals(city, getDocumentDataAsCity(docRef))); + } + + @Test + public void testAddDocWithAutoGenId() throws Exception { + String autoId = manageDataSnippets.addDocumentDataWithAutoGeneratedId(); + City city = new City("Tokyo"); + city.setCountry("Japan"); + DocumentReference docRef = db.collection("cities").document(autoId); + assertTrue(Objects.equals(city, getDocumentDataAsCity(docRef))); + } + + @Test + public void testAddDocAfterAutoGenId() throws Exception { + String autoId = manageDataSnippets.addDocumentDataAfterAutoGeneratingId(); + City city = new City(); + DocumentReference docRef = db.collection("cities").document(autoId); + assertTrue(Objects.equals(city, getDocumentDataAsCity(docRef))); + } + + @Test + public void testUpdateSimpleDocument() throws Exception { + manageDataSnippets.updateSimpleDocument(); + DocumentReference docRef = db.collection("cities").document("DC"); + City city = new City("Washington D.C."); + city.setCapital(true); + assertTrue(Objects.equals(city, getDocumentDataAsCity(docRef))); + } + + @Test + public void testUpdateUsingMap() throws Exception { + manageDataSnippets.updateUsingMap(); + DocumentReference docRef = db.collection("cities").document("DC"); + City city = new City("Washington D.C."); + city.setCapital(true); + city.setCountry("USA"); + assertTrue(Objects.equals(city, getDocumentDataAsCity(docRef))); + } + + @Test + public void testUpdateAndCreateIfMissing() throws Exception { + manageDataSnippets.updateAndCreateIfMissing(); + DocumentReference docRef = db.collection("cities").document("BJ"); + assertTrue(getDocumentDataAsCity(docRef).getCapital()); + } + + @Test + public void testUpdateNestedFields() throws Exception { + manageDataSnippets.updateNestedFields(); + DocumentReference docRef = db.collection("users").document("frank"); + + DocumentSnapshot snapshot = getDocumentData(docRef); + assertEquals((long) snapshot.getLong("age"), 13); + assertEquals(snapshot.getString("favorites.color"), "Red"); + assertEquals(snapshot.getString("favorites.food"), "Pizza"); + } + + @Test + public void testUpdateServerTimestamp() throws Exception { + manageDataSnippets.updateServerTimestamp(); + DocumentReference docRef = db.collection("objects").document("some-id"); + Map data = getDocumentDataAsMap(docRef); + assertTrue(data.get("timestamp") instanceof Date); + } + + @Test + public void testDeleteFields() throws Exception { + manageDataSnippets.deleteFields(); + DocumentReference docRef = db.collection("cities").document("BJ"); + Map data = getDocumentDataAsMap(docRef); + assertFalse(data.containsKey("capital")); + } + + @Test(expected = Exception.class) + public void testDeleteDocument() throws Exception { + manageDataSnippets.deleteDocument(); + getDocumentDataAsMap(db.collection("cities").document("DC")); + } + + @Test + public void testSimpleTransaction() throws Exception { + DocumentReference docRef = db.collection("cities").document("SF"); + ApiFuture future = manageDataSnippets.runSimpleTransaction(); + future.get(); + Map data = getDocumentDataAsMap(docRef); + assertEquals(data.get("population"), 860000L + 1L); + } + + @Test + public void testTransactionReturnsInfo() throws Exception { + String info = manageDataSnippets.returnInfoFromTransaction(50L); + assertEquals(info, "Population increased to 51"); + try { + info = manageDataSnippets.returnInfoFromTransaction(5000001L); + assertTrue("Should never get here", false); + } catch (Exception e) { + assertTrue(e.getMessage().contains("Sorry! Population is too big.")); + } + } + + @Test + public void testWriteBatchIsSuccessful() throws Exception { + manageDataSnippets.writeBatch(); + CollectionReference collection = db.collection("cities"); + ApiFuture document = collection.document("NYC").get(); + assertTrue(document.get().exists()); + DocumentReference documentReference = collection.document("SF"); + Map data = getDocumentDataAsMap(documentReference); + assertTrue(data.containsKey("population")); + document = collection.document("LA").get(); + assertFalse(document.get().exists()); + } + + private DocumentSnapshot getDocumentData(DocumentReference docRef) throws Exception { + return docRef.get().get(); + } + + private Map getDocumentDataAsMap(DocumentReference docRef) throws Exception { + return docRef.get().get().getData(); + } + + private City getDocumentDataAsCity(DocumentReference docRef) throws Exception { + return docRef.get().get().toObject(City.class); + } + + private static void deleteAllDocuments() throws Exception { + ApiFuture future = db.collection("cities").get(); + QuerySnapshot querySnapshot = future.get(); + for (DocumentSnapshot doc : querySnapshot.getDocuments()) { + // block on delete operation + db.collection("cities").document(doc.getId()).delete().get(); + } + } + + @AfterClass + public static void tearDown() throws Exception { + manageDataSnippets.deleteCollection(db.collection("cities"), 10); + manageDataSnippets.deleteCollection(db.collection("users"), 10); + } +} diff --git a/firestore/src/test/java/com/example/firestore/snippets/QueryDataSnippetsIT.java b/firestore/src/test/java/com/example/firestore/snippets/QueryDataSnippetsIT.java new file mode 100644 index 00000000000..3b93a38bac9 --- /dev/null +++ b/firestore/src/test/java/com/example/firestore/snippets/QueryDataSnippetsIT.java @@ -0,0 +1,225 @@ +/* + * Copyright 2017 Google Inc. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except + * in compliance with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under the License + * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express + * or implied. See the License for the specific language governing permissions and limitations under + * the License. + */ + +package com.example.firestore.snippets; + +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.assertTrue; + +import com.google.api.core.ApiFuture; +import com.google.cloud.firestore.DocumentSnapshot; +import com.google.cloud.firestore.Firestore; +import com.google.cloud.firestore.FirestoreOptions; +import com.google.cloud.firestore.Query; +import com.google.cloud.firestore.QuerySnapshot; +import com.google.common.collect.ImmutableMap; +import java.util.ArrayList; +import java.util.Arrays; +import java.util.HashSet; +import java.util.List; +import java.util.Map; +import java.util.Objects; +import java.util.Set; +import org.junit.AfterClass; +import org.junit.BeforeClass; +import org.junit.Test; +import org.junit.runner.RunWith; +import org.junit.runners.JUnit4; + +@RunWith(JUnit4.class) +@SuppressWarnings("checkstyle:abbreviationaswordinname") +public class QueryDataSnippetsIT { + + private static Firestore db; + private static QueryDataSnippets queryDataSnippets; + private static String projectId = "java-docs-samples-firestore"; + + @BeforeClass + public static void setUpBeforeClass() throws Exception { + FirestoreOptions firestoreOptions = FirestoreOptions.getDefaultInstance().toBuilder() + .setProjectId(projectId) + .build(); + db = firestoreOptions.getService(); + deleteAllDocuments(); + queryDataSnippets = new QueryDataSnippets(db); + queryDataSnippets.prepareExamples(); + } + + @Test + public void testCreateAQuery() throws Exception { + Query q = queryDataSnippets.createAQuery(); + Set result = getResultsAsSet(q); + Set expectedResults = new HashSet<>(Arrays.asList("DC", "TOK", "BJ")); + assertTrue(Objects.equals(result, expectedResults)); + } + + @Test + public void testSimpleQueryReturnsExpectedResults() throws Exception { + List> expectedResults = new ArrayList<>(); + + expectedResults.add(new HashSet<>(Arrays.asList("SF", "LA"))); + expectedResults.add(new HashSet<>(Arrays.asList("SF", "DC"))); + expectedResults.add(new HashSet<>(Arrays.asList("SF", "DC", "TOK"))); + + List queries = queryDataSnippets.createSimpleQueries(); + for (int i = 0; i < queries.size(); i++) { + Set results = getResultsAsSet(queries.get(i)); + assertTrue(Objects.equals(results, expectedResults.get(i))); + } + } + + @Test + public void testChainedQuery() throws Exception { + Query q = queryDataSnippets.createChainedQuery(); + Set result = getResultsAsSet(q); + Set expectedResults = new HashSet<>(); + assertTrue(Objects.equals(result, expectedResults)); + } + + @Test + public void testRangeQuery() throws Exception { + Query q = queryDataSnippets.createRangeQuery(); + Set result = getResultsAsSet(q); + Set expectedResults = new HashSet<>(Arrays.asList("SF", "LA")); + assertTrue(Objects.equals(result, expectedResults)); + } + + @Test(expected = Exception.class) + public void testInvalidRangeQueryThrowsException() throws Exception { + Query q = queryDataSnippets.createInvalidRangeQuery(); + getResults(q); + } + + @Test + public void testOrderByNameWithLimitQuery() throws Exception { + Query q = queryDataSnippets.createOrderByNameWithLimitQuery(); + List result = getResults(q); + List expectedResults = Arrays.asList("BJ", "LA", "SF"); + assertEquals(result, expectedResults); + } + + @Test + public void testOrderByNameDescWithLimitQuery() throws Exception { + Query q = queryDataSnippets.createOrderByNameDescWithLimitQuery(); + List result = getResults(q); + List expectedResults = Arrays.asList("DC", "TOK", "SF"); + assertTrue(Objects.equals(result, expectedResults)); + } + + @Test + public void testWhereWithOrderByAndLimitQuery() throws Exception { + Query q = queryDataSnippets.createWhereWithOrderByAndLimitQuery(); + List result = getResults(q); + List expectedResults = Arrays.asList("LA", "TOK"); + assertEquals(result, expectedResults); + } + + @Test + public void testRangeWithOrderByQuery() throws Exception { + Query q = queryDataSnippets.createRangeWithOrderByQuery(); + List result = getResults(q); + List expectedResults = Arrays.asList("LA", "TOK", "BJ"); + assertEquals(result, expectedResults); + } + + @Test(expected = Exception.class) + public void testInvalidRangeWithOrderByQuery() throws Exception { + Query q = queryDataSnippets.createInvalidRangeWithOrderByQuery(); + getResults(q); + } + + @Test + public void testStartAtFieldQueryCursor() throws Exception { + Query q = queryDataSnippets.createStartAtFieldQueryCursor(); + List expectedResults = Arrays.asList("TOK", "BJ"); + List result = getResults(q); + assertTrue(Objects.equals(result, expectedResults)); + } + + @Test + public void testEndAtFieldQueryCursor() throws Exception { + Query q = queryDataSnippets.createEndAtFieldQueryCursor(); + List expectedResults = Arrays.asList("DC", "SF", "LA"); + List result = getResults(q); + assertEquals(result, expectedResults); + } + + @Test + public void testMultipleCursorConditions() throws Exception { + // populate us_cities collection + Map city1 = new ImmutableMap.Builder() + .put("name", "Springfield").put("state", "Massachusetts").build(); + Map city2 = new ImmutableMap.Builder() + .put("name", "Springfield").put("state", "Missouri").build(); + Map city3 = new ImmutableMap.Builder() + .put("name", "Springfield").put("state", "Wisconsin").build(); + + db.collection("us_cities").document("Massachusetts").set(city1).get(); + db.collection("us_cities").document("Missouri").set(city2).get(); + db.collection("us_cities").document("Wisconsin").set(city3).get(); + + Query query1 = db.collection("us_cities") + .orderBy("name") + .orderBy("state") + .startAt("Springfield"); + + // all documents are retrieved + QuerySnapshot querySnapshot = query1.get().get(); + List docs = querySnapshot.getDocuments(); + assertEquals(3, docs.size()); + + + // Will return "Springfield, Missouri" and "Springfield, Wisconsin" + Query query2 = db.collection("us_cities") + .orderBy("name") + .orderBy("state") + .startAt("Springfield", "Missouri"); + + // only Missouri and Wisconsin are retrieved + List expectedResults = Arrays.asList("Missouri", "Wisconsin"); + List result = getResults(query2); + assertTrue(Objects.equals(result, expectedResults)); + } + + private Set getResultsAsSet(Query query) throws Exception { + List docIds = getResults(query); + return new HashSet<>(docIds); + } + + private List getResults(Query query) throws Exception { + // asynchronously retrieve query results + ApiFuture future = query.get(); + // block on response + QuerySnapshot querySnapshot = future.get(); + List docIds = new ArrayList<>(); + for (DocumentSnapshot document : querySnapshot.getDocuments()) { + docIds.add(document.getId()); + } + return docIds; + } + + private static void deleteAllDocuments() throws Exception { + ApiFuture future = db.collection("cities").get(); + QuerySnapshot querySnapshot = future.get(); + for (DocumentSnapshot doc : querySnapshot.getDocuments()) { + // block on delete operation + db.collection("cities").document(doc.getId()).delete().get(); + } + } + + @AfterClass + public static void tearDown() throws Exception { + deleteAllDocuments(); + } +} diff --git a/firestore/src/test/java/com/example/firestore/snippets/RetrieveDataSnippetsIT.java b/firestore/src/test/java/com/example/firestore/snippets/RetrieveDataSnippetsIT.java new file mode 100644 index 00000000000..455733d29d3 --- /dev/null +++ b/firestore/src/test/java/com/example/firestore/snippets/RetrieveDataSnippetsIT.java @@ -0,0 +1,113 @@ +/* + * Copyright 2017 Google Inc. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except + * in compliance with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under the License + * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express + * or implied. See the License for the specific language governing permissions and limitations under + * the License. + */ + +package com.example.firestore.snippets; + +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.assertTrue; + +import com.example.firestore.snippets.model.City; + +import com.google.api.core.ApiFuture; +import com.google.cloud.firestore.DocumentSnapshot; +import com.google.cloud.firestore.Firestore; +import com.google.cloud.firestore.FirestoreOptions; +import com.google.cloud.firestore.QuerySnapshot; +import java.util.HashSet; +import java.util.List; +import java.util.Map; +import java.util.Set; +import org.junit.AfterClass; +import org.junit.BeforeClass; +import org.junit.Test; +import org.junit.runner.RunWith; +import org.junit.runners.JUnit4; + +@RunWith(JUnit4.class) +@SuppressWarnings("checkstyle:abbreviationaswordinname") +public class RetrieveDataSnippetsIT { + private static Firestore db; + private static RetrieveDataSnippets retrieveDataSnippets; + private static String projectId = "java-docs-samples-firestore"; + + @BeforeClass + public static void setUpBeforeClass() throws Exception { + FirestoreOptions firestoreOptions = FirestoreOptions.getDefaultInstance().toBuilder() + .setProjectId(projectId) + .build(); + db = firestoreOptions.getService(); + deleteAllDocuments(); + retrieveDataSnippets = new RetrieveDataSnippets(db); + retrieveDataSnippets.prepareExamples(); + } + + @Test + public void testRetrievalAsMap() throws Exception { + Map data = retrieveDataSnippets.getDocumentAsMap(); + assertEquals(data.get("name"), "San Francisco"); + assertEquals(data.get("country"), "USA"); + assertEquals(data.get("capital"), false); + assertEquals(data.get("population"), 860000L); + } + + @Test + public void testRetrieveAsEntity() throws Exception { + City city = retrieveDataSnippets.getDocumentAsEntity(); + assertEquals(city.getName(), "Beijing"); + assertEquals(city.getCountry(), "China"); + assertEquals(city.getCapital(), true); + assertEquals((long) city.getPopulation(), 21500000L); + } + + @Test + public void testRetrieveQueryResults() throws Exception { + List docs = retrieveDataSnippets.getQueryResults(); + assertEquals(docs.size(), 3); + Set docIds = new HashSet<>(); + for (DocumentSnapshot doc : docs) { + docIds.add(doc.getId()); + } + assertTrue(docIds.contains("BJ") && docIds.contains("TOK") && docIds.contains("DC")); + } + + @Test + public void testRetrieveAllDocuments() throws Exception { + List docs = retrieveDataSnippets.getAllDocuments(); + assertEquals(docs.size(), 5); + Set docIds = new HashSet<>(); + for (DocumentSnapshot doc : docs) { + docIds.add(doc.getId()); + } + assertTrue( + docIds.contains("SF") + && docIds.contains("LA") + && docIds.contains("DC") + && docIds.contains("TOK") + && docIds.contains("BJ")); + } + + private static void deleteAllDocuments() throws Exception { + ApiFuture future = db.collection("cities").get(); + QuerySnapshot querySnapshot = future.get(); + for (DocumentSnapshot doc : querySnapshot.getDocuments()) { + // block on delete operation + db.collection("cities").document(doc.getId()).delete().get(); + } + } + + @AfterClass + public static void tearDownAfterClass() throws Exception { + deleteAllDocuments(); + } +} diff --git a/pom.xml b/pom.xml index d14b425184c..07e7db7bc59 100644 --- a/pom.xml +++ b/pom.xml @@ -56,6 +56,8 @@ errorreporting + firestore + iap kms From 6a3e8ae9cecc0506c611a188dae164850171b6b2 Mon Sep 17 00:00:00 2001 From: DPE bot Date: Wed, 4 Oct 2017 08:17:07 -0700 Subject: [PATCH 08/10] Auto-update dependencies. (#878) --- appengine-java8/cloudsql/pom.xml | 2 +- appengine-java8/firebase-tictactoe/pom.xml | 2 +- appengine-java8/gaeinfo/pom.xml | 2 +- appengine-java8/guestbook-cloud-datastore/pom.xml | 2 +- appengine-java8/metadata/pom.xml | 2 +- appengine-java8/postgres/pom.xml | 2 +- appengine-java8/pubsub/pom.xml | 4 ++-- appengine-java8/spanner/pom.xml | 2 +- appengine/cloudsql/pom.xml | 2 +- appengine/firebase-tictactoe/pom.xml | 2 +- bigquery/cloud-client/pom.xml | 2 +- bigquery/rest/pom.xml | 6 +++--- compute/cmdline/pom.xml | 2 +- datastore/cloud-client/pom.xml | 2 +- datastore/pom.xml | 2 +- dlp/pom.xml | 2 +- errorreporting/pom.xml | 2 +- flexible/cloudsql/pom.xml | 6 +++--- flexible/cloudstorage/pom.xml | 2 +- flexible/datastore/pom.xml | 2 +- flexible/errorreporting/pom.xml | 2 +- flexible/gaeinfo/pom.xml | 2 +- flexible/postgres/pom.xml | 6 +++--- flexible/pubsub/pom.xml | 4 ++-- flexible/sparkjava/pom.xml | 2 +- kms/pom.xml | 4 ++-- language/analysis/pom.xml | 2 +- language/cloud-client/pom.xml | 2 +- logging/cloud-client/pom.xml | 2 +- monitoring/cloud-client/pom.xml | 2 +- pubsub/cloud-client/pom.xml | 2 +- spanner/cloud-client/pom.xml | 2 +- speech/cloud-client/pom.xml | 2 +- storage/cloud-client/pom.xml | 2 +- storage/json-api/pom.xml | 2 +- storage/storage-transfer/pom.xml | 2 +- storage/xml-api/cmdline-sample/pom.xml | 2 +- storage/xml-api/serviceaccount-appengine-sample/pom.xml | 2 +- translate/cloud-client/pom.xml | 2 +- translate/pom.xml | 2 +- unittests/pom.xml | 2 +- video/cloud-client/pom.xml | 2 +- vision/cloud-client/pom.xml | 2 +- vision/face-detection/pom.xml | 2 +- vision/label/pom.xml | 2 +- vision/landmark-detection/pom.xml | 2 +- vision/text/pom.xml | 2 +- 47 files changed, 56 insertions(+), 56 deletions(-) diff --git a/appengine-java8/cloudsql/pom.xml b/appengine-java8/cloudsql/pom.xml index 1ff842c0db6..c4bed723822 100644 --- a/appengine-java8/cloudsql/pom.xml +++ b/appengine-java8/cloudsql/pom.xml @@ -63,7 +63,7 @@ com.google.api-client google-api-client-appengine - 1.22.0 + 1.23.0 diff --git a/appengine-java8/firebase-tictactoe/pom.xml b/appengine-java8/firebase-tictactoe/pom.xml index e382e2097b0..2cc512e36eb 100644 --- a/appengine-java8/firebase-tictactoe/pom.xml +++ b/appengine-java8/firebase-tictactoe/pom.xml @@ -32,7 +32,7 @@ 2.7 20.0 - 1.22.0 + 1.23.0 4.12 1.10.19 0.36 diff --git a/appengine-java8/gaeinfo/pom.xml b/appengine-java8/gaeinfo/pom.xml index 6621d82cfa9..3770b34ccaa 100644 --- a/appengine-java8/gaeinfo/pom.xml +++ b/appengine-java8/gaeinfo/pom.xml @@ -65,7 +65,7 @@ Copyright 2017 Google Inc. org.thymeleaf thymeleaf - 3.0.7.RELEASE + 3.0.8.RELEASE diff --git a/appengine-java8/guestbook-cloud-datastore/pom.xml b/appengine-java8/guestbook-cloud-datastore/pom.xml index add04b69ec8..8dfbd1a892a 100644 --- a/appengine-java8/guestbook-cloud-datastore/pom.xml +++ b/appengine-java8/guestbook-cloud-datastore/pom.xml @@ -59,7 +59,7 @@ com.google.cloud google-cloud - 0.24.0-alpha + 0.25.0-alpha diff --git a/appengine-java8/metadata/pom.xml b/appengine-java8/metadata/pom.xml index 47a2f5963f7..8366ec7f281 100644 --- a/appengine-java8/metadata/pom.xml +++ b/appengine-java8/metadata/pom.xml @@ -60,7 +60,7 @@ Copyright 2017 Google Inc. org.thymeleaf thymeleaf - 3.0.7.RELEASE + 3.0.8.RELEASE diff --git a/appengine-java8/postgres/pom.xml b/appengine-java8/postgres/pom.xml index b68bf51aa2b..d4784b8a510 100644 --- a/appengine-java8/postgres/pom.xml +++ b/appengine-java8/postgres/pom.xml @@ -63,7 +63,7 @@ com.google.api-client google-api-client-appengine - 1.22.0 + 1.23.0 diff --git a/appengine-java8/pubsub/pom.xml b/appengine-java8/pubsub/pom.xml index fe47c70e8f2..7b3c895ac59 100644 --- a/appengine-java8/pubsub/pom.xml +++ b/appengine-java8/pubsub/pom.xml @@ -49,12 +49,12 @@ com.google.cloud google-cloud-pubsub - 0.24.0-beta + 0.25.0-beta com.google.cloud google-cloud-datastore - 1.6.0 + 1.7.0 diff --git a/appengine-java8/spanner/pom.xml b/appengine-java8/spanner/pom.xml index 9a0f1c62017..3ac7df00238 100644 --- a/appengine-java8/spanner/pom.xml +++ b/appengine-java8/spanner/pom.xml @@ -37,7 +37,7 @@ com.google.cloud google-cloud-spanner - 0.24.0-beta + 0.25.0-beta javax.servlet diff --git a/appengine/cloudsql/pom.xml b/appengine/cloudsql/pom.xml index cd8b00a5405..019e67d0afd 100644 --- a/appengine/cloudsql/pom.xml +++ b/appengine/cloudsql/pom.xml @@ -64,7 +64,7 @@ com.google.api-client google-api-client-appengine - 1.22.0 + 1.23.0 diff --git a/appengine/firebase-tictactoe/pom.xml b/appengine/firebase-tictactoe/pom.xml index 31607fd2089..e47c930d85a 100644 --- a/appengine/firebase-tictactoe/pom.xml +++ b/appengine/firebase-tictactoe/pom.xml @@ -39,7 +39,7 @@ com.google.api-client google-api-client-appengine - 1.22.0 + 1.23.0 com.google.code.gson diff --git a/bigquery/cloud-client/pom.xml b/bigquery/cloud-client/pom.xml index 7b677eb4df2..bffd6410232 100644 --- a/bigquery/cloud-client/pom.xml +++ b/bigquery/cloud-client/pom.xml @@ -37,7 +37,7 @@ com.google.cloud google-cloud-bigquery - 0.24.0-beta + 0.25.0-beta commons-cli diff --git a/bigquery/rest/pom.xml b/bigquery/rest/pom.xml index f79c174e3ea..7ce05652319 100644 --- a/bigquery/rest/pom.xml +++ b/bigquery/rest/pom.xml @@ -42,7 +42,7 @@ com.google.api-client google-api-client - 1.22.0 + 1.23.0 com.google.guava @@ -53,7 +53,7 @@ com.google.http-client google-http-client - 1.22.0 + 1.23.0 com.google.guava @@ -64,7 +64,7 @@ com.google.oauth-client google-oauth-client - 1.22.0 + 1.23.0 com.google.guava diff --git a/compute/cmdline/pom.xml b/compute/cmdline/pom.xml index fca6054b266..a2747461175 100644 --- a/compute/cmdline/pom.xml +++ b/compute/cmdline/pom.xml @@ -75,7 +75,7 @@ limitations under the License. com.google.api-client google-api-client - 1.22.0 + 1.23.0 com.google.apis diff --git a/datastore/cloud-client/pom.xml b/datastore/cloud-client/pom.xml index f80fe42f496..dda2eaeca39 100644 --- a/datastore/cloud-client/pom.xml +++ b/datastore/cloud-client/pom.xml @@ -37,7 +37,7 @@ com.google.cloud google-cloud-datastore - 1.6.0 + 1.7.0 diff --git a/datastore/pom.xml b/datastore/pom.xml index d2594511efe..fba9afe9a05 100644 --- a/datastore/pom.xml +++ b/datastore/pom.xml @@ -41,7 +41,7 @@ com.google.cloud google-cloud-datastore - 1.6.0 + 1.7.0 diff --git a/dlp/pom.xml b/dlp/pom.xml index 3e67a294e7d..2d59b05f1f5 100644 --- a/dlp/pom.xml +++ b/dlp/pom.xml @@ -42,7 +42,7 @@ com.google.cloud google-cloud-dlp - 0.24.0-alpha + 0.25.0-alpha diff --git a/errorreporting/pom.xml b/errorreporting/pom.xml index 3b8a21f7825..1c2f9d2b385 100644 --- a/errorreporting/pom.xml +++ b/errorreporting/pom.xml @@ -36,7 +36,7 @@ limitations under the License. com.google.cloud google-cloud-errorreporting - 0.24.0-alpha + 0.25.0-alpha diff --git a/flexible/cloudsql/pom.xml b/flexible/cloudsql/pom.xml index a73b21ab685..d3bb61ef7f9 100644 --- a/flexible/cloudsql/pom.xml +++ b/flexible/cloudsql/pom.xml @@ -53,17 +53,17 @@ com.google.api-client google-api-client - 1.22.0 + 1.23.0 com.google.api-client google-api-client-appengine - 1.22.0 + 1.23.0 com.google.api-client google-api-client-servlet - 1.22.0 + 1.23.0 javax.servlet diff --git a/flexible/cloudstorage/pom.xml b/flexible/cloudstorage/pom.xml index 53ae959e11e..e7ed2c91796 100644 --- a/flexible/cloudstorage/pom.xml +++ b/flexible/cloudstorage/pom.xml @@ -49,7 +49,7 @@ com.google.cloud google-cloud-storage - 1.6.0 + 1.7.0 diff --git a/flexible/datastore/pom.xml b/flexible/datastore/pom.xml index f6642e2199b..20bf263adf9 100644 --- a/flexible/datastore/pom.xml +++ b/flexible/datastore/pom.xml @@ -49,7 +49,7 @@ com.google.cloud google-cloud-datastore - 1.6.0 + 1.7.0 diff --git a/flexible/errorreporting/pom.xml b/flexible/errorreporting/pom.xml index 6d4ea073bc9..1f0d1593e0e 100644 --- a/flexible/errorreporting/pom.xml +++ b/flexible/errorreporting/pom.xml @@ -47,7 +47,7 @@ com.google.cloud google-cloud-errorreporting - 0.24.0-alpha + 0.25.0-alpha diff --git a/flexible/gaeinfo/pom.xml b/flexible/gaeinfo/pom.xml index c920c4296d7..d5366272421 100644 --- a/flexible/gaeinfo/pom.xml +++ b/flexible/gaeinfo/pom.xml @@ -65,7 +65,7 @@ Copyright 2017 Google Inc. org.thymeleaf thymeleaf - 3.0.7.RELEASE + 3.0.8.RELEASE diff --git a/flexible/postgres/pom.xml b/flexible/postgres/pom.xml index aa3085af3f5..cce8a01d129 100644 --- a/flexible/postgres/pom.xml +++ b/flexible/postgres/pom.xml @@ -53,17 +53,17 @@ com.google.api-client google-api-client - 1.22.0 + 1.23.0 com.google.api-client google-api-client-appengine - 1.22.0 + 1.23.0 com.google.api-client google-api-client-servlet - 1.22.0 + 1.23.0 javax.servlet diff --git a/flexible/pubsub/pom.xml b/flexible/pubsub/pom.xml index 904b902a5bd..db5f1ab6b8a 100644 --- a/flexible/pubsub/pom.xml +++ b/flexible/pubsub/pom.xml @@ -63,12 +63,12 @@ com.google.cloud google-cloud-pubsub - 0.24.0-beta + 0.25.0-beta com.google.cloud google-cloud-datastore - 1.6.0 + 1.7.0 diff --git a/flexible/sparkjava/pom.xml b/flexible/sparkjava/pom.xml index 01b0f802a5a..a579479342a 100644 --- a/flexible/sparkjava/pom.xml +++ b/flexible/sparkjava/pom.xml @@ -61,7 +61,7 @@ limitations under the License. com.google.cloud google-cloud-datastore - 1.6.0 + 1.7.0 diff --git a/kms/pom.xml b/kms/pom.xml index e21b3889075..eee7b66824d 100644 --- a/kms/pom.xml +++ b/kms/pom.xml @@ -32,12 +32,12 @@ com.google.api-client google-api-client - 1.22.0 + 1.23.0 com.google.http-client google-http-client-jackson2 - 1.22.0 + 1.23.0 args4j diff --git a/language/analysis/pom.xml b/language/analysis/pom.xml index ffb33e7e931..395bd628f7b 100644 --- a/language/analysis/pom.xml +++ b/language/analysis/pom.xml @@ -32,7 +32,7 @@ limitations under the License. com.google.cloud google-cloud-language - 0.24.0-beta + 0.25.0-beta com.google.guava diff --git a/language/cloud-client/pom.xml b/language/cloud-client/pom.xml index a05355673d2..4478ed31c64 100644 --- a/language/cloud-client/pom.xml +++ b/language/cloud-client/pom.xml @@ -38,7 +38,7 @@ com.google.cloud google-cloud-language - 0.24.0-beta + 0.25.0-beta com.google.guava diff --git a/logging/cloud-client/pom.xml b/logging/cloud-client/pom.xml index d913f7923f2..3a47ca2fe18 100644 --- a/logging/cloud-client/pom.xml +++ b/logging/cloud-client/pom.xml @@ -37,7 +37,7 @@ com.google.cloud google-cloud-logging - 1.6.0 + 1.7.0 diff --git a/monitoring/cloud-client/pom.xml b/monitoring/cloud-client/pom.xml index d75958f180e..f1454ba0793 100644 --- a/monitoring/cloud-client/pom.xml +++ b/monitoring/cloud-client/pom.xml @@ -54,7 +54,7 @@ com.google.cloud google-cloud-monitoring - 0.24.0-alpha + 0.25.0-alpha com.google.guava diff --git a/pubsub/cloud-client/pom.xml b/pubsub/cloud-client/pom.xml index 44f33890831..06252004a4b 100644 --- a/pubsub/cloud-client/pom.xml +++ b/pubsub/cloud-client/pom.xml @@ -37,7 +37,7 @@ com.google.cloud google-cloud-pubsub - 0.24.0-beta + 0.25.0-beta diff --git a/spanner/cloud-client/pom.xml b/spanner/cloud-client/pom.xml index b983d68fd65..9fe177c8587 100644 --- a/spanner/cloud-client/pom.xml +++ b/spanner/cloud-client/pom.xml @@ -52,7 +52,7 @@ limitations under the License. com.google.cloud google-cloud-spanner - 0.24.0-beta + 0.25.0-beta com.google.guava diff --git a/speech/cloud-client/pom.xml b/speech/cloud-client/pom.xml index dfc3c122e0b..22efed49ef1 100644 --- a/speech/cloud-client/pom.xml +++ b/speech/cloud-client/pom.xml @@ -38,7 +38,7 @@ com.google.cloud google-cloud-speech - 0.24.0-alpha + 0.25.0-alpha diff --git a/storage/cloud-client/pom.xml b/storage/cloud-client/pom.xml index a67b45efd19..b2a876ac2e0 100644 --- a/storage/cloud-client/pom.xml +++ b/storage/cloud-client/pom.xml @@ -37,7 +37,7 @@ com.google.cloud google-cloud-storage - 1.6.0 + 1.7.0 diff --git a/storage/json-api/pom.xml b/storage/json-api/pom.xml index 2ad785f59bd..22a58c30878 100644 --- a/storage/json-api/pom.xml +++ b/storage/json-api/pom.xml @@ -54,7 +54,7 @@ com.google.oauth-client google-oauth-client-jetty - 1.22.0 + 1.23.0 diff --git a/storage/storage-transfer/pom.xml b/storage/storage-transfer/pom.xml index 5d8fa677bac..caecfbc635d 100644 --- a/storage/storage-transfer/pom.xml +++ b/storage/storage-transfer/pom.xml @@ -38,7 +38,7 @@ com.google.apis google-api-services-storagetransfer - v1-rev25-1.22.0 + v1-rev26-1.22.0 com.google.guava diff --git a/storage/xml-api/cmdline-sample/pom.xml b/storage/xml-api/cmdline-sample/pom.xml index e0732e7d3e3..6c80ae761a9 100644 --- a/storage/xml-api/cmdline-sample/pom.xml +++ b/storage/xml-api/cmdline-sample/pom.xml @@ -27,7 +27,7 @@ - 1.22.0 + 1.23.0 UTF-8 1.6.0 3.7.0 diff --git a/storage/xml-api/serviceaccount-appengine-sample/pom.xml b/storage/xml-api/serviceaccount-appengine-sample/pom.xml index baddaaa6b12..9cc4dc733a1 100644 --- a/storage/xml-api/serviceaccount-appengine-sample/pom.xml +++ b/storage/xml-api/serviceaccount-appengine-sample/pom.xml @@ -34,7 +34,7 @@ 1.7 1.7 1.9.57 - 1.22.0 + 1.23.0 ${project.build.directory}/${project.build.finalName} UTF-8 diff --git a/translate/cloud-client/pom.xml b/translate/cloud-client/pom.xml index 100d7c69fb4..d4204584d17 100644 --- a/translate/cloud-client/pom.xml +++ b/translate/cloud-client/pom.xml @@ -37,7 +37,7 @@ com.google.cloud google-cloud-translate - 1.6.0 + 1.7.0 diff --git a/translate/pom.xml b/translate/pom.xml index f4285eeb8e3..ad72a020860 100644 --- a/translate/pom.xml +++ b/translate/pom.xml @@ -38,7 +38,7 @@ limitations under the License. com.google.cloud google-cloud-translate - 1.6.0 + 1.7.0 junit diff --git a/unittests/pom.xml b/unittests/pom.xml index e370b91b7f4..61d3f52caf8 100644 --- a/unittests/pom.xml +++ b/unittests/pom.xml @@ -23,7 +23,7 @@ UTF-8 3.1.0 2.5.1 - 1.22.0 + 1.23.0 diff --git a/video/cloud-client/pom.xml b/video/cloud-client/pom.xml index acbdbee5021..5efca7d0e95 100644 --- a/video/cloud-client/pom.xml +++ b/video/cloud-client/pom.xml @@ -43,7 +43,7 @@ com.google.cloud google-cloud-video-intelligence - 0.24.0-alpha + 0.25.0-beta diff --git a/vision/cloud-client/pom.xml b/vision/cloud-client/pom.xml index da08ea9414b..8ae30704938 100644 --- a/vision/cloud-client/pom.xml +++ b/vision/cloud-client/pom.xml @@ -38,7 +38,7 @@ com.google.cloud google-cloud-vision - 0.24.0-beta + 0.25.0-beta diff --git a/vision/face-detection/pom.xml b/vision/face-detection/pom.xml index 20689ee96a6..c49f446b848 100644 --- a/vision/face-detection/pom.xml +++ b/vision/face-detection/pom.xml @@ -44,7 +44,7 @@ com.google.api-client google-api-client - 1.22.0 + 1.23.0 com.google.guava diff --git a/vision/label/pom.xml b/vision/label/pom.xml index 2a33d98323c..4e7eeb12017 100644 --- a/vision/label/pom.xml +++ b/vision/label/pom.xml @@ -43,7 +43,7 @@ com.google.api-client google-api-client - 1.22.0 + 1.23.0 com.google.guava diff --git a/vision/landmark-detection/pom.xml b/vision/landmark-detection/pom.xml index 620a03dca16..3a055738d4e 100644 --- a/vision/landmark-detection/pom.xml +++ b/vision/landmark-detection/pom.xml @@ -43,7 +43,7 @@ com.google.api-client google-api-client - 1.22.0 + 1.23.0 com.google.guava diff --git a/vision/text/pom.xml b/vision/text/pom.xml index 8af3bb2d9de..0b9a5c6ec66 100644 --- a/vision/text/pom.xml +++ b/vision/text/pom.xml @@ -43,7 +43,7 @@ com.google.api-client google-api-client - 1.22.0 + 1.23.0 com.google.guava From 8548a77ae2a6d81a63e8dbd8a615d8afce771227 Mon Sep 17 00:00:00 2001 From: DPE bot Date: Thu, 5 Oct 2017 19:16:54 -0700 Subject: [PATCH 09/10] Auto-update dependencies. (#879) --- compute/cmdline/pom.xml | 2 +- kms/pom.xml | 2 +- storage/json-api/pom.xml | 2 +- storage/storage-transfer/pom.xml | 2 +- storage/xml-api/cmdline-sample/pom.xml | 2 +- vision/face-detection/pom.xml | 2 +- vision/label/pom.xml | 2 +- vision/landmark-detection/pom.xml | 2 +- vision/text/pom.xml | 2 +- 9 files changed, 9 insertions(+), 9 deletions(-) diff --git a/compute/cmdline/pom.xml b/compute/cmdline/pom.xml index a2747461175..b69df85a209 100644 --- a/compute/cmdline/pom.xml +++ b/compute/cmdline/pom.xml @@ -84,7 +84,7 @@ limitations under the License. - v1-rev157-1.22.0 + v1-rev158-1.23.0 UTF-8 diff --git a/kms/pom.xml b/kms/pom.xml index eee7b66824d..239cf330284 100644 --- a/kms/pom.xml +++ b/kms/pom.xml @@ -16,7 +16,7 @@ com.google.apis google-api-services-cloudkms - v1-rev22-1.22.0 + v1-rev22-1.23.0 com.google.guava diff --git a/storage/json-api/pom.xml b/storage/json-api/pom.xml index 22a58c30878..4c1e4718880 100644 --- a/storage/json-api/pom.xml +++ b/storage/json-api/pom.xml @@ -38,7 +38,7 @@ com.google.apis google-api-services-storage - v1-rev112-1.22.0 + v1-rev112-1.23.0 com.google.guava diff --git a/storage/storage-transfer/pom.xml b/storage/storage-transfer/pom.xml index caecfbc635d..4d475296783 100644 --- a/storage/storage-transfer/pom.xml +++ b/storage/storage-transfer/pom.xml @@ -38,7 +38,7 @@ com.google.apis google-api-services-storagetransfer - v1-rev26-1.22.0 + v1-rev26-1.23.0 com.google.guava diff --git a/storage/xml-api/cmdline-sample/pom.xml b/storage/xml-api/cmdline-sample/pom.xml index 6c80ae761a9..b221ffb0da1 100644 --- a/storage/xml-api/cmdline-sample/pom.xml +++ b/storage/xml-api/cmdline-sample/pom.xml @@ -66,7 +66,7 @@ com.google.apis google-api-services-storage - v1-rev112-1.22.0 + v1-rev112-1.23.0 com.google.guava diff --git a/vision/face-detection/pom.xml b/vision/face-detection/pom.xml index c49f446b848..cf9902da065 100644 --- a/vision/face-detection/pom.xml +++ b/vision/face-detection/pom.xml @@ -39,7 +39,7 @@ com.google.apis google-api-services-vision - v1-rev362-1.22.0 + v1-rev363-1.23.0 com.google.api-client diff --git a/vision/label/pom.xml b/vision/label/pom.xml index 4e7eeb12017..6970c5ed49e 100644 --- a/vision/label/pom.xml +++ b/vision/label/pom.xml @@ -38,7 +38,7 @@ com.google.apis google-api-services-vision - v1-rev362-1.22.0 + v1-rev363-1.23.0 com.google.api-client diff --git a/vision/landmark-detection/pom.xml b/vision/landmark-detection/pom.xml index 3a055738d4e..dee4868732f 100644 --- a/vision/landmark-detection/pom.xml +++ b/vision/landmark-detection/pom.xml @@ -38,7 +38,7 @@ com.google.apis google-api-services-vision - v1-rev362-1.22.0 + v1-rev363-1.23.0 com.google.api-client diff --git a/vision/text/pom.xml b/vision/text/pom.xml index 0b9a5c6ec66..94e54560076 100644 --- a/vision/text/pom.xml +++ b/vision/text/pom.xml @@ -38,7 +38,7 @@ com.google.apis google-api-services-vision - v1-rev362-1.22.0 + v1-rev363-1.23.0 com.google.api-client From 6637e6bb7b8e26484d9db3b0aa63952892ebc92b Mon Sep 17 00:00:00 2001 From: lluunn <32310205+lluunn@users.noreply.github.com> Date: Fri, 6 Oct 2017 11:15:28 -0700 Subject: [PATCH 10/10] Java sample for doing online prediction in Cloud Machine Learning Engine. (#868) * Java sample for online prediction in CMLE. * update README * add licence and some comments * Update README, add license to pom.xml * fix README * small fix --- mlengine/online-prediction/README.md | 18 +++++ mlengine/online-prediction/input.txt | 1 + mlengine/online-prediction/pom.xml | 62 ++++++++++++++++ .../src/main/java/OnlinePredictionSample.java | 73 +++++++++++++++++++ 4 files changed, 154 insertions(+) create mode 100644 mlengine/online-prediction/README.md create mode 100644 mlengine/online-prediction/input.txt create mode 100644 mlengine/online-prediction/pom.xml create mode 100644 mlengine/online-prediction/src/main/java/OnlinePredictionSample.java diff --git a/mlengine/online-prediction/README.md b/mlengine/online-prediction/README.md new file mode 100644 index 00000000000..2723b8ceb8c --- /dev/null +++ b/mlengine/online-prediction/README.md @@ -0,0 +1,18 @@ +# Cloud Machine Learning Engine - Online Prediction with Java + +## Setup +This sample demonstrates how to send online prediction requests to your deployed +model on CMLE. +Follow the [tutorial](https://cloud.google.com/ml-engine/docs/how-tos/deploying-models) +to deploy your model first. + +This sample is using the [Application Default Credential](https://developers.google.com/identity/protocols/application-default-credentials). You can install the Google Cloud SDK and run: +

gcloud auth application-default login
+ +## Run +Modify the OnlinePredictionSample.java with your project/model/version information. + +Compile the sample code using Maven by running the following command: +
mvn compile
+Execute the sample code using Maven by running the following command: +
mvn -q exec:java
diff --git a/mlengine/online-prediction/input.txt b/mlengine/online-prediction/input.txt new file mode 100644 index 00000000000..19eb80fdd15 --- /dev/null +++ b/mlengine/online-prediction/input.txt @@ -0,0 +1 @@ +{"instances": ["YOUR_INPUT_INSTANCE1", "YOUR_INPUT_INSTANCE2"]} diff --git a/mlengine/online-prediction/pom.xml b/mlengine/online-prediction/pom.xml new file mode 100644 index 00000000000..c7e87f0c740 --- /dev/null +++ b/mlengine/online-prediction/pom.xml @@ -0,0 +1,62 @@ + + + + 4.0.0 + com.google.cloud.samples + mlengine-online-prediction + 1 + + + + + org.codehaus.mojo + exec-maven-plugin + 1.4.0 + + + + java + + + + + OnlinePredictionSample + + + java.util.logging.config.file + logging.properties + + + + + + + + + joda-time + joda-time + 2.2 + + + com.google.api-client + google-api-client + 1.22.0 + + + com.google.apis + google-api-services-discovery + v1-rev58-1.22.0 + + + diff --git a/mlengine/online-prediction/src/main/java/OnlinePredictionSample.java b/mlengine/online-prediction/src/main/java/OnlinePredictionSample.java new file mode 100644 index 00000000000..6f70dad7009 --- /dev/null +++ b/mlengine/online-prediction/src/main/java/OnlinePredictionSample.java @@ -0,0 +1,73 @@ +/* + * Copyright 2017 Google Inc. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +import com.google.api.client.googleapis.auth.oauth2.GoogleCredential; +import com.google.api.client.googleapis.javanet.GoogleNetHttpTransport; +import com.google.api.client.http.FileContent; +import com.google.api.client.http.GenericUrl; +import com.google.api.client.http.HttpContent; +import com.google.api.client.http.HttpRequest; +import com.google.api.client.http.HttpRequestFactory; +import com.google.api.client.http.HttpTransport; +import com.google.api.client.http.UriTemplate; +import com.google.api.client.json.JsonFactory; +import com.google.api.client.json.jackson2.JacksonFactory; +import com.google.api.services.discovery.Discovery; +import com.google.api.services.discovery.model.JsonSchema; +import com.google.api.services.discovery.model.RestDescription; +import com.google.api.services.discovery.model.RestMethod; +import java.io.File; + +/* + * Sample code for doing Cloud Machine Learning Engine online prediction in Java. + */ + +public class OnlinePredictionSample { + public static void main(String[] args) throws Exception { + HttpTransport httpTransport = GoogleNetHttpTransport.newTrustedTransport(); + JsonFactory jsonFactory = JacksonFactory.getDefaultInstance(); + Discovery discovery = new Discovery.Builder(httpTransport, jsonFactory, null).build(); + + RestDescription api = discovery.apis().getRest("ml", "v1").execute(); + RestMethod method = api.getResources().get("projects").getMethods().get("predict"); + + JsonSchema param = new JsonSchema(); + String projectId = "YOUR_PROJECT_ID"; + // You should have already deployed a model and a version. + // For reference, see https://cloud.google.com/ml-engine/docs/how-tos/deploying-models. + String modelId = "YOUR_MODEL_ID"; + String versionId = "YOUR_VERSION_ID"; + param.set( + "name", String.format("projects/%s/models/%s/versions/%s", projectId, modelId, versionId)); + + GenericUrl url = + new GenericUrl(UriTemplate.expand(api.getBaseUrl() + method.getPath(), param, true)); + System.out.println(url); + + String contentType = "application/json"; + File requestBodyFile = new File("input.txt"); + HttpContent content = new FileContent(contentType, requestBodyFile); + System.out.println(content.getLength()); + + GoogleCredential credential = GoogleCredential.getApplicationDefault(); + HttpRequestFactory requestFactory = httpTransport.createRequestFactory(credential); + HttpRequest request = requestFactory.buildRequest(method.getHttpMethod(), url, content); + + String response = request.execute().parseAsString(); + System.out.println(response); + } +} +