Deploying from Source Control

Cloud Repositories

If you prefer to deploy your function source code from a source repository like GitHub or Bitbucket, you can use Google Cloud Source Repositories to deploy functions directly from branches or tags in your repository.

Set up Cloud Source Repositories

  1. Follow the Cloud Source Repositories getting started steps to set up your repository.
  2. Connect your GitHub or Bitbucket repository by following the hosted repository guide.

Once the connection between Cloud Source Repositories and your external repository is established, these repositories are kept synchronized so that you can commit to your chosen repository as you would normally.

Deploy using the gcloud tool

To deploy a function from your source repo, use the --source command line argument. For example:

gcloud beta functions deploy <NAME> \
  --source<PROJECT_ID>/repos/<REPOSITORY_ID>/moveable-aliases/master/paths/<SOURCE> \

The following table describes common gcloud beta functions deploy arguments:

Argument Description
deploy The Cloud Functions command you are executing, in this case the deploy command.
<NAME> The name of the Cloud Function you are deploying. This name can only contain letters, numbers, underscores, and hyphens. Unless you specify the --entry-point option, your module must export a function with the same name.
--source The location of the source code to deploy. The location can be source code in Google Cloud Storage, a reference to a source repository, or a local filesystem path. For usage details, see the gcloud Command Reference.
<TRIGGER> The trigger type for this function (see Calling Cloud Functions).
--entry-point <FUNCTION_NAME> The name of a function that should be used as an entry point, instead of the <NAME> argument that is used by default. Use this optional argument when the function exported in your source file has a different name than the <NAME> argument you're using to deploy.

Next steps

Send feedback about...

Cloud Functions Documentation