This repository contains code to manage CI/CD for the many Pulumi providers in a consistent and (mostly) automated manner. The repo's intended audience are Pulumi Corp engineers, but its contents may also serve as a helpful example for Pulumi community members looking to maintain their own providers with a similar CI/CD process to Pulumi Corp.
Pulumi providers use GitHub Actions for CI/CD. Because we maintain a long list of providers, we use this repository to:
- Generate GitHub Actions Workflow files for any provider. These can be deployed to all providers or a single provider respectively by the GitHub Actions workflows in this repository.
- Keep an inventory of existing Pulumi providers.
- Maintain logic for branch protection across provider repositories.
This repository has the following components:
-
The
provider-ci
andnative-provider-ci
directories contain code to generate GitHub Actions workflow files for Pulumi providers, as well as the generated output for each provider (retained for the purpose of convenient output diffing). -
The
infra/providers/
directory contains a Pulumi program which uses the Pulumi GitHub provider to ensure consistent branch protections across our provider repositories.For an overview of how Pulumi programs work, see the Pulumi docs.
-
GitHub Actions workflows to automate common operations across all providers or a single provider.
The following tools are required for generating and deploying GitHub Actions workflows:
After checking out the code, run the following command:
cd provider-ci && make clean && make -j
Common commands:
make
: Generate all code and check the output.make provider NAME=aws
: Generate code for single provider with debug informationmake lint-providers
: Check the generated code for all providers.make lint-providers/aws/repo
: Check the generated code for a specific provider.
Sometimes, you want those changes NOW rather than having to wait for a GitHub PR.
This example command will generate workflows for pulumi-datadog, and place them in the specified --out
directory.
Adjust for your provider and filesystem.
./bin/provider-ci generate --name pulumi/pulumi-datadog --template bridged-provider --config ./providers/datadog/config.yaml --out ../../pulumi-dtadog
To add a new provider:
-
A new provider needs a top-level
.ci-mgmt.yaml
in its own repository with the following basic configuration:# Required values: provider: foo # substitute the name of your provider, without the pulumi- prefix env: # A map of required configuration for any integration tests, etc. AN_OPTION: value ANOTHER_OPTION: true # etc. lint: true # Linting should be true in most cases, unless failing rules in the upstream provider makes this impractical. # Optional values: docker: true # Whether the provider's tests use Docker to run. If set to true, a file `testing/docker-compose.yml` must be present in the provider repository. setup-script: testing/setup.sh # Path to a script that's used for testing bootstraps
ci-mgmt
will read your provider's.ci-mgmt.yaml
and generate the standard set of CI files from templates. You can override every one of the default values in your.ci-mgmt.yaml
file. -
Add your provider to
provider-ci/providers.json
in alphabetical order. This ensures your provider receives regular updates and maintenance. -
Add your provider to
.github/ISSUE_TEMPLATE/0-ecosystem-providers.md
to ensure manual rollouts track your provider. -
Commit the changes and open a pull request.
-
To receive a pull request with your new config files, you can run the Update Workflows, Single Bridged Provider workflow run, using your provider name as the input. Another option is to wait for the nightly cronjob to send this pull request automatically.
-
If you would like to manually generate the configuration to get started right away, you can do so in your provider repository root:
go run github.com/pulumi/ci-mgmt/provider-ci@master generate \ --name pulumi/pulumi-$(PROVIDER_NAME) \ --out . \ --template bridged-provider \ --config .ci-mgmt.yaml
The generated files will be writen to your current directory.
The Update GH Workflows, ecosystem providers Workflow runs on a nightly schedule. You may trigger this Workflow manually; however be aware that this causes a lot of GitHub Actions to run at the same time, which may cause rate limiting across the org. Plan ahead and do this at a low-traffic time.
Fetch the latest JSON Schema then re-generate type definitions:
make discovery
You can apply ad-hoc source edits across provider repositories even on files that are not managed or generated by ci-mgmt. For example, you might need to automatically update example code to use a newer Pulumi SDK major version dependency or a newer version of the underlying infrastructure such as .NET Framework. This can be done with migrations:
-
describe your desired edits as a
SourceMigration
inprovider-ci/internal/pkg/migrations
-
test your changes locally by running ci-mgmt:
go run . generate -c ../../pulumi-azure/.ci-mgmt.yaml -o ../../pulumi-azure/
-
stand up a PR to ci-mgmt
-
trigger an action such as update-workflows-bridged-providers.yml from the PR; this will create PRs that synchronize the selected repositories with ci-mgmt and apply the source migration as part of the change
-
merge the PR to ci-mgmt
-
merge the PR to the desired provider repositories (not needed if these PRs are set to automerge)