This page explains how to use Cloud Build to build and test Node.js
applications, store built artifacts in an npm repository in Artifact Registry, and
generate build provenance information.
Cloud Build enables you to use any publicly available container image
to execute your tasks. The public
node
image from Docker Hub
comes preinstalled with the npm
tool. You can configure Cloud Build
to build your Node.js
project with this tool.
Before you begin
The instructions on this page assume that you are familiar with Node.js
. In
addition:
- Be familiar with npm.
- Have your
Node.js
project handy, includingpackage.json
andtest.js
files. - Make sure your
package.json
file includes astart
script and atest
script. - Be familiar with how to write a Cloud Build configuration file.
- Have an npm repository in Artifact Registry. If you don't have one, create a new repository.
- To run the
gcloud
commands in this page, install the Google Cloud CLI.
Building with npm
To execute your tasks in the node
image from Docker Hub, specify the image URL
in the name
field in the Cloud Build config file.
Cloud Build starts the container specified in the name
field using the image's default entrypoint. To override the default entrypoint
and define how the build step should be run when it is invoked, add an
entrypoint
field in your build step. The node
image in Docker Hub comes
preinstalled with the npm
tool. Specify the tools in the entrypoint
field to
invoke them as the entrypoint of your build step.
In the following example build config file:
- The
name
field specifies that thenode
image from Docker Hub is used by Cloud Build to execute your task. When you're specifying thenode
image, you can either omit the node version to default to:latest
, or specify a node version to use a specific version. For example,name: node
will use the latest version of node, andname: node:12
will usenode:12
. The
entrypoint
field specifies that thenpm
tool is used when thenode
image is invoked.steps: - name: 'node' entrypoint: 'npm'
Configuring Node.js
builds
In your project root directory, create a config file named
cloudbuild.yaml
.Install dependencies: Before you can build your application, you must ensure that all of your project's dependencies are installed from
npm
. You can install dependencies using theinstall
command within thenpm
build step. Theargs
field of a build step takes a list of arguments and passes them to the image referenced by the name field. In your build config file, addinstall
to theargs
field to invoke theinstall
command:steps: - name: 'node' entrypoint: 'npm' args: ['install']
Add tests: If you've defined a
test
script in yourpackage.json
, you can configure Cloud Build to run the script by addingtest
to theargs
field:steps: - name: 'node' entrypoint: 'npm' args: ['install'] - name: 'node' entrypoint: 'npm' args: ['test']
Run custom commands: If your
package.json
contains any custom commands, you can configure Cloud Build to run that command. In theargs
field, addrun
as the first argument followed by the name of the custom command. The following build config file has arguments to run a custom command calledbuild
:steps: - name: 'node' entrypoint: 'npm' args: ['install'] - name: 'node' entrypoint: 'npm' args: ['test'] - name: 'node' entrypoint: 'npm' args: ['run', 'build']
Upload to Artifact Registry:
In your config file, add the
npmPackages
field and specify your npm repository in Artifact Registry:artifacts: npmPackages: - repository: 'https://LOCATION-npm.pkg.dev/PROJECT-ID/REPOSITORY_NAME' packagePath: 'PACKAGE_PATH'
Replace the following values:
- LOCATION: the location for your repository in Artifact Registry.
- PROJECT_ID: the ID of the Google Cloud project that contains your Artifact Registry repository.
- REPOSITORY_NAME: the name of your npm repository in Artifact Registry.
- PACKAGE_PATH: the path for the local directory
containing the npm package that you want to upload to Artifact Registry. We
recommend using an absolute path. Your
PACKAGE_PATH
value can be.
to use the current working directory, but the field cannot be omitted or left empty. This directory must contain apackage.json
file.
Optional: Enable provenance generation
Cloud Build can generate verifiable Supply chain Levels for Software Artifacts (SLSA) build provenance metadata to help secure your continuous integration pipeline.
To enable provenance generation, add
requestedVerifyOption: VERIFIED
to theoptions
section in your config file.Start your build: manually or using build triggers.
Once your build completes, you can view repository details in Artifact Registry.
You can also view build provenance metadata and validate provenance.
Running tests on multiple node
versions
Sometimes it is necessary to ensure that your project works across multiple
versions of node
. You can create and configure
Cloud Build triggers
such that:
- In your build config file, specify the
node
version as a substitution variable. - Create one trigger for each version of
node
against which you want to build your application. - In each of the trigger settings, use the substitution variable value field to
indicate the version of the
node
for that trigger.
The following steps explain how to specify the node
version using trigger-specific
substitution variables:
In your repository root, add a build config file, which specifies the
node
version as a substitution variable. In the following example build config file,$_NODE_VERSION
is a user-defined substitution variable:steps: - name: 'node:$_NODE_VERSION' entrypoint: 'npm' args: ['install'] - name: 'node:$_NODE_VERSION' entrypoint: 'npm' args: ['test']
For each version of
node
you want to build against, create a build trigger using the following steps:Open the Triggers page in the Google Cloud console:
Select your project from the project selector drop-down menu at the top of the page.
Click Open.
Click Create trigger.
On the Create trigger page, enter the following settings:
Enter a name for your trigger.
Select the repository event to start your trigger.
Select the repository that contains your source code and build config file.
Specify the regex for the branch or tag name that will start your trigger.
Configuration: Choose the build config file you created previously.
Under Substitution variables, click Add variable.
- Under Variable, specify the
node
version variable you used in your build config file, and under Value specify the version of thenode
. For example,_NODE_VERSION
and12
.
- Under Variable, specify the
Click Create to save your build trigger.
You can use these triggers to build your code on the version of node
you
specified in the trigger.
What's next
- Learn how to view build results.
- Learn how to safeguard builds.
- Learn how to build container images.
- Learn how to build Go applications.
- Learn how to perform blue/green deployments on Compute Engine.
- Learn how to troubleshoot build errors.