-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add dedicated documentation section (#34)
- Loading branch information
Showing
4 changed files
with
200 additions
and
44 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,47 @@ | ||
# Local Development | ||
By following these steps, you will be able to build the container image for your desired architecture and generate packages using the containerized environment. This enables efficient local development, allowing you to iterate on your code, test packages, and validate changes effectively. | ||
|
||
## Build container | ||
|
||
To build the container, follow the steps below: | ||
|
||
Install `podman` on your system: https://podman.io/docs/installation | ||
|
||
Update unqualified search in `/etc/containers/registries.conf`: | ||
|
||
``` | ||
unqualified-search-registries = ["docker.io"] | ||
``` | ||
|
||
On amd64 architecture: | ||
``` | ||
podman build --build-arg arch=amd64 -f container/build.containerfile -t build:amd64 . | ||
``` | ||
|
||
On arm64 architecture: | ||
``` | ||
podman build --build-arg arch=arm64v8 -f container/build.containerfile -t build:arm64v8 . | ||
``` | ||
|
||
Note: You do not need to use `sudo` as the build should work just fine with unprivileged containers. | ||
|
||
## Build a package | ||
|
||
To build a package, perform the following steps inside the package repository: | ||
|
||
Create a .build directory: | ||
``` | ||
mkdir .build | ||
``` | ||
|
||
On amd64 architecture: | ||
``` | ||
podman run --rm -v $PWD:/input -v $PWD/.build:/output build:amd64 build | ||
``` | ||
|
||
On arm64 architecture: | ||
``` | ||
podman run --rm -v $PWD:/input -v $PWD/.build:/output build:arm64v8 build | ||
``` | ||
|
||
Alternatively, you can use pre-built containers from the GitHub Container Registry (ghcr) by accessing the following link: https://github.com/gardenlinux/package-build/pkgs/container/package-build. These pre-built containers can be used as an alternative to building the container locally. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
# Versioning | ||
|
||
This chapter describes how the versioning of Garden Linux packages work that have not been mirrored by other sources. Thereby, there are three types of version schemas used: | ||
|
||
- [Commit Hash Version](#commit-hash-version) | ||
- [First Upstream Version](#first-upstream-version) | ||
- [Git Tag Version](#git-tag-version) | ||
|
||
## Commit Hash Version | ||
**Example:** `gardenlinux/3.2.2-2gardenlinux~3618de3e65de043ca91cbf3f112eaf353a2c9c68` | ||
**Published:** `false` | ||
|
||
Whenever there is a build triggered in a given package repo that is not based on a provided Git Tag, the pipeline tries to evaluate if there was already a released build for the given upstream version of the corresponding package by checking the Git tags of the corresponding package repo. | ||
|
||
If there was already such a build, this versioning schema applies to the package build then. | ||
|
||
This way, a developer can test changes to the package repo like providing new patches for it. Once the resulting package fulfills the expectation, a developer could then tag its latest commit, so that the latest version is properly versioned and could be published to Github releases as described in chapter [Git Tag Version](#git-tag-version). | ||
|
||
Packages that are using this kind of versioning are only built but not published. In order to access those packages, the corresponding package build (Github Action) must be opened. It contains the source and binary package of the given built package in its artifact section. | ||
|
||
## First Upstream Version | ||
**Example:** `gardenlinux/3.2.2-2gardenlinux0` | ||
**Published:** `true` | ||
|
||
If the package pipeline is triggered without providing a Git Tag and it turns out that there was not already a released build for the given upstream version, then the pipeline will automatically add a Git Tag and publish the resulting package to the Github releases. Thereby, the pipeline checks the Git tags of the given package repo to determine if such a version has already been released or not. | ||
|
||
In order to provide a proper version schema, the pipeline will add the version suffix `gardenlinux0` to such packages. This way, a developer can see that the package was automatically built and updated by the packaging pipeline. | ||
|
||
This mechanism allows to automatically update Garden Linux packages whenever there is an update in the corresponding upstream version without requiring a developer to add a Git tag. This reduces the general maintenance efforts because a developer doesn't need to manually tag a package to get the latest upstream version into the Garden Linux releases. | ||
|
||
## Git Tag Version | ||
**Example:** `gardenlinux/3.2.2-2gardenlinux1`, `gardenlinux/3.2.2-2gardenlinux2`, `gardenlinux/3.2.2-2gardenlinux3`, ... | ||
**Published:** `true` | ||
|
||
If there is already a released built for the given upstream version in the Garden Linux package releases but a developer needs to provide updates to the package itself (e.g. via new patches), the developer can release such an update by tagging the last functional Git commit with the following schema: | ||
* `{UPSTREAM VERSION}gardenlinux{1|2|3|...}` | ||
|
||
As long as the developer does not tag such a package, the versioning from chapter [Commit Hash Version](#commit-hash-version) applies to the built package. Such packages are considered to be used for testing only whereas tagged versions are published to the Garden Linux package releases. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,104 @@ | ||
# Gardenlinux build-package workflows | ||
|
||
This repository contains the Gardenlinux workflows for building and deploying containers and provide a resuable workflow for other packages to build and depolying. | ||
|
||
- [Workflow](#workflows) | ||
- [Workflow Detail](#workflow-details) | ||
- [Build Container](#build-container) | ||
- [Workflow Configuration](#workflow-configuration) | ||
- [Job Details](#job-details) | ||
- [Build Package](#build-package) | ||
- [Workflow Configuration](#workflow-configuration-1) | ||
- [Job Details](#job-details-1) | ||
- [Usage](#usage) | ||
- [Contributing](#contributing) | ||
|
||
## Workflows | ||
|
||
The following workflows are defined in this repository: | ||
|
||
- `build_container.yml`: This workflow builds container images based on the provided .containererfile and pushes it to a container registry. | ||
- `build_pkg.yml`: This is reusable workflow builds a package based on the provided input configurations and pushes it to a package repository. | ||
|
||
## Workflow Details | ||
|
||
### Build Container | ||
|
||
The `build_container.yml` workflow is responsible for building container images and pushing it to a container registry. | ||
|
||
#### Workflow Configuration | ||
|
||
The `container/` folder in this project contains all it's configurations. The `build_container.yml` workflow is triggered on every push to the repository. | ||
|
||
#### Job Details | ||
|
||
The `build` job within the `build_container.yml` workflow performs the following steps: | ||
- Checks out the repository. | ||
- Sets up the binfmt using a privileged Podman container. | ||
- Builds the container images based on the provided containerfiles, considering the `host` and `target` matrix values that builds amd64:amd64, arm64v8:amd64, amd64:arm64v8 and arm64v8:arm64v8 images. | ||
- Publishes the built container images to the container registry. | ||
|
||
### Build Package | ||
|
||
The `build_pkg.yml` workflow is a reusable workflow that can be called by other packages. It builds a package based on the provided input configurations and pushes it to a package repository. | ||
|
||
#### Workflow Configuration | ||
|
||
The `build_pkg.yml` workflow can be triggered by calling it with specific input parameters. | ||
|
||
Input Parameters available in `build_pkg.yml`: | ||
| Parameter | Type | Description | | ||
| --------- | ---- | ------------| | ||
|`repository`|**Type:** string<br>**Default:** `${{ github.repository }}`| The repository to build the package from.| | ||
|`ref`|**Type:** string<br>**Default:** `${{ github.sha }}`| The ref (commit or branch) to build the package from.| | ||
|`build_container`|**Type:** string<br>**Default:** `ghcr.io/gardenlinux/package-build`| The container image used for building the package.| | ||
|`dependencies`|**Type:** string| Comma-separated list of repositories and tags to fetch dependencies from.| | ||
|`source`|**Type:** string| The source name of the package. There are three values that one can choose from:<br>- Debian Source Package: `{SOURCE PACKAGE NAME}`<br>- Git Source: `git+{GIT URL}`<br>- Native Build: `native`| | ||
|`debian_source`|**Type:** string| Defines from which source the `debian/` directory should be used. There are three values that one can choose from:<br>- Debian Source Package: `{SOURCE PACKAGE NAME}`<br>- Git Source: `git+{GIT URL}`<br>- Native Build: `native`| | ||
|`email`|**Type:** string<br>**Default:** `[email protected]`| The Debian package maintainer email.| | ||
|`maintainer`|**Type:** string<br>**Default:** `Garden Linux Builder`| The Debian package maintainer full name.| | ||
|`distribution`|**Type:** string<br>**Default:** `gardenlinux`| The target distribution for the package.| | ||
|`message`|**Type:** string<br>**Default:** `Rebuild for Garden Linux.`| The changelog entry message for the package build.| | ||
|`build_option`|**Type:** string| Additional build options for the package build. Build option `terse` is always set.| | ||
|`build_profiles`|**Type:** string| Additional build profiles for the package build.| | ||
|
||
|
||
#### Job Details | ||
|
||
The `build_pkg.yml` workflow consists of the following jobs: | ||
- `source`: This job retrieves the source package, sets up the build environment, and builds the source package. | ||
- `packages`: This job builds the binary packages for the specified architecture. | ||
- `publish`: This job publishes the drafted release. | ||
- `cleanup`: This job deletes the drafted release in case of failure. | ||
|
||
#### Usage | ||
|
||
To use the `build_pkg.yml` workflow defined in this repository, follow these steps: | ||
|
||
1. Create a new workflow file (e.g., `build.yaml`) in the `.github/workflows/` folder of your package-project. | ||
2. In the new workflow file, include the following content, eg: htop: | ||
|
||
``` | ||
name: project | ||
on: push | ||
jobs: | ||
htop: | ||
uses: gardenlinux/package-build/.github/workflows/build_pkg.yml@branchname | ||
``` | ||
Replace `project` to other package name of your package-project. Replace `branchname` with the specific branch or tag of the build_pkg.yaml workflow you want to use. The default is `main` branch. | ||
|
||
3. Call the gardenlinux/package-build/.github/workflows/build_pkg.yml@branchname workflow with the specific input parameters under `with:` specific to your project. such as `email`, `maintainer`, `distribution`, `message` and others mentioned in the Workflow Configuration section. The default values will be use if wihout provide any input parameters. | ||
``` | ||
uses: gardenlinux/package-build/.github/workflows/build_pkg.yml@branchname | ||
with: | ||
email: your@address | ||
maintainer: "Your Name" | ||
``` | ||
4. Commit and push the new workflow file to your project's repository. | ||
5. The `build_pkg.yml` workflow will be triggered based on the provided inputs. | ||
|
||
> Note: Make sure to adjust and use the matches branch name on your package-project in the uses field to match the desired branch name of the `build_pkg.yaml@branchname`` workflow. | ||
## Contributing | ||
|
||
Contributions to this repository are welcome. If you encounter any issues or have suggestions for improvements, please open an issue or submit a pull request. |