Compare commits
4 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| bd93ef2f8f | |||
| f06cb112d8 | |||
| d57f56f196 | |||
| 277c0f882d |
@@ -3,7 +3,6 @@ on:
|
|||||||
push:
|
push:
|
||||||
branches:
|
branches:
|
||||||
- main
|
- main
|
||||||
- fix/helm-build-node
|
|
||||||
paths:
|
paths:
|
||||||
- git-pages/**
|
- git-pages/**
|
||||||
- .gitea/workflows/helm-build-push.yml
|
- .gitea/workflows/helm-build-push.yml
|
||||||
|
|||||||
@@ -53,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}" \
|
||||||
|
|||||||
@@ -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
|
||||||
|
|
||||||
|
|||||||
@@ -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