Terraform Developer Experience

🌱

8 June 2021


Recently we have been working more and more to increase the adoption of our shared Terraform modules across the client teams. Doing that we noticed a nice little pattern: Within the source of a module foo we include two more modules: roles/provisioning and policy_documents/provisioning.

Given they are nested, these are not automatically run as part of the main module. Teams are intended to instantiate these modules in their roles entrypoint to create the necessary IAM roles that can provision the foo module.

This pattern allows us to advocate for smaller roles while maintaining the ease of use.