1
+ # This workflow builds the product for all supported platforms and uploads the resulting
2
+ # binaries as Actions artifacts. The workflow also uploads a build metadata file
3
+ # (metadata.json) -- and a Terraform Registry manifest file (terraform-registry-manifest.json).
4
+ #
5
+ # Reference: https://github.com/hashicorp/terraform-provider-crt-example/blob/main/.github/workflows/README.md
6
+ #
7
+
8
+ name : build
9
+
10
+ # We default to running this workflow on every push to every branch.
11
+ # This provides fast feedback when build issues occur, so they can be
12
+ # fixed prior to being merged to the main branch.
13
+ #
14
+ # If you want to opt out of this, and only run the build on certain branches
15
+ # please refer to the documentation on branch filtering here:
16
+ #
17
+ # https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#onpushbranchestagsbranches-ignoretags-ignore
18
+ #
19
+ on : [workflow_dispatch, push]
20
+
21
+ env :
22
+ PKG_NAME : " terraform-provider-archive"
23
+
24
+ jobs :
25
+ # Detects the Go toolchain version to use for product builds.
26
+ #
27
+ # The implementation is inspired by envconsul -- https://go.hashi.co/get-go-version-example
28
+ get-go-version :
29
+ name : " Detect Go toolchain version"
30
+ runs-on : ubuntu-latest
31
+ outputs :
32
+ go-version : ${{ steps.get-go-version.outputs.go-version }}
33
+ steps :
34
+ - uses : actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
35
+ - uses : actions/setup-go@0aaccfd150d50ccaeb58ebd88d36e91967a5f35b # v5.4.0
36
+ with :
37
+ go-version-file : ' go.mod'
38
+ - name : Detect Go version
39
+ id : get-go-version
40
+ run : |
41
+ version="$(go list -f {{.GoVersion}} -m)"
42
+ echo "go-version=$version" >> "$GITHUB_OUTPUT"
43
+
44
+ # Parses the version/VERSION file. Reference: https://github.com/hashicorp/actions-set-product-version/blob/main/README.md
45
+ #
46
+ # > This action should be implemented in product repo `build.yml` files. The action is intended to grab the version
47
+ # > from the version file at the beginning of the build, then passes those versions (along with metadata, where
48
+ # > necessary) to any workflow jobs that need version information.
49
+ set-product-version :
50
+ name : " Parse version file"
51
+ runs-on : ubuntu-latest
52
+ outputs :
53
+ product-version : ${{ steps.set-product-version.outputs.product-version }}
54
+ product-base-version : ${{ steps.set-product-version.outputs.base-product-version }}
55
+ product-prerelease-version : ${{ steps.set-product-version.outputs.prerelease-product-version }}
56
+ product-minor-version : ${{ steps.set-product-version.outputs.minor-product-version }}
57
+ steps :
58
+ - uses : actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
59
+ - name : Set variables
60
+ id : set-product-version
61
+ uses : hashicorp/actions-set-product-version@v2
62
+
63
+ # Creates metadata.json file containing build metadata for consumption by CRT workflows.
64
+ #
65
+ # Reference: https://github.com/hashicorp/actions-generate-metadata/blob/main/README.md
66
+ generate-metadata-file :
67
+ needs : set-product-version
68
+ runs-on : ubuntu-latest
69
+ outputs :
70
+ filepath : ${{ steps.generate-metadata-file.outputs.filepath }}
71
+ steps :
72
+ - name : " Checkout directory"
73
+ uses : actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
74
+ - name : Generate metadata file
75
+ id : generate-metadata-file
76
+ uses : hashicorp/actions-generate-metadata@v1
77
+ with :
78
+ version : ${{ needs.set-product-version.outputs.product-version }}
79
+ product : ${{ env.PKG_NAME }}
80
+ repositoryOwner : " hashicorp"
81
+ - uses : actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2
82
+ with :
83
+ name : metadata.json
84
+ path : ${{ steps.generate-metadata-file.outputs.filepath }}
85
+
86
+ # Uploads an Actions artifact named terraform-registry-manifest.json.zip.
87
+ #
88
+ # The artifact contains a single file with a filename that Terraform Registry expects
89
+ # (example: terraform-provider-crt-example_2.3.6-alpha1_manifest.json). The file contents
90
+ # are identical to the terraform-registry-manifest.json file in the source repository.
91
+ upload-terraform-registry-manifest-artifact :
92
+ needs : set-product-version
93
+ runs-on : ubuntu-latest
94
+ steps :
95
+ - name : " Checkout directory"
96
+ uses : actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
97
+ with :
98
+ path : ${{ env.PKG_NAME }}
99
+ - name : " Copy manifest from checkout directory to a file with the desired name"
100
+ id : terraform-registry-manifest
101
+ run : |
102
+ name="${{ env.PKG_NAME }}"
103
+ version="${{ needs.set-product-version.outputs.product-version }}"
104
+
105
+ source="${name}/terraform-registry-manifest.json"
106
+ destination="${name}_${version}_manifest.json"
107
+
108
+ cp "$source" "$destination"
109
+ echo "filename=$destination" >> "$GITHUB_OUTPUT"
110
+ - uses : actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2
111
+ with :
112
+ name : terraform-registry-manifest.json
113
+ path : ${{ steps.terraform-registry-manifest.outputs.filename }}
114
+ if-no-files-found : error
115
+
116
+ # Builds the product for all platforms except macOS.
117
+ #
118
+ # With `reproducible: report`, this job also reports whether the build is reproducible,
119
+ # but does not enforce it.
120
+ #
121
+ # Reference: https://github.com/hashicorp/actions-go-build/blob/main/README.md
122
+ build :
123
+ needs :
124
+ - get-go-version
125
+ - set-product-version
126
+ runs-on : ubuntu-latest
127
+ strategy :
128
+ fail-fast : true
129
+ # Verify expected Artifacts list for a workflow run.
130
+ matrix :
131
+ goos : [freebsd, windows, linux, darwin]
132
+ goarch : ["386", "amd64", "arm", "arm64"]
133
+ exclude :
134
+ - goos : freebsd
135
+ goarch : arm64
136
+ - goos : windows
137
+ goarch : arm64
138
+ - goos : windows
139
+ goarch : arm
140
+ - goos : darwin
141
+ goarch : 386
142
+ - goos : darwin
143
+ goarch : arm
144
+
145
+ name : Go ${{ needs.get-go-version.outputs.go-version }} ${{ matrix.goos }} ${{ matrix.goarch }} build
146
+ steps :
147
+ - uses : actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
148
+ - uses : hashicorp/actions-go-build@v1
149
+ env :
150
+ CGO_ENABLED : 0
151
+ BASE_VERSION : ${{ needs.set-product-version.outputs.product-base-version }}
152
+ PRERELEASE_VERSION : ${{ needs.set-product-version.outputs.product-prerelease-version}}
153
+ METADATA_VERSION : ${{ env.METADATA }}
154
+ with :
155
+ bin_name : " ${{ env.PKG_NAME }}_v${{ needs.set-product-version.outputs.product-version }}_x5"
156
+ product_name : ${{ env.PKG_NAME }}
157
+ product_version : ${{ needs.set-product-version.outputs.product-version }}
158
+ go_version : ${{ needs.get-go-version.outputs.go-version }}
159
+ os : ${{ matrix.goos }}
160
+ arch : ${{ matrix.goarch }}
161
+ reproducible : report
162
+ instructions : |
163
+ go build \
164
+ -o "$BIN_PATH" \
165
+ -trimpath \
166
+ -buildvcs=false \
167
+ -ldflags "-s -w"
168
+ cp LICENSE "$TARGET_DIR/LICENSE.txt"
169
+
170
+ whats-next :
171
+ needs :
172
+ - build
173
+ - generate-metadata-file
174
+ - upload-terraform-registry-manifest-artifact
175
+ runs-on : ubuntu-latest
176
+ name : " What's next?"
177
+ steps :
178
+ - name : " Write a helpful summary"
179
+ run : |
180
+ github_dot_com="${{ github.server_url }}"
181
+ owner_with_name="${{ github.repository }}"
182
+ ref="${{ github.ref }}"
183
+
184
+ echo "### What's next?" >> "$GITHUB_STEP_SUMMARY"
185
+ echo "#### For a release branch (see \`.release/ci.hcl\`)" >> $GITHUB_STEP_SUMMARY
186
+ echo "After this \`build\` workflow run completes succesfully, you can expect the CRT \`prepare\` workflow to begin momentarily." >> "$GITHUB_STEP_SUMMARY"
187
+ echo "To find the \`prepare\` workflow run, [view the checks for this commit]($github_dot_com/$owner_with_name/commits/$ref)" >> "$GITHUB_STEP_SUMMARY"
0 commit comments