Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/no0dles/hammerkit
build tool with support for containerization, build caching for local development and ci
https://github.com/no0dles/hammerkit
build-tool ci-tools docker typescript yaml
Last synced: 25 days ago
JSON representation
build tool with support for containerization, build caching for local development and ci
- Host: GitHub
- URL: https://github.com/no0dles/hammerkit
- Owner: no0dles
- License: mit
- Created: 2021-04-05T06:16:16.000Z (almost 4 years ago)
- Default Branch: master
- Last Pushed: 2024-01-14T10:23:25.000Z (12 months ago)
- Last Synced: 2024-04-28T04:42:21.356Z (9 months ago)
- Topics: build-tool, ci-tools, docker, typescript, yaml
- Language: TypeScript
- Homepage: https://no0dles.gitbook.io/hammerkit/
- Size: 1.89 MB
- Stars: 55
- Watchers: 3
- Forks: 1
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# About
## What is hammerkit?
Hammerkit is a build tool intended to build software projects in **containers** locally and in a CI. The advantage of containerized builds are:
* the build tools used from the container image are the same across all machines.
* the build process is isolated since every file in the container has to be declared as a source or an output. Therefore side effects can be reduced.There are a lot of containerized CI systems that allow writing containerized builds today, but they lack some features hammerkit tries to solve:
* they are often not **usable during development** on your local machine, so you have either maintain two build scripts or wrap one of them in the other.
* they mount the entire repository into the container and can therefore **side effect** can reduce reliability
* some of them do not allow **switching images** during build steps. Requiring to maintain a large build image, that contains all tools needed to build to software.Additionally hammerkit tries to reduce complexity of build caching in CI systems. Usually you define a directory that is being cached and restored before and after the CI build. That's totally fine for smaller project where there are not that many directories to cache. The bigger the project gets, the more effort it is, to keep all directories up to date.
Hammerkit on the other hand knows the source and output files of each build step and can therefore compact the build results into a single directory. Making it easy to being cached. Once restored, hammerkit can detect what's changed since last time and only build the changes.
## Where to go next?
Check out the [docs](https://no0dles.gitbook.io/hammerkit/) for more info about how hammerkit can be used.