Skip to content

Latest commit

 

History

History
67 lines (46 loc) · 3.51 KB

README.md

File metadata and controls

67 lines (46 loc) · 3.51 KB

Build Harness

Inspired by: https://github.com/cloudposse/build-harness

This is a collection of Makefiles to facilitate building One Concern projects. It contains a collection of reusable make targets that can be composed together.

Goal: encapsulate logic around common software tasks using make in a way that can be versioned and easily composed with repo-specific build logic.

  • The same targets can and should be used in both local dev and in CI
  • Provide reasonable defaults but allow extension of standard targets
  • Design for composition so that targets can be easily composed together

Usage

At the top of your Makefile, include the harness:

-include $(shell curl -sSL -o .build-harness "https://raw.githubusercontent.com/oneconcern/build-harness/main/Makefile.harness"; echo .build-harness)

Add the initialized build harness to your .gitignore:

.build-harness
build-harness

Initialization

The Makefile.harness file only includes a basic set of targets to facilitate downloading/installing the full harness. To leverage the full set of targets, you may either automatically initialize the harness or manually initialize it and include the targets you want.

Automatic Initialization: To automatically initialize the harness, export the env variable BUILD_HARNESS_AUTO_INIT=true before running any targets in your Makefile. This will automatically download and install the full harness, and make all of its targets available to your Makefile.

Manual Initialization: you can manually initialize the harness by running make init in your project directory. This will download and install the full harness to a top-level harness directory, after which you can choose which targets to include in your Makefile.

Design

  • Namespace targets with / as delimiter. E.g. docker/build:
  • Use -include to break up Makefiles by responsibility and compose groups of commands together
  • Keep targets small. For more complex tasks, write shell scripts and call those from targets
  • Separate repo, releases, and versioning for harness. Download/include it in each project’s main Makefile

The master set of makefiles exposes targets for specific tools, and it is up to the Makefile in each repo to compose the applicable targets appropriately.

Recommended Targets

While each repo may have its own specific targets, there are a few common targets that are recommended for all repos. Note that these targets are specifically NOT included in the harness, as they are intended to be customized for each repo.

  • All: build and deploy the entire program from scratch
  • Install: install any needed tools/packages for working in the repo
  • Uninstall: completely remove this application
  • Clean: remove all build artifacts (aka dist/ directory, built Docker images, etc…)
  • Check: run all checks on a built artifact before ‘installation’. Linting, formatting, unit tests, etc...
  • Test: run all unit tests
    • Integration: only integration tests
    • Performance: only performance tests
    • Load: only load tests
    • Stress: only stress tests
  • Lint: runs the same linting checks that are run in CI
  • Build: build all application assets
  • Deps: install all project dependencies (i.e. from Poetry)
    • Dev: install all project dependencies AND dev dependencies

CI/CD

  • Build small custom images that can perform each responsibility in a separate step?
  • At the least, create a base harness Docker image that already has all the major deps installed so that CI doesn’t have to install them each time