Skip to content

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 if P is set.
  • ACCTEST_TIMEOUT - (Default: 360m) Timeout before acceptance tests panic.
  • BASE_REF - (Default: main) Origin reference to use for Git diff comparison, as in origin/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, use GO_VER=go.
  • K - (Default: None) Name of the service package you want to use, such as ec2, iam, or lambda, limiting Go processing to that package and dependencies. Equivalent to PKG variable. Assigns values to PKG_NAME, SVC_DIR, and TEST overridding any values set.
  • P - (Default: 20) Number of concurrent acceptance tests to run. Assigns a value to ACCTEST_PARALLELISM overridding any value set.
  • PKG - (Default: None) Name of the service package you want to use, such as ec2, iam, or lambda, limiting Go processing to that package and dependencies. Equivalent to K variable. Assigns values to PKG_NAME, SVC_DIR, and TEST overridding any values set.
  • PKG_NAME - (Default: internal) Subdirectory (Go package) to use as the basis for Go processing. Overridden if PKG or K is set.
  • RUNARGS - (Default: None) Raw arguments passed to Go when running acceptance tests. For example, RUNARGS=-run=TestMyTest. Overridden if TESTS or T 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 if PKG or K 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 to SWEEPERS. For example, SWEEPARGS=-sweep-run=aws_example_thing.
  • SWEEPERS - (Default: None) Resources to sweep, including dependencies. Similar to SWEEPARGS. For example, SWEEPERS=aws_example_thing. Assigns a value to SWEEPARGS overridding any value set.
  • T - (Default: None) Names of tests to run. Equivalent to TESTS. Assigns a value to RUNARGS overridding any value set.
  • TEST - (Default: ./...) Limit tests to this directory and dependencies. Overridden if PKG or K 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 to T. Assigns a value to RUNARGS overridding any value set.
  • TESTARGS - (Default: None) Raw arguments passed to Go when running tests. Unlike RUNARGS, this is not overridden if TESTS or T is set.

Cheat Sheet#

  • Target: Use as a subcommand to make, such as make 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-lintM Run all CI acceptance test checks ✔️ K, PKG, SVC_DIR
buildD Build the provider GO_VER
changelog-misspell CHANGELOG Misspell / misspell ✔️
ciM Run all CI checks ✔️ BASE_REF, GO_VER, K, PKG, SEMGREP_ARGS, SVC_DIR, TEST, TESTARGS
ci-quickM Run quicker CI checks ✔️ BASE_REF, GO_VER, K, PKG, SEMGREP_ARGS, SVC_DIR, TEST, TESTARGS
cleanM Clean up Go cache, tidy and re-install tools GO_VER
clean-goD Clean up Go cache GO_VER
clean-make-tests Clean up artifacts from make tests
clean-tidyD Clean up tidy GO_VER
copyright Copyright Checks / add headers check ✔️
default = build GO_VER
deps-checkD Dependency Checks / go_mod ✔️ GO_VER
docsM 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-constantsM 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
genD Run all Go generators GO_VER
gen-checkD 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-lintM 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
installM = build GO_VER
lintM Legacy target, use caution ✔️
lint-fixM Fix acceptance test, website, and docs linter findings ✔️
misspellM 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 ✔️
saneD Run sane check ACCTEST_PARALLELISM, ACCTEST_TIMEOUT, GO_VER, TEST_COUNT
sanityD Run sanity check (failures allowed) ACCTEST_PARALLELISM, ACCTEST_TIMEOUT, GO_VER, TEST_COUNT
semgrepM Run all CI Semgrep checks ✔️ K, PKG, PKG_NAME, SEMGREP_ARGS
semgrep-allD Run semgrep on all files K, PKG, PKG_NAME, SEMGREP_ARGS
semgrep-code-qualityD Semgrep Checks / Code Quality Scan ✔️ K, PKG, PKG_NAME, SEMGREP_ARGS
semgrep-constantsD Fix constants with Semgrep --autofix K, PKG, PKG_NAME, SEMGREP_ARGS
semgrep-dockerD Run Semgrep ✔️
semgrep-fixD Fix Semgrep issues that have fixes K, PKG, PKG_NAME, SEMGREP_ARGS
semgrep-namingD Semgrep Checks / Test Configs Scan ✔️ K, PKG, PKG_NAME, SEMGREP_ARGS
semgrep-naming-caeD Semgrep Checks / Naming Scan Caps/AWS/EC2 ✔️ K, PKG, PKG_NAME, SEMGREP_ARGS
semgrep-service-namingD Semgrep Checks / Service Name Scan A-Z ✔️ K, PKG, PKG_NAME, SEMGREP_ARGS
semgrep-validate Validate Semgrep configuration files
skaffD Install skaff GO_VER
skaff-check-compile Skaff Checks / Compile skaff ✔️
sweepD Run sweepers GO_VER, SWEEP_DIR, SWEEP_TIMEOUT, SWEEP, SWEEPARGS
sweeperD Run sweepers with failures allowed GO_VER, SWEEP_DIR, SWEEP_TIMEOUT, SWEEP
sweeper-checkM Provider Checks / Sweeper Linked, Unlinked ✔️
sweeper-linked Provider Checks / Sweeper Functions Linked ✔️
sweeper-unlinkedD Provider Checks / Sweeper Functions Not Linked ✔️
tD Run acceptance tests (similar to testacc) ACCTEST_PARALLELISM, ACCTEST_TIMEOUT, GO_VER, K, PKG, PKG_NAME, RUNARGS, TEST_COUNT, TESTARGS
testD Run unit tests GO_VER, K, PKG, TEST, TESTARGS
test-compileD Test package compilation GO_VER, K, PKG, PKG_NAME, TEST, TESTARGS
testaccD 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-shortD 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
tfproviderdocsD Provider Checks / tfproviderdocs ✔️
tfsdk2fwD Install tfsdk2fw GO_VER
toolsD Install tools GO_VER
tsM Alias to testacc-short
websiteM 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 ✔️