Scaffolding for new Terraform module projects
-
main.tf
,variables.tf
,outputs.tf
files to module root path -
.editorconfig
,.gitignore
,.gitattributes
and.terraform-version
files to module root path -
Option to choose test frameworks
-
test
directory with an example test based on test framework selection -
.pre-commit-config.yaml
forterraform fmt
,terraform-docs
,check-merge-conflict
and (go fmt
,golint
) /rubocop
-
example
directory with module usage tf files
- terraform
pro tip: use tfenv
- terraform-docs
- pre-commit
- For tests
-
Install nodejs
pro tip: use nvm
-
Install Yeoman
npm install -g yo
- Install this generator
npm install -g generator-tf-module
To use the included generator execute the below command in shell and provide your new module name for the prompt
> yo tf-module
...
? Enter name for the new terraform module : example-module
? Enter description for the new terraform module : A new terraform module
? Enter author name : sudokar
? Choose test framework (Use arrow keys)
❯ Terratest
kitchen-terraform
Project layout generated for the new module with Terratest selection
example-module
├── .editorconfig
├── .gitattributes
├── .gitignore
├── .pre-commit-config.yaml
├── .terraform-version
├── README.md
├── main.tf
├── outputs.tf
├── variables.tf
├── example
│ ├── main.tf
│ ├── outputs.tf
│ └── variables.tf
├── test
└── example_test.go
Project layout generated for the new module with kitchen-terraform selection
example-module
├── .editorconfig
├── .gitattributes
├── .gitignore
├── .pre-commit-config.yaml
├── .terraform-version
├── .ruby-version
├── .kitchen.yml
├── Gemfile
├── README.md
├── main.tf
├── outputs.tf
├── variables.tf
├── example
│ ├── main.tf
│ ├── outputs.tf
│ └── variables.tf
├── test
└── integration
└── default
└── example_spec.rb
Step 1
On the generated module's root path, Initialize git repository
git init
Step 2
On the generated module's root path, Install pre-commit hooks
pre-commit install
Step 3 (Applicable only for terratest
)
For golang tests, get below libs
> go get github.com/gruntwork-io/terratest/modules/terraform
> go get github.com/stretchr/testify/assert
To support maintenance of this project, Buy Me a Coffee
Found a bug? feel free to raise an issue.
Pull requests are always welcome. Keen to review and merge asap.
This project is maintained by sudokar
MIT