A template repository for a Cloud Run microservice, written in Node.js.
gcloud services enable run.googleapis.com
This template works with Cloud Code, an IDE extension to let you rapidly iterate, debug, and run code on Kubernetes and Cloud Run.
Learn how to use Cloud Code for:
Creating a new application from a custom template (.template/templates.json
allows for use as an app template) - VSCode, IntelliJ
export GOOGLE_CLOUD_PROJECT=<GCP_PROJECT_ID>
npm run dev
Set Project Id:
export GOOGLE_CLOUD_PROJECT=<GCP_PROJECT_ID>
Enable the Artifact Registry API:
gcloud services enable artifactregistry.googleapis.com
Create an Artifact Registry repo:
export REPOSITORY="samples"
export REGION=us-central1
gcloud artifacts repositories create $REPOSITORY --location $REGION --repository-format "docker"
Use the gcloud credential helper to authorize Docker to push to your Artifact Registry:
gcloud auth configure-docker
Build the container using a buildpack:
npm run build
Deploy to Cloud Run:
npm run deploy
Pass credentials via GOOGLE_APPLICATION_CREDENTIALS
env var:
export GOOGLE_APPLICATION_CREDENTIALS="[PATH]"
Set Project Id:
export GOOGLE_CLOUD_PROJECT=<GCP_PROJECT_ID>
Run unit tests
npm run test
Run system tests
gcloud builds submit \
--config test/advance.cloudbuild.yaml \
--substitutions 'COMMIT_SHA=manual'
The Cloud Build configuration file will build and deploy the containerized service to Cloud Run, run tests managed by NPM, then clean up testing resources. This configuration restricts public access to the test service. Therefore, service accounts need to have the permission to issue Id tokens for request authorization:
Enable Cloud Run, Cloud Build, Artifact Registry, and IAM APIs:
gcloud services enable run.googleapis.com cloudbuild.googleapis.com iamcredentials.googleapis.com artifactregistry.googleapis.com
Set environment variables.
export PROJECT_ID="$(gcloud config get-value project)"
export PROJECT_NUMBER="$(gcloud projects describe $(gcloud config get-value project) --format='value(projectNumber)')"
Create an Artifact Registry repo (or use another already created repo):
export REPOSITORY="samples"
export REGION=us-central1
gcloud artifacts repositories create $REPOSITORY --location $REGION --repository-format "docker"
Create service account token-creator
with Service Account Token Creator
and Cloud Run Invoker
roles.
gcloud iam service-accounts create token-creator
gcloud projects add-iam-policy-binding $PROJECT_ID \
--member="serviceAccount:token-creator@$PROJECT_ID.iam.gserviceaccount.com" \
--role="roles/iam.serviceAccountTokenCreator"
gcloud projects add-iam-policy-binding $PROJECT_ID \
--member="serviceAccount:token-creator@$PROJECT_ID.iam.gserviceaccount.com" \
--role="roles/run.invoker"
Add Service Account Token Creator
role to the Cloud Build service account.
gcloud projects add-iam-policy-binding $PROJECT_ID \
--member="serviceAccount:$PROJECT_NUMBER@cloudbuild.gserviceaccount.com" \
--role="roles/iam.serviceAccountTokenCreator"
This repo performs basic periodic testing for maintenance. Please use the issue tracker for bug reports, features requests and submitting pull requests.
Please see the contributing guidelines
This library is licensed under Apache 2.0. Full license text is available in LICENSE.