Compare commits
6 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| bd93ef2f8f | |||
| f06cb112d8 | |||
| d57f56f196 | |||
| 277c0f882d | |||
| cc7f4f0976 | |||
| 6621b3f336 |
@@ -3,7 +3,6 @@ on:
|
|||||||
push:
|
push:
|
||||||
branches:
|
branches:
|
||||||
- main
|
- main
|
||||||
- feature/helm-chart
|
|
||||||
paths:
|
paths:
|
||||||
- git-pages/**
|
- git-pages/**
|
||||||
- .gitea/workflows/helm-build-push.yml
|
- .gitea/workflows/helm-build-push.yml
|
||||||
|
|||||||
@@ -39,6 +39,12 @@ jobs:
|
|||||||
container:
|
container:
|
||||||
image: alpine/helm:3.19.0
|
image: alpine/helm:3.19.0
|
||||||
steps:
|
steps:
|
||||||
|
- name: Install Node.js for actions/checkout
|
||||||
|
# COMPROMISE: Requires internet access.
|
||||||
|
# Does NOT work in air-gapped environments.
|
||||||
|
# Replace with a custom image (e.g., extending alpine/helm + nodejs) if needed.
|
||||||
|
run: apk add --no-cache nodejs
|
||||||
|
|
||||||
- uses: actions/checkout@v4
|
- uses: actions/checkout@v4
|
||||||
- uses: actions/checkout@v4
|
- uses: actions/checkout@v4
|
||||||
with:
|
with:
|
||||||
@@ -47,6 +53,7 @@ jobs:
|
|||||||
|
|
||||||
- name: Package Helm chart
|
- name: Package Helm chart
|
||||||
run: |
|
run: |
|
||||||
|
helm dependency update "${CHART_PATH}"
|
||||||
helm package "${CHART_PATH}" \
|
helm package "${CHART_PATH}" \
|
||||||
--version "${VERSION}" \
|
--version "${VERSION}" \
|
||||||
--app-version "${VERSION}" \
|
--app-version "${VERSION}" \
|
||||||
|
|||||||
+64
-2
@@ -63,15 +63,77 @@ checkout → laske versio package.json + git-tageista → output
|
|||||||
|
|
||||||
**Trigger:** `workflow_call`
|
**Trigger:** `workflow_call`
|
||||||
|
|
||||||
**Inputs:** `env_json`, `version`
|
**Inputs:**
|
||||||
|
|
||||||
|
| Parametri | Pakollinen | Kuvaus |
|
||||||
|
|-----------|------------|--------|
|
||||||
|
| `env_json` | Kyllä | Konffi `gitea-env.conf`:stä |
|
||||||
|
| `version` | Kyllä | Version string (check-version output) |
|
||||||
|
|
||||||
|
**`env_json`-avaimet:**
|
||||||
|
|
||||||
|
| Avain | Pakollinen | Kuvaus |
|
||||||
|
|-------|------------|--------|
|
||||||
|
| `DOCKER_REGISTRY` | Kyllä | Registry (esim. `gitea.app.keskikuja.site/niko`) |
|
||||||
|
| `DOCKER_IMAGE_NAME` | Kyllä | Kuvan nimi ilman registry-polkua |
|
||||||
|
| `DOCKER_UI_URL` | Ei | Registry UI -linkki raportointia varten |
|
||||||
|
| `DOCKERFILE` | Ei | Dockerfile-polku, oletus `Dockerfile` |
|
||||||
|
| `GITEA_API_URL` | Kyllä | Gitean API-URL |
|
||||||
|
| `GIT_TAG_PREFIX` | Ei | Tag-prefix (esim. `docker/`) |
|
||||||
|
|
||||||
**Secrets:** `GITEA_TOKEN`, `DOCKER_USERNAME`, `DOCKER_PASSWORD`
|
**Secrets:** `GITEA_TOKEN`, `DOCKER_USERNAME`, `DOCKER_PASSWORD`
|
||||||
|
|
||||||
**Steppi-kaavio:**
|
**Steppi-kaavio:**
|
||||||
```
|
```
|
||||||
build-push (build + push samassa jobissa, ei levyn kautta) → tag-commit
|
build-push (build + push, labelit: commit+date) → tag-commit (git-tagin luonti)
|
||||||
```
|
```
|
||||||
|
|
||||||
|
**Huomio:** Ei käytä `container:`-direktiiviä — ajaa suoraan runnerilla,
|
||||||
|
joten `actions/checkout` toimii ilman node-asennuksia.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
### `helm-build-push.yml` — Helm chart build & push
|
||||||
|
|
||||||
|
**Trigger:** `workflow_call`
|
||||||
|
|
||||||
|
**Inputs:**
|
||||||
|
|
||||||
|
| Parametri | Pakollinen | Kuvaus |
|
||||||
|
|-----------|------------|--------|
|
||||||
|
| `env_json` | Kyllä | Konffi `gitea-env.conf`:stä |
|
||||||
|
| `version` | Kyllä | Version string (check-version output) |
|
||||||
|
| `chart_path` | Ei | Polku Chart.yaml-hakemistoon, oletus `.` |
|
||||||
|
|
||||||
|
**`env_json`-avaimet:**
|
||||||
|
|
||||||
|
| Avain | Pakollinen | Kuvaus |
|
||||||
|
|-------|------------|--------|
|
||||||
|
| `HELM_REGISTRY` | Kyllä | OCI-registry (esim. `gitea.app.keskikuja.site/niko`) |
|
||||||
|
| `HELM_UI_URL` | Ei | Registry UI -linkki raportointia varten |
|
||||||
|
| `GITEA_API_URL` | Kyllä | Gitean API-URL |
|
||||||
|
| `GIT_TAG_PREFIX` | Ei | Tag-prefix (esim. `helm/`) |
|
||||||
|
|
||||||
|
**Secrets:** `GITEA_TOKEN`, `HELM_USER`, `HELM_PASSWORD`
|
||||||
|
|
||||||
|
**Steppi-kaavio:**
|
||||||
|
```
|
||||||
|
build-push (helm package → helm push OCI) → tag-commit (git-tagin luonti)
|
||||||
|
```
|
||||||
|
|
||||||
|
**Steppien kuvaus `build-push`-jobissa:**
|
||||||
|
1. **Node.js-asennus** — `apk add --no-cache nodejs` (vaaditaan `actions/checkout`-actionia varten)
|
||||||
|
2. **Checkout** — sovellusrepo ja gitea-ci-library `.ci/`-polkuun
|
||||||
|
3. **Package** — `helm package` versiolla `$VERSION`
|
||||||
|
4. **Push OCI** — `helm push` registryyn autentikoinnilla
|
||||||
|
5. **Report status** — commit-status + UI-linkki
|
||||||
|
|
||||||
|
**Kompromissi:** Kontti `alpine/helm` ei sisällä node.js:ää, mutta
|
||||||
|
`actions/checkout@v4` on JavaScript-action ja vaatii sen. Siksi nodejs
|
||||||
|
asennetaan lennossa ennen checkouttia. Tämä vaatii internet-yhteyden
|
||||||
|
eikä toimi air gap -ympäristössä. Korvaa tarvittaessa custom-kontilla
|
||||||
|
(jossa helm + nodejs, ks. `skills/ci-container-build/SKILL.md`).
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
## Consumer-esimerkki (`example-*`)
|
## Consumer-esimerkki (`example-*`)
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ set -e
|
|||||||
RAW_VERSION=""
|
RAW_VERSION=""
|
||||||
|
|
||||||
if [ -n "${VERSION_FILE-}" ] && [ -f "${VERSION_FILE-}" ]; then
|
if [ -n "${VERSION_FILE-}" ] && [ -f "${VERSION_FILE-}" ]; then
|
||||||
RAW_VERSION=$(sed -n 's/^version:[[:space:]]*\([^[:space:]]*\).*/\1/p' "${VERSION_FILE}")
|
RAW_VERSION=$(tr -d "$(printf '\xef\xbb\xbf')" < "${VERSION_FILE}" | sed -n 's/^version:[[:space:]]*\([^[:space:]]*\).*/\1/p')
|
||||||
if [ -z "${RAW_VERSION}" ]; then
|
if [ -z "${RAW_VERSION}" ]; then
|
||||||
if echo "${VERSION_FILE}" | grep -q -E '\.json$'; then
|
if echo "${VERSION_FILE}" | grep -q -E '\.json$'; then
|
||||||
RAW_VERSION=$(jq -r '.version' "${VERSION_FILE}")
|
RAW_VERSION=$(jq -r '.version' "${VERSION_FILE}")
|
||||||
@@ -22,7 +22,7 @@ if [ -z "${RAW_VERSION}" ]; then
|
|||||||
elif [ -f pom.xml ]; then
|
elif [ -f pom.xml ]; then
|
||||||
RAW_VERSION=$(grep -oP '<version>\K[^<]+' pom.xml | head -1)
|
RAW_VERSION=$(grep -oP '<version>\K[^<]+' pom.xml | head -1)
|
||||||
elif [ -f Chart.yaml ]; then
|
elif [ -f Chart.yaml ]; then
|
||||||
RAW_VERSION=$(sed -n 's/^version:[[:space:]]*\([^[:space:]]*\).*/\1/p' Chart.yaml)
|
RAW_VERSION=$(tr -d "$(printf '\xef\xbb\xbf')" < Chart.yaml | sed -n 's/^version:[[:space:]]*\([^[:space:]]*\).*/\1/p')
|
||||||
else
|
else
|
||||||
echo "ERROR: No version source found (VERSION_FILE, VERSION, package.json, pom.xml, Chart.yaml)" >&2
|
echo "ERROR: No version source found (VERSION_FILE, VERSION, package.json, pom.xml, Chart.yaml)" >&2
|
||||||
exit 1
|
exit 1
|
||||||
|
|||||||
@@ -349,7 +349,7 @@ pitää komponentit selkeästi erillään, ja tekee repossa navigoinnista suorav
|
|||||||
|
|
||||||
| Ongelma | Ratkaisu |
|
| Ongelma | Ratkaisu |
|
||||||
|---|---|
|
|---|---|
|
||||||
| Monta komponenttia, yksi repo — mikä triggeröi? | `paths:`-filtteri: `push: { paths: ['<komponentti>/**'] }` |
|
| Monta komponenttia, yksi repo — mikä triggeröi? | `paths:`-filtteri: komponentin hakemisto + sen CI-workflow't ja conf-tiedosto |
|
||||||
| Jokaisella komponentilla oma versio | `VERSION_FILE=<komponentti>/package.json` confissa |
|
| Jokaisella komponentilla oma versio | `VERSION_FILE=<komponentti>/package.json` confissa |
|
||||||
| Git-tägit sekaisin ellei nimiavaruutta | `GIT_TAG_PREFIX=<komponentti>/` confissa → tägi `<komponentti>/1.2.3` |
|
| Git-tägit sekaisin ellei nimiavaruutta | `GIT_TAG_PREFIX=<komponentti>/` confissa → tägi `<komponentti>/1.2.3` |
|
||||||
| Eri julkaisutahdit | Riippumattomat CI-triggerit, omat versiopolut |
|
| Eri julkaisutahdit | Riippumattomat CI-triggerit, omat versiopolut |
|
||||||
@@ -378,7 +378,8 @@ on:
|
|||||||
branches:
|
branches:
|
||||||
- main
|
- main
|
||||||
paths:
|
paths:
|
||||||
- '<komponentti>/**'
|
- <komponentti>/**
|
||||||
|
- .gitea/workflows/<komponentti>.*
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
load-config:
|
load-config:
|
||||||
@@ -435,6 +436,7 @@ jos commitilla on jo tägi, pipeline skipataan `if: artifact_exists != 'true'`.
|
|||||||
- Älä aja kaikkia komponentteja samasta triggeristä — `paths:` pitää CI:t erillisinä
|
- Älä aja kaikkia komponentteja samasta triggeristä — `paths:` pitää CI:t erillisinä
|
||||||
- Älä käytä samaa versionhallintatiedostoa usealle komponentille
|
- Älä käytä samaa versionhallintatiedostoa usealle komponentille
|
||||||
- Älä anna monorepo-parametreja pipeline-overrideina — kaikki kuuluu conf-tiedostoon
|
- Älä anna monorepo-parametreja pipeline-overrideina — kaikki kuuluu conf-tiedostoon
|
||||||
|
- Älä rajaa `paths:` pelkkään komponentin hakemistoon — CI ei triggeröidy workflow- tai conf-muutoksista
|
||||||
|
|
||||||
## Versionhallinta
|
## Versionhallinta
|
||||||
|
|
||||||
|
|||||||
@@ -189,3 +189,72 @@ Ei pipeä (`|`) komennon perässä — se syö exit-koodin. Käytä redirectiä
|
|||||||
|
|
||||||
Providerin scriptit haetaan `actions/checkout`-stepillä `.ci/`-polkuun.
|
Providerin scriptit haetaan `actions/checkout`-stepillä `.ci/`-polkuun.
|
||||||
Consumer ei kopioi eikä muokkaa providerin tiedostoja.
|
Consumer ei kopioi eikä muokkaa providerin tiedostoja.
|
||||||
|
|
||||||
|
## 10. Build & Push -providerit
|
||||||
|
|
||||||
|
### `docker-build-push.yml` — Docker image build & push
|
||||||
|
|
||||||
|
Buildaa ja pushee Docker-imagen OCI-registryyn. Ajaa suoraan runnerilla
|
||||||
|
(ei `container:`-direktiiviä), joten `actions/checkout` toimii natiivisti.
|
||||||
|
|
||||||
|
**`env_json`-avaimet (pakolliset):**
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
DOCKER_REGISTRY: gitea.app.keskikuja.site/niko
|
||||||
|
DOCKER_IMAGE_NAME: my-app
|
||||||
|
```
|
||||||
|
|
||||||
|
**Käyttö reitittimessä:**
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
docker-build-push:
|
||||||
|
uses: OWNER/gitea-ci-library/.gitea/workflows/docker-build-push.yml@v1
|
||||||
|
needs: [check-version]
|
||||||
|
if: needs.check-version.outputs.artifact_exists == 'false'
|
||||||
|
secrets: inherit
|
||||||
|
with:
|
||||||
|
env_json: ${{ needs.load-config.outputs.env_json }}
|
||||||
|
version: ${{ needs.check-version.outputs.version }}
|
||||||
|
```
|
||||||
|
|
||||||
|
Tarkka input/secret-lista: `docs/workflows.md`.
|
||||||
|
|
||||||
|
### `helm-build-push.yml` — Helm chart build & push
|
||||||
|
|
||||||
|
Pakkaa ja pushee Helm-chartin OCI-registryyn. Käyttää `alpine/helm`-konttia.
|
||||||
|
|
||||||
|
**`env_json`-avaimet (pakolliset):**
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
HELM_REGISTRY: gitea.app.keskikuja.site/niko
|
||||||
|
```
|
||||||
|
|
||||||
|
**Käyttö reitittimessä:**
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
helm-build-push:
|
||||||
|
uses: OWNER/gitea-ci-library/.gitea/workflows/helm-build-push.yml@v1
|
||||||
|
needs: [check-version]
|
||||||
|
if: needs.check-version.outputs.artifact_exists == 'false'
|
||||||
|
secrets: inherit
|
||||||
|
with:
|
||||||
|
env_json: ${{ needs.load-config.outputs.env_json }}
|
||||||
|
version: ${{ needs.check-version.outputs.version }}
|
||||||
|
# chart_path: '.' # oletus, vaihda jos Chart.yaml on alihakemistossa
|
||||||
|
```
|
||||||
|
|
||||||
|
**Node.js-kompromissi:** `actions/checkout@v4` on JavaScript-action.
|
||||||
|
Kontissa `alpine/helm` ei ole node.js:ää, joten se asennetaan lennossa
|
||||||
|
`apk add --no-cache nodejs` ennen checkouttia.
|
||||||
|
|
||||||
|
- Vaatii internet-yhteyden
|
||||||
|
- Ei toimi air gap -ympäristössä
|
||||||
|
- Korvaa tarvittaessa custom-kontilla (helm + nodejs):
|
||||||
|
rakenna `ci-container-build`-skillillä ja päivitä workflow'n
|
||||||
|
`container: image:` osoittamaan omaan konttiin
|
||||||
|
|
||||||
|
**Yksittäisten Helm-UI-linkkien raportointi:** `HELM_UI_URL` on
|
||||||
|
tarkoitettu yleiselle registry UI:lle — provider muodostaa linkin
|
||||||
|
`${HELM_UI_URL}/${CHART_NAME}/${VERSION}` automaattisesti.
|
||||||
|
|
||||||
|
Tarkka input/secret-lista: `docs/workflows.md`.
|
||||||
|
|||||||
@@ -153,6 +153,21 @@ teardown() {
|
|||||||
[ "$NEXT_VERSION" = "0.3.2" ]
|
[ "$NEXT_VERSION" = "0.3.2" ]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@test "VERSION_FILE=Chart-umbrella.yaml extracts only top-level version" {
|
||||||
|
mock_set_sequence '[{"code": 200, "body": []}]'
|
||||||
|
mock_start
|
||||||
|
|
||||||
|
export VERSION_FILE="$BATS_TEST_DIRNAME/fixtures/check-version/Chart-umbrella.yaml"
|
||||||
|
run bash scripts/check-version.sh
|
||||||
|
|
||||||
|
echo "STATUS=$status"
|
||||||
|
echo "OUTPUT=$output"
|
||||||
|
[ "$status" -eq 0 ]
|
||||||
|
source /tmp/build-ctx/build.env
|
||||||
|
echo "NEXT_VERSION=$NEXT_VERSION"
|
||||||
|
[ "$NEXT_VERSION" = "0.1.0" ]
|
||||||
|
}
|
||||||
|
|
||||||
@test "no version source exits with error" {
|
@test "no version source exits with error" {
|
||||||
mock_set_sequence '[{"code": 200, "body": []}]'
|
mock_set_sequence '[{"code": 200, "body": []}]'
|
||||||
mock_start
|
mock_start
|
||||||
|
|||||||
@@ -0,0 +1,12 @@
|
|||||||
|
apiVersion: v2
|
||||||
|
name: agent-platform
|
||||||
|
description: Agent Platform umbrella chart
|
||||||
|
type: application
|
||||||
|
version: 0.1.0
|
||||||
|
dependencies:
|
||||||
|
- name: vikunja
|
||||||
|
version: "0.1.0"
|
||||||
|
repository: oci://registry.example.com
|
||||||
|
- name: langfuse
|
||||||
|
version: "0.2.0"
|
||||||
|
repository: oci://registry.example.com
|
||||||
Reference in New Issue
Block a user