Makefile Cheat Sheet#
The Terraform AWS Provider Makefile includes a lot of functionality to make working on the provider easier and more efficient. Many contributors are familiar with using the Makefile for running acceptance tests, but there is a lot more functionality hidden in this humble file.
Tip
See Continuous Integration for more information about the CI-focused parts of the Makefile.
Basics#
If you're new to our Makefile, this section will bring you up to speed.
Location#
The Makefile is located in the root of the provider repository and is called GNUmakefile.
Phony Targets#
Historically, Makefiles were used to help with the complexities of compiling and linking software projects, managing dependencies, and enabling the creation of various target files. make
would create a "target" file as determined by the command line:
% make <target>
Today, we use phony targets in the Makefile to automate many tasks. "Phony" simply means that the target doesn't define the file we're trying to make but rather the recipe we want to perform, such as running tests.
For example, testacc
is a phony target to simplify the command for running acceptance tests:
make testacc TESTS=TestAccIAMRole_basic PKG=iam
Meta Targets and Dependent Targets#
Meta targets are make
targets that only run other targets. They aggregate the functionality of other targets for convenience. In the Cheat Sheet, meta targets are marked with M.
Dependent targets also run other targets but, in addition, have their own functionality. A dependent target generally runs the other targets first before executing its own functionality. In the Cheat Sheet, dependent targets are marked with D.
For example, in the cheat sheet, the ci
, clean
, and misspell
targets are meta targets that only run other targets.
On the other hand, examples of dependent targets are deps-check
, gen-check
, and semgrep-code-quality
.
When you call a meta or dependent target and it runs other targets, those targets must complete successfully in order for the target you called to succeed.
Variables#
In the Cheat Sheet, you can see which variables affect which targets. This section describes the variables in more detail.
Variables are often defined before the make
call on the same line, such as MY_VAR=42 make my-target
. However, they can also be set on the same line after the make
call or in your environment, using, for example, export MY_VAR=42
.
Note
Targets that meta and dependent targets run may not all respect the same set of variables.
ACCTEST_PARALLELISM
- (Default:20
) Number of concurrent acceptance tests to run. Overridden ifP
is set.ACCTEST_TIMEOUT
- (Default:360m
) Timeout before acceptance tests panic.BASE_REF
- (Default:main
) Origin reference to use for Gitdiff
comparison, as inorigin/BASE_REF
.CURDIR
- (Default: Value of$PWD
) Root path to use for/.ci/scripts/
.GO_VER
- (Default: Value in.go-version
file) Version of Go to use. To use the default version on your system, useGO_VER=go
.K
- (Default: None) Name of the service package you want to use, such asec2
,iam
, orlambda
, limiting Go processing to that package and dependencies. Equivalent toPKG
variable. Assigns values toPKG_NAME
,SVC_DIR
, andTEST
overridding any values set.P
- (Default:20
) Number of concurrent acceptance tests to run. Assigns a value toACCTEST_PARALLELISM
overridding any value set.PKG
- (Default: None) Name of the service package you want to use, such asec2
,iam
, orlambda
, limiting Go processing to that package and dependencies. Equivalent toK
variable. Assigns values toPKG_NAME
,SVC_DIR
, andTEST
overridding any values set.PKG_NAME
- (Default:internal
) Subdirectory (Go package) to use as the basis for Go processing. Overridden ifPKG
orK
is set.RUNARGS
- (Default: None) Raw arguments passed to Go when running acceptance tests. For example,RUNARGS=-run=TestMyTest
. Overridden ifTESTS
orT
is set.SEMGREP_ARGS
- (Default:--error
) Semgrep arguments. See the Semgrep reference.SEMGREP_ENABLE_VERSION_CHECK
- (Default:false
) Whether to check Semgrep servers to verify you are running the latest Semgrep version.SEMGREP_SEND_METRICS
- (Default:off
) When Semgrep usage metrics are sent to Semgrep.SEMGREP_TIMEOUT
- (Default:900
) Maximum time to spend running a rule on a single file, in seconds.SVC_DIR
- (Default:./internal/service
) Directory to as the base for recursive processing. Overridden ifPKG
orK
is set.SWEEP_DIR
- (Default:./internal/sweep
) Location of the sweep directory.SWEEP
- (Default:us-west-2,us-east-1,us-east-2,us-west-1
) Comma-separated list of AWS regions to sweep.SWEEP_TIMEOUT
- (Default:360m
) Time Go will spend sweeping resources before panicking.SWEEPARGS
- (Default: None) Raw arguments that define what to sweep, including dependencies. Similar toSWEEPERS
. For example,SWEEPARGS=-sweep-run=aws_example_thing
.SWEEPERS
- (Default: None) Resources to sweep, including dependencies. Similar toSWEEPARGS
. For example,SWEEPERS=aws_example_thing
. Assigns a value toSWEEPARGS
overridding any value set.T
- (Default: None) Names of tests to run. Equivalent toTESTS
. Assigns a value toRUNARGS
overridding any value set.TEST
- (Default:./...
) Limit tests to this directory and dependencies. Overridden ifPKG
orK
is set.TEST_COUNT
- (Default:1
) Number of times to run each acceptance or unit test.TESTS
- (Default: None) Names of tests to run. Equivalent toT
. Assigns a value toRUNARGS
overridding any value set.TESTARGS
- (Default: None) Raw arguments passed to Go when running tests. UnlikeRUNARGS
, this is not overridden ifTESTS
orT
is set.
Cheat Sheet#
- Target: Use as a subcommand to
make
, such asmake gen
. Meta and dependent targets are marked with M and D, respectively. - Description: When CI-related, this aligns with the name of the check as seen on GitHub.
- CI?: Indicates whether the target is equivalent or largely equivalent to a check run on the GitHub repository for a pull request. See continuous integration for more details.
- Legacy?: Indicates whether the target is a legacy holdover. Use caution with a legacy target! It may not work, or it may perform checks or fixes that do not align with current practices. In the future, this target should be removed, modernized, or verified to still have value.
- Vars: Variables that you can set when using the target, such as
MY_VAR=42 make my-target
. Meta and dependent targets run other targets that may not respect the same variables.
Tip
Makefile autocompletion works out of the box on Zsh (the default shell for Terminal on macOS) and Fish shells. For Bash, the bash-completion
package, among others, provides Makefile autocompletion. Using autocompletion allows you, for example, to type make ac
, press tab, and the shell autocompletes make acctest-lint
.
Target | Description | CI? | Legacy? | Vars |
---|---|---|---|---|
acctest-lint M |
Run all CI acceptance test checks | ✔️ | K , PKG , SVC_DIR |
|
build D |
Build the provider | GO_VER |
||
changelog-misspell |
CHANGELOG Misspell / misspell | ✔️ | ||
ci M |
Run all CI checks | ✔️ | BASE_REF , GO_VER , K , PKG , SEMGREP_ARGS , SVC_DIR , TEST , TESTARGS |
|
ci-quick M |
Run quicker CI checks | ✔️ | BASE_REF , GO_VER , K , PKG , SEMGREP_ARGS , SVC_DIR , TEST , TESTARGS |
|
clean M |
Clean up Go cache, tidy and re-install tools | GO_VER |
||
clean-go D |
Clean up Go cache | GO_VER |
||
clean-make-tests |
Clean up artifacts from make tests | |||
clean-tidy D |
Clean up tidy | GO_VER |
||
copyright |
Copyright Checks / add headers check | ✔️ | ||
default | = build |
GO_VER |
||
deps-check D |
Dependency Checks / go_mod | ✔️ | GO_VER |
|
docs M |
Run all CI documentation checks | ✔️ | ||
docs-check |
Check provider documentation | ✔️ | ||
docs-link-check |
Documentation Checks / markdown-link-check | ✔️ | ||
docs-lint |
Lint documentation | ✔️ | ||
docs-lint-fix |
Fix documentation linter findings | ✔️ | ||
docs-markdown-lint |
Documentation Checks / markdown-lint | ✔️ | ||
docs-misspell |
Documentation Checks / misspell | ✔️ | ||
examples-tflint |
Examples Checks / tflint | ✔️ | ||
fix-constants M |
Use Semgrep to fix constants | K , PKG , PKG_NAME , SEMGREP_ARGS |
||
fix-imports |
Fixing source code imports with goimports | |||
fmt |
Fix Go source formatting | K , PKG , PKG_NAME |
||
fmt-check |
Verify Go source is formatted | CURDIR |
||
fumpt |
Run gofumpt | K , PKG , PKG_NAME |
||
gen D |
Run all Go generators | GO_VER |
||
gen-check D |
Provider Checks / go_generate | ✔️ | ||
generate-changelog |
Generate changelog | CURDIR |
||
gh-workflow-lint |
Workflow Linting / actionlint | ✔️ | ||
go-build |
Provider Checks / go-build | ✔️ | ||
go-misspell |
Provider Checks / misspell | ✔️ | ||
golangci-lint M |
All golangci-lint Checks | ✔️ | K , PKG , TEST |
|
golangci-lint1 |
golangci-lint Checks / 1 of 5 | ✔️ | K , PKG , TEST |
|
golangci-lint2 |
golangci-lint Checks / 2 of 5 | ✔️ | K , PKG , TEST |
|
golangci-lint3 |
golangci-lint Checks / 3 of 5 | ✔️ | K , PKG , TEST |
|
golangci-lint4 |
golangci-lint Checks / 4 of 5 | ✔️ | K , PKG , TEST |
|
golangci-lint5 |
golangci-lint Checks / 5 of 5 | ✔️ | K , PKG , TEST |
|
help |
Display help | |||
import-lint |
Provider Checks / import-lint | ✔️ | K , PKG , TEST |
|
install M |
= build |
GO_VER |
||
lint M |
Legacy target, use caution | ✔️ | ||
lint-fix M |
Fix acceptance test, website, and docs linter findings | ✔️ | ||
misspell M |
Run all CI misspell checks | ✔️ | ||
prereq-go |
Install the project's Go version | GO_VER |
||
provider-lint |
ProviderLint Checks / providerlint | ✔️ | K , PKG , SVC_DIR |
|
provider-markdown-lint |
Provider Check / markdown-lint | ✔️ | ||
sane D |
Run sane check | ACCTEST_PARALLELISM , ACCTEST_TIMEOUT , GO_VER , TEST_COUNT |
||
sanity D |
Run sanity check (failures allowed) | ACCTEST_PARALLELISM , ACCTEST_TIMEOUT , GO_VER , TEST_COUNT |
||
semgrep M |
Run all CI Semgrep checks | ✔️ | K , PKG , PKG_NAME , SEMGREP_ARGS |
|
semgrep-all D |
Run semgrep on all files | K , PKG , PKG_NAME , SEMGREP_ARGS |
||
semgrep-code-quality D |
Semgrep Checks / Code Quality Scan | ✔️ | K , PKG , PKG_NAME , SEMGREP_ARGS |
|
semgrep-constants D |
Fix constants with Semgrep --autofix | K , PKG , PKG_NAME , SEMGREP_ARGS |
||
semgrep-docker D |
Run Semgrep | ✔️ | ||
semgrep-fix D |
Fix Semgrep issues that have fixes | K , PKG , PKG_NAME , SEMGREP_ARGS |
||
semgrep-naming D |
Semgrep Checks / Test Configs Scan | ✔️ | K , PKG , PKG_NAME , SEMGREP_ARGS |
|
semgrep-naming-cae D |
Semgrep Checks / Naming Scan Caps/AWS /EC2 |
✔️ | K , PKG , PKG_NAME , SEMGREP_ARGS |
|
semgrep-service-naming D |
Semgrep Checks / Service Name Scan A-Z | ✔️ | K , PKG , PKG_NAME , SEMGREP_ARGS |
|
semgrep-validate |
Validate Semgrep configuration files | |||
skaff D |
Install skaff | GO_VER |
||
skaff-check-compile |
Skaff Checks / Compile skaff | ✔️ | ||
sweep D |
Run sweepers | GO_VER , SWEEP_DIR , SWEEP_TIMEOUT , SWEEP , SWEEPARGS |
||
sweeper D |
Run sweepers with failures allowed | GO_VER , SWEEP_DIR , SWEEP_TIMEOUT , SWEEP |
||
sweeper-check M |
Provider Checks / Sweeper Linked, Unlinked | ✔️ | ||
sweeper-linked |
Provider Checks / Sweeper Functions Linked | ✔️ | ||
sweeper-unlinked D |
Provider Checks / Sweeper Functions Not Linked | ✔️ | ||
t D |
Run acceptance tests (similar to testacc ) |
ACCTEST_PARALLELISM , ACCTEST_TIMEOUT , GO_VER , K , PKG , PKG_NAME , RUNARGS , TEST_COUNT , TESTARGS |
||
test D |
Run unit tests | GO_VER , K , PKG , TEST , TESTARGS |
||
test-compile D |
Test package compilation | GO_VER , K , PKG , PKG_NAME , TEST , TESTARGS |
||
testacc D |
Run acceptance tests | ACCTEST_PARALLELISM , ACCTEST_TIMEOUT , GO_VER , K , PKG , PKG_NAME , RUNARGS , TEST_COUNT , TESTARGS |
||
testacc-lint |
Acceptance Test Linting / terrafmt | ✔️ | K , PKG , SVC_DIR |
|
testacc-lint-fix |
Fix acceptance test linter findings | K , PKG , SVC_DIR |
||
testacc-short D |
Run acceptace tests with the -short flag | ACCTEST_PARALLELISM , ACCTEST_TIMEOUT , GO_VER , K , PKG , PKG_NAME , RUNARGS , TEST_COUNT , TESTARGS |
||
testacc-tflint |
Acceptance Test Linting / tflint | ✔️ | K , PKG , SVC_DIR |
|
testacc-tflint-dir |
Run tflint on Terraform acceptance test directories |
✔️ | K , PKG , SVC_DIR |
|
testacc-tflint-dir-fix |
Fix tflint issues in Terraform acceptance test directories |
✔️ | K , PKG , SVC_DIR |
|
testacc-tflint-embedded |
Run tflint on embedded Terraform configurations |
✔️ | K , PKG , SVC_DIR |
|
tfproviderdocs D |
Provider Checks / tfproviderdocs | ✔️ | ||
tfsdk2fw D |
Install tfsdk2fw | GO_VER |
||
tools D |
Install tools | GO_VER |
||
ts M |
Alias to testacc-short |
|||
website M |
Run all CI website checks | ✔️ | ||
website-link-check |
Check website links | ✔️ | ||
website-link-check-ghrc |
Check website links with ghrc | ✔️ | ||
website-link-check-markdown |
Website Checks / markdown-link-check-a-z-markdown | ✔️ | ||
website-link-check-md |
Website Checks / markdown-link-check-md | ✔️ | ||
website-lint |
Lint website files | ✔️ | ||
website-lint-fix |
Fix website linter findings | ✔️ | ||
website-markdown-lint |
Website Checks / markdown-lint | ✔️ | ||
website-misspell |
Website Checks / misspell | ✔️ | ||
website-terrafmt |
Website Checks / terrafmt | ✔️ | ||
website-tflint |
Website Checks / tflint | ✔️ | ||
yamllint |
YAML Linting / yamllint |
✔️ |