generated from pulumi/pulumi-tf-provider-boilerplate
-
Notifications
You must be signed in to change notification settings - Fork 12
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Regenerate workflows for pulumi-grafana (#226)
Co-authored-by: pulumi-bot <[email protected]>
- Loading branch information
1 parent
83bbca7
commit b908ad3
Showing
6 changed files
with
66 additions
and
49 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
name: Download the code generator binary | ||
description: Downloads the code generator binary to `bin/`. | ||
|
||
runs: | ||
using: "composite" | ||
steps: | ||
|
||
- name: Download the code generator binary for grafana | ||
uses: actions/download-artifact@fa0a91b85d4f404e444e00e005971372dc801d16 # v4.1.8 | ||
with: | ||
name: pulumi-tfgen-grafana | ||
path: ${{ github.workspace }}/bin | ||
|
||
- name: Ensure the code generator binary for grafana is executable | ||
shell: bash | ||
run: | | ||
find ${{ github.workspace }} -name "pulumi-*-grafana" -print -exec chmod +x {} \; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -5,7 +5,7 @@ ORG := pulumiverse | |
PROJECT := github.com/$(ORG)/pulumi-$(PACK) | ||
PROVIDER_PATH := provider | ||
VERSION_PATH := $(PROVIDER_PATH)/pkg/version.Version | ||
TFGEN := pulumi-tfgen-$(PACK) | ||
CODEGEN := pulumi-tfgen-$(PACK) | ||
PROVIDER := pulumi-resource-$(PACK) | ||
JAVA_GEN := pulumi-java-gen | ||
TESTPARALLELISM := 10 | ||
|
@@ -14,11 +14,17 @@ PULUMI_PROVIDER_BUILD_PARALLELISM ?= | |
PULUMI_CONVERT := 1 | ||
PULUMI_MISSING_DOCS_ERROR := true | ||
|
||
PULUMICTL_VERSION := v0.0.46 | ||
PULUMICTL := $(shell which pulumictl || \ | ||
(test ! -e $(WORKING_DIR)/bin/pulumictl && \ | ||
GOPATH="$(WORKING_DIR)" go install "github.com/pulumi/pulumictl/cmd/pulumictl@$(PULUMICTL_VERSION)"; \ | ||
echo "$(WORKING_DIR)/bin/puluimctl")) | ||
|
||
# Override during CI using `make [TARGET] PROVIDER_VERSION=""` or by setting a PROVIDER_VERSION environment variable | ||
# Local & branch builds will just used this fixed default version unless specified | ||
PROVIDER_VERSION ?= 0.0.0-alpha.0+dev | ||
# Use this normalised version everywhere rather than the raw input to ensure consistency. | ||
VERSION_GENERIC = $(shell pulumictl convert-version --language generic --version "$(PROVIDER_VERSION)") | ||
VERSION_GENERIC = $(shell $(PULUMICTL) convert-version --language generic --version "$(PROVIDER_VERSION)") | ||
|
||
# Strips debug information from the provider binary to reduce its size and speed up builds | ||
LDFLAGS_STRIP_SYMBOLS=-s -w | ||
|
@@ -29,7 +35,7 @@ LDFLAGS=$(LDFLAGS_PROJ_VERSION) $(LDFLAGS_UPSTREAM_VERSION) $(LDFLAGS_EXTRAS) $( | |
|
||
# Create a `.make` directory for tracking targets which don't generate a single file output. This should be ignored by git. | ||
# For targets which either don't generate a single file output, or the output file is committed, we use a "sentinel" | ||
# file within `.make/` to track the staleness of the target and only rebuild when needed. | ||
# file within `.make/` to track the staleness of the target and only rebuild when needed. | ||
# For each phony target, we create an internal target with the same name, but prefixed with `.make/` where the work is performed. | ||
# At the end of each internal target we run `@touch $@` to update the file which is the name of the target. | ||
|
||
|
@@ -95,8 +101,8 @@ GEN_ENVS := PULUMI_HOME=$(GEN_PULUMI_HOME) PULUMI_CONVERT_EXAMPLES_CACHE_DIR=$(G | |
generate_dotnet: .make/generate_dotnet | ||
build_dotnet: .make/build_dotnet | ||
.make/generate_dotnet: export PATH := $(WORKING_DIR)/.pulumi/bin:$(PATH) | ||
.make/generate_dotnet: .make/install_plugins bin/$(TFGEN) | ||
$(GEN_ENVS) $(WORKING_DIR)/bin/$(TFGEN) dotnet --out sdk/dotnet/ | ||
.make/generate_dotnet: .make/install_plugins bin/$(CODEGEN) | ||
$(GEN_ENVS) $(WORKING_DIR)/bin/$(CODEGEN) dotnet --out sdk/dotnet/ | ||
cd sdk/dotnet/ && \ | ||
printf "module fake_dotnet_module // Exclude this directory from Go tools\n\ngo 1.17\n" > go.mod && \ | ||
echo "$(VERSION_GENERIC)" >version.txt | ||
|
@@ -109,8 +115,8 @@ build_dotnet: .make/build_dotnet | |
generate_go: .make/generate_go | ||
build_go: .make/build_go | ||
.make/generate_go: export PATH := $(WORKING_DIR)/.pulumi/bin:$(PATH) | ||
.make/generate_go: .make/install_plugins bin/$(TFGEN) | ||
$(GEN_ENVS) $(WORKING_DIR)/bin/$(TFGEN) go --out sdk/go/ | ||
.make/generate_go: .make/install_plugins bin/$(CODEGEN) | ||
$(GEN_ENVS) $(WORKING_DIR)/bin/$(CODEGEN) go --out sdk/go/ | ||
@touch $@ | ||
.make/build_go: .make/generate_go | ||
cd sdk && go list "$$(grep -e "^module" go.mod | cut -d ' ' -f 2)/go/..." | xargs -I {} bash -c 'go build {} && go clean -i {}' | ||
|
@@ -136,8 +142,8 @@ build_java: .make/build_java | |
generate_nodejs: .make/generate_nodejs | ||
build_nodejs: .make/build_nodejs | ||
.make/generate_nodejs: export PATH := $(WORKING_DIR)/.pulumi/bin:$(PATH) | ||
.make/generate_nodejs: .make/install_plugins bin/$(TFGEN) | ||
$(GEN_ENVS) $(WORKING_DIR)/bin/$(TFGEN) nodejs --out sdk/nodejs/ | ||
.make/generate_nodejs: .make/install_plugins bin/$(CODEGEN) | ||
$(GEN_ENVS) $(WORKING_DIR)/bin/$(CODEGEN) nodejs --out sdk/nodejs/ | ||
printf "module fake_nodejs_module // Exclude this directory from Go tools\n\ngo 1.17\n" > sdk/nodejs/go.mod | ||
@touch $@ | ||
.make/build_nodejs: .make/generate_nodejs | ||
|
@@ -151,8 +157,8 @@ build_nodejs: .make/build_nodejs | |
generate_python: .make/generate_python | ||
build_python: .make/build_python | ||
.make/generate_python: export PATH := $(WORKING_DIR)/.pulumi/bin:$(PATH) | ||
.make/generate_python: .make/install_plugins bin/$(TFGEN) | ||
$(GEN_ENVS) $(WORKING_DIR)/bin/$(TFGEN) python --out sdk/python/ | ||
.make/generate_python: .make/install_plugins bin/$(CODEGEN) | ||
$(GEN_ENVS) $(WORKING_DIR)/bin/$(CODEGEN) python --out sdk/python/ | ||
printf "module fake_python_module // Exclude this directory from Go tools\n\ngo 1.17\n" > sdk/python/go.mod | ||
cp README.md sdk/python/ | ||
@touch $@ | ||
|
@@ -193,7 +199,7 @@ install_nodejs_sdk: .make/install_nodejs_sdk | |
install_python_sdk: | ||
.PHONY: install_dotnet_sdk install_go_sdk install_java_sdk install_nodejs_sdk install_python_sdk | ||
|
||
# Install Pulumi plugins required for TFGen to resolve references | ||
# Install Pulumi plugins required for CODEGEN to resolve references | ||
install_plugins: .make/install_plugins | ||
.make/install_plugins: export PULUMI_HOME := $(WORKING_DIR)/.pulumi | ||
.make/install_plugins: export PATH := $(WORKING_DIR)/.pulumi/bin:$(PATH) | ||
|
@@ -215,12 +221,12 @@ lint_provider.fix: | |
# `make provider_no_deps` builds the provider binary directly, without ensuring that | ||
# `cmd/pulumi-resource-grafana/schema.json` is valid and up to date. | ||
# To create a release ready binary, you should use `make provider`. | ||
build_provider_cmd = cd provider && go build $(PULUMI_PROVIDER_BUILD_PARALLELISM) -o $(WORKING_DIR)/bin/$(PROVIDER) -ldflags "$(LDFLAGS)" $(PROJECT)/$(PROVIDER_PATH)/cmd/$(PROVIDER) | ||
build_provider_cmd = cd provider && CGO_ENABLED=0 go build $(PULUMI_PROVIDER_BUILD_PARALLELISM) -o "$(1)" -ldflags "$(LDFLAGS)" $(PROJECT)/$(PROVIDER_PATH)/cmd/$(PROVIDER) | ||
provider: bin/$(PROVIDER) | ||
provider_no_deps: | ||
$(call build_provider_cmd) | ||
$(call build_provider_cmd,$(WORKING_DIR)/bin/$(PROVIDER)) | ||
bin/$(PROVIDER): .make/schema | ||
$(call build_provider_cmd) | ||
$(call build_provider_cmd,$(WORKING_DIR)/bin/$(PROVIDER)) | ||
.PHONY: provider provider_no_deps | ||
|
||
test: export PATH := $(WORKING_DIR)/bin:$(PATH) | ||
|
@@ -246,13 +252,13 @@ tfgen_no_deps: .make/schema | |
.make/schema: export PULUMI_CONVERT_EXAMPLES_CACHE_DIR := $(WORKING_DIR)/.pulumi/examples-cache | ||
.make/schema: export PULUMI_DISABLE_AUTOMATIC_PLUGIN_ACQUISITION := $(PULUMI_CONVERT) | ||
.make/schema: export PULUMI_MISSING_DOCS_ERROR := $(PULUMI_MISSING_DOCS_ERROR) | ||
.make/schema: bin/$(TFGEN) .make/install_plugins .make/upstream | ||
$(WORKING_DIR)/bin/$(TFGEN) schema --out provider/cmd/$(PROVIDER) | ||
.make/schema: bin/$(CODEGEN) .make/install_plugins .make/upstream | ||
$(WORKING_DIR)/bin/$(CODEGEN) schema --out provider/cmd/$(PROVIDER) | ||
(cd provider && VERSION=$(VERSION_GENERIC) go generate cmd/$(PROVIDER)/main.go) | ||
@touch $@ | ||
tfgen_build_only: bin/$(TFGEN) | ||
bin/$(TFGEN): provider/*.go provider/go.* .make/upstream | ||
(cd provider && go build $(PULUMI_PROVIDER_BUILD_PARALLELISM) -o $(WORKING_DIR)/bin/$(TFGEN) -ldflags "$(LDFLAGS_PROJ_VERSION) $(LDFLAGS_EXTRAS)" $(PROJECT)/$(PROVIDER_PATH)/cmd/$(TFGEN)) | ||
tfgen_build_only: bin/$(CODEGEN) | ||
bin/$(CODEGEN): provider/*.go provider/go.* .make/upstream | ||
(cd provider && go build $(PULUMI_PROVIDER_BUILD_PARALLELISM) -o $(WORKING_DIR)/bin/$(CODEGEN) -ldflags "$(LDFLAGS_PROJ_VERSION) $(LDFLAGS_EXTRAS)" $(PROJECT)/$(PROVIDER_PATH)/cmd/$(CODEGEN)) | ||
.PHONY: tfgen schema tfgen_no_deps tfgen_build_only | ||
|
||
# Apply patches to the upstream submodule, if it exists | ||
|
@@ -266,7 +272,7 @@ endif | |
.PHONY: upstream | ||
|
||
bin/pulumi-java-gen: .pulumi-java-gen.version | ||
pulumictl download-binary -n pulumi-language-java -v v$(shell cat .pulumi-java-gen.version) -r pulumi/pulumi-java | ||
$(PULUMICTL) download-binary -n pulumi-language-java -v v$(shell cat .pulumi-java-gen.version) -r pulumi/pulumi-java | ||
|
||
# To make an immediately observable change to .ci-mgmt.yaml: | ||
# | ||
|
@@ -298,7 +304,7 @@ ci-mgmt: .ci-mgmt.yaml | |
|
||
# Start debug server for tfgen | ||
debug_tfgen: | ||
dlv --listen=:2345 --headless=true --api-version=2 exec $(WORKING_DIR)/bin/$(TFGEN) -- schema --out provider/cmd/$(PROVIDER) | ||
dlv --listen=:2345 --headless=true --api-version=2 exec $(WORKING_DIR)/bin/$(CODEGEN) -- schema --out provider/cmd/$(PROVIDER) | ||
.PHONY: debug_tfgen | ||
|
||
# Provider cross-platform build & packaging | ||
|
@@ -312,29 +318,28 @@ SKIP_SIGNING ?= | |
|
||
# These targets assume that the schema-embed.json exists - it's generated by tfgen. | ||
# We disable CGO to ensure that the binary is statically linked. | ||
bin/linux-amd64/$(PROVIDER): TARGET := linux-amd64 | ||
bin/linux-arm64/$(PROVIDER): TARGET := linux-arm64 | ||
bin/darwin-amd64/$(PROVIDER): TARGET := darwin-amd64 | ||
bin/darwin-arm64/$(PROVIDER): TARGET := darwin-arm64 | ||
bin/windows-amd64/$(PROVIDER).exe: TARGET := windows-amd64 | ||
bin/linux-amd64/$(PROVIDER): export GOOS := linux | ||
bin/linux-amd64/$(PROVIDER): export GOARCH := amd64 | ||
bin/linux-arm64/$(PROVIDER): export GOOS := linux | ||
bin/linux-arm64/$(PROVIDER): export GOARCH := arm64 | ||
bin/darwin-amd64/$(PROVIDER): export GOOS := darwin | ||
bin/darwin-amd64/$(PROVIDER): export GOARCH := amd64 | ||
bin/darwin-arm64/$(PROVIDER): export GOOS := darwin | ||
bin/darwin-arm64/$(PROVIDER): export GOARCH := arm64 | ||
bin/windows-amd64/$(PROVIDER).exe: export GOOS := windows | ||
bin/windows-amd64/$(PROVIDER).exe: export GOARCH := amd64 | ||
bin/%/$(PROVIDER) bin/%/$(PROVIDER).exe: bin/jsign-6.0.jar | ||
@# check the TARGET is set | ||
test $(TARGET) | ||
cd provider && \ | ||
export GOOS=$$(echo "$(TARGET)" | cut -d "-" -f 1) && \ | ||
export GOARCH=$$(echo "$(TARGET)" | cut -d "-" -f 2) && \ | ||
export CGO_ENABLED=0 && \ | ||
go build -o "${WORKING_DIR}/$@" $(PULUMI_PROVIDER_BUILD_PARALLELISM) -ldflags "$(LDFLAGS)" "$(PROJECT)/$(PROVIDER_PATH)/cmd/$(PROVIDER)" | ||
|
||
@# Only sign windows binary if fully configured. | ||
$(call build_provider_cmd,$(WORKING_DIR)/$@) | ||
|
||
@# Only sign windows binary if fully configured. | ||
@# Test variables set by joining with | between and looking for || showing at least one variable is empty. | ||
@# Move the binary to a temporary location and sign it there to avoid the target being up-to-date if signing fails. | ||
set -e; \ | ||
if [[ "${TARGET}" = "windows-amd64" && ${SKIP_SIGNING} != "true" ]]; then \ | ||
@set -e; \ | ||
if [[ "${GOOS}-${GOARCH}" = "windows-amd64" && "${SKIP_SIGNING}" != "true" ]]; then \ | ||
if [[ "|${AZURE_SIGNING_CLIENT_ID}|${AZURE_SIGNING_CLIENT_SECRET}|${AZURE_SIGNING_TENANT_ID}|${AZURE_SIGNING_KEY_VAULT_URI}|" == *"||"* ]]; then \ | ||
echo "Can't sign windows binaries as required configuration not set: AZURE_SIGNING_CLIENT_ID, AZURE_SIGNING_CLIENT_SECRET, AZURE_SIGNING_TENANT_ID, AZURE_SIGNING_KEY_VAULT_URI"; \ | ||
echo "To rebuild with signing delete the unsigned $@ and rebuild with the fixed configuration"; \ | ||
if [[ ${CI} == "true" ]]; then exit 1; fi; \ | ||
if [[ "${CI}" == "true" ]]; then exit 1; fi; \ | ||
else \ | ||
mv $@ [email protected]; \ | ||
az login --service-principal \ | ||
|