From a2d43fbf4f67a3678765d55d6f044f3ebb942b2b Mon Sep 17 00:00:00 2001 From: Loren Yu Date: Wed, 8 Jan 2025 16:54:57 -0800 Subject: [PATCH 1/2] Add template release management documentation (#825) --- template-only-docs/release-management.md | 13 +++++++++++++ 1 file changed, 13 insertions(+) create mode 100644 template-only-docs/release-management.md diff --git a/template-only-docs/release-management.md b/template-only-docs/release-management.md new file mode 100644 index 00000000..693086a1 --- /dev/null +++ b/template-only-docs/release-management.md @@ -0,0 +1,13 @@ +# Template release management + +1. Every week look at the commits that have been merged to `main` and decide if we want to create a new infra template release +2. Choose a version number based on the changes that have been merged. + 1. If there are changes that are not backwards compatible, usually flagged with a ⚠️ icon, increase the major version number (or minor version number while we are still on 0.*.* releases). + 2. If there are significant new features, increase the minor version number. + 3. If there are only bug fixes, tech debt, DevEx improvements, or other minor changes, increase the patch version number. +3. Generate release notes +4. Adjust release notes as needed: + 1. Add a summary at the top of the release notes highlighting the most important changes, and call out any breaking changes. + 2. Add a table of the infrastructure layers that have been updated. This table should inform project teams which layers they need to run `make infra-update-*` for. + 3. Organize the commit messages into sections, adding a section for each layer that has been updated. + 4. Reword commit messages to be more user-friendly to users of the Platform who have less context of the Platform internals From ed61139f5307d6e6970deae12ae0318aa6f4945b Mon Sep 17 00:00:00 2001 From: Loren Yu Date: Wed, 8 Jan 2025 16:55:14 -0800 Subject: [PATCH 2/2] Add template technical design principles (#824) --- .../template-technical-design-principles.md | 48 +++++++++++++++++++ 1 file changed, 48 insertions(+) create mode 100644 template-only-docs/template-technical-design-principles.md diff --git a/template-only-docs/template-technical-design-principles.md b/template-only-docs/template-technical-design-principles.md new file mode 100644 index 00000000..6cf9b5f2 --- /dev/null +++ b/template-only-docs/template-technical-design-principles.md @@ -0,0 +1,48 @@ +# Template technical design principles + +This document outlines the technical design principles that the template-infra project follows. These principles guide the development of the infrastructure template. + +## Design for simplicity + +### Design for the common case + +- Optimize for the common case +- Avoid adding unnecessary flexibility that increases complexity +- Ensure that uncommon cases can be addressed through explicit customization + +### Foster developer understanding and ownership + +- Ensure the infrastructure is transparent and comprehensible to project teams. +- Encourage developers to understand the inner workings of the infrastructure so they are equipped to extend or customize it as needed. + +### Maintain a level of complexity comparable to what project teams would manage if building the functionality themselves + +- Avoid adding complexity to the project that arises from the fact that the code came from a template +- Avoid adding complexity to the project that arises from the need to support multiple use cases + +### Establish strong conventions and sensible defaults + +- Use conventions to eliminate unnecessary decision-making and prevent bikeshedding. For example, require a `Makefile` with a `release-build` target in all applications rather than allow project teams to decide what command to use for building the container. +- Adopt sensible defaults to minimize configuration overhead. For example, hardcode values (e.g., healthcheck timeout and interval) where flexibility is unnecessary. + +### Minimize the surface area of interfaces + +- Design interfaces with the minimum number of inputs required to meet the needs of most teams. For example, minimize the number of variables to Terraform modules and the number of inputs to GitHub Actions workflows. +- Provide default values to inputs when possible. + +## Prefer configuration files over template variables + +The infra template supports configuration through the following mechanisms: + +- Configurations in project-config and app-config Terraform modules +- Template variables stored in answers files in the `.template-infra` directory + +In general, prefer configuration behavior through the static project-config and app-config modules. + +Use template variables only when defining configuration for things that cannot access Terraform state. Examples include: + +- Defining the name of an application when adding an application to the project. This cannot be hardcoded (e.g. to `app`) for multi-application projects. +- Defining the local port to use when running the application locally during local development. This is used by docker-compose.yml and cannot be hardcoded since a multi-application project cannot run multiple applications on the same port. +- Toggling GitHub Actions workflows on and off based on whether the project team has finished setting up their application's dev environment. While GitHub Actions workflows can access project-config and app-config within the workflow, project-config and app-config cannot be used to disable a workflow trigger entirely. It would be possible to add an extra calling workflow that can first check the project-config and app-config and then call the actual workflow, but this would add unnecessary complexity and violate the principle of maintaining a level of complexity comparable to what project teams would manage if building the functionality themselves. + +Examples of template variables include `app_name`, which is used to name the application folder, and `app_local_port`, which defines the port to be used when running the application locally during local development.