28 Commits

Author SHA1 Message Date
jcabillot 562eb2c36f Merge pull request 'feat(ci): refactor pipelines — hadolint, PR checks, tag releases, nightly rebuild' (#10) from fix/refactor-ci-pipelines into master
Main Branch / lint (push) Successful in 8s
Main Branch / build (push) Successful in 16s
Main Branch / test (push) Successful in 13s
Main Branch / push (push) Successful in 57s
Reviewed-on: #10
2026-06-12 16:16:41 -04:00
cloudix_mcp_server dadef5f5af fix(ci): correct actions/checkout and docker/login-action SHAs
PR Checks / lint (pull_request) Successful in 7s
PR Checks / build (pull_request) Successful in 5s
PR Checks / test (pull_request) Successful in 11s
2026-06-12 15:36:03 -04:00
cloudix_mcp_server bbee1e557c fix(ci): correct actions/checkout and docker/login-action SHAs
PR Checks / test (pull_request) Successful in 10s
PR Checks / lint (pull_request) Successful in 13s
PR Checks / build (pull_request) Successful in 6s
2026-06-12 15:35:52 -04:00
cloudix_mcp_server 4e4b35b6b1 fix(ci): correct actions/checkout, docker/login-action, and github-tag-action SHAs 2026-06-12 15:35:48 -04:00
cloudix_mcp_server 2fe73e8cc8 fix(ci): correct actions/checkout SHA to valid v4 ref
PR Checks / lint (pull_request) Successful in 15s
PR Checks / build (pull_request) Successful in 8s
PR Checks / test (pull_request) Successful in 11s
2026-06-12 15:35:42 -04:00
cloudix_mcp_server 682ed23ac9 chore(ci): remove old monolithic docker-build.yaml in favor of split workflows
PR Checks / lint (pull_request) Failing after 9s
PR Checks / build (pull_request) Has been skipped
PR Checks / test (pull_request) Has been skipped
2026-06-12 15:32:40 -04:00
cloudix_mcp_server 980dea8082 feat(ci): add nightly rebuild workflow with cron schedule 2026-06-12 15:32:36 -04:00
cloudix_mcp_server 8a1c7eae7e feat(ci): add tag release workflow for versioned Docker pushes 2026-06-12 15:32:33 -04:00
cloudix_mcp_server 80213da94f feat(ci): add main branch workflow with lint, build, test, push 2026-06-12 15:32:30 -04:00
cloudix_mcp_server 977c9bd85a feat(ci): add PR checks workflow with hadolint, build, and test 2026-06-12 15:32:20 -04:00
jcabillot f3bb4e5c6c Merge pull request 'ci: add automatic semver tagging on merge to master' (#9) from feat/semver-tag-action into master
Docker Build and Push / lint (push) Successful in 7s
Docker Build and Push / build (push) Successful in 16s
Docker Build and Push / test (push) Successful in 18s
Docker Build and Push / push (push) Failing after 30s
Reviewed-on: #9
2026-06-12 13:45:05 -04:00
cloudix_mcp_server 730240ef8b ci: add automatic semver tagging on merge to master
Docker Build and Push / lint (pull_request) Successful in 6s
Docker Build and Push / build (pull_request) Successful in 21s
Docker Build and Push / test (pull_request) Successful in 15s
Docker Build and Push / push (pull_request) Has been skipped
2026-06-12 13:13:56 -04:00
jcabillot 71f3766454 Merge pull request 'chore(deps): update hadolint/hadolint-action action to v3.3.0' (#8) from renovate/hadolint-hadolint-action-3.x into master
Docker Build and Push / lint (push) Successful in 7s
Docker Build and Push / build (push) Successful in 16s
Docker Build and Push / test (push) Successful in 14s
Docker Build and Push / push (push) Successful in 18s
Reviewed-on: #8
2026-06-12 07:47:22 -04:00
renovate e4837a316b chore(deps): update hadolint/hadolint-action action to v3.3.0
Docker Build and Push / lint (pull_request) Successful in 6s
Docker Build and Push / build (pull_request) Successful in 26s
Docker Build and Push / test (pull_request) Successful in 19s
Docker Build and Push / push (pull_request) Has been skipped
2026-06-12 01:17:12 +00:00
jcabillot e7f7ec7597 Merge pull request 'fix: add version comments to Gitea Actions workflow' (#7) from fix/action-version-comments into master
Docker Build and Push / lint (push) Successful in 8s
Docker Build and Push / build (push) Successful in 13s
Docker Build and Push / test (push) Successful in 31s
Docker Build and Push / push (push) Successful in 17s
Reviewed-on: #7
2026-06-11 21:13:43 -04:00
cloudix_mcp_server 5b55f972ae fix: add version comments to Gitea Actions workflow
Docker Build and Push / lint (pull_request) Successful in 6s
Docker Build and Push / build (pull_request) Successful in 25s
Docker Build and Push / test (pull_request) Successful in 14s
Docker Build and Push / push (pull_request) Has been skipped
2026-06-11 19:05:30 -04:00
cloudix_mcp_server 5933d76192 Merge pull request 'chore(deps): update alpine docker tag to v3.24' (#6) from renovate/alpine-3.x into master
Docker Build and Push / lint (push) Successful in 6s
Docker Build and Push / build (push) Successful in 20s
Docker Build and Push / test (push) Successful in 16s
Docker Build and Push / push (push) Successful in 24s
2026-06-10 19:17:28 -04:00
renovate f592d86f79 chore(deps): update alpine docker tag to v3.24
Docker Build and Push / lint (pull_request) Successful in 6s
Docker Build and Push / build (pull_request) Successful in 13s
Docker Build and Push / test (pull_request) Successful in 12s
Docker Build and Push / push (pull_request) Has been skipped
2026-06-09 20:54:00 +00:00
cloudix_mcp_server 477a2aca41 fix: add branches: [master] filter on push trigger
Docker Build and Push / lint (push) Failing after 11m53s
Docker Build and Push / build (push) Has been skipped
Docker Build and Push / test (push) Has been skipped
Docker Build and Push / push (push) Has been skipped
2026-06-09 10:48:13 -04:00
jcabillot 4aa5863648 Merge pull request 'chore: improve renovate dependency detection' (#4) from chore/renovate into master
Docker Build and Push / lint (push) Successful in 11s
Docker Build and Push / build (push) Successful in 11s
Docker Build and Push / test (push) Successful in 14s
Docker Build and Push / push (push) Successful in 16s
Reviewed-on: #4
2026-06-09 08:38:15 -04:00
Sagent 040c110a07 chore: improve renovate dependency detection
Docker Build and Push / lint (push) Successful in 8s
Docker Build and Push / build (push) Successful in 12s
Docker Build and Push / lint (pull_request) Successful in 6s
Docker Build and Push / test (push) Successful in 15s
Docker Build and Push / build (pull_request) Successful in 26s
Docker Build and Push / push (push) Successful in 34s
Docker Build and Push / test (pull_request) Successful in 14s
Docker Build and Push / push (pull_request) Has been skipped
2026-06-09 02:12:45 +00:00
jcabillot 92815bba00 Merge pull request 'ci: migrate to 4-job pipeline with SHA-pinned actions' (#3) from feat/gitea-actions-v2 into master
Docker Build and Push / lint (push) Successful in 10s
Docker Build and Push / build (push) Successful in 18s
Docker Build and Push / test (push) Successful in 15s
Docker Build and Push / push (push) Failing after 11m29s
Reviewed-on: https://scm.cloudix.cabillot.eu/perso/crond/pulls/3
2026-06-08 20:25:00 -04:00
Sagent d1c751ee31 fix: handle unset crond_line (nounset crash) and improve test diagnostics
Docker Build and Push / lint (push) Successful in 8s
Docker Build and Push / lint (pull_request) Successful in 6s
Docker Build and Push / build (pull_request) Successful in 12s
Docker Build and Push / build (push) Successful in 17s
Docker Build and Push / test (pull_request) Successful in 15s
Docker Build and Push / test (push) Successful in 15s
Docker Build and Push / push (pull_request) Has been skipped
Docker Build and Push / push (push) Successful in 17s
2026-06-08 23:10:54 +00:00
cloudix_mcp_server 9fb7bcae49 fix: remove quotes from HEALTHCHECK interval (hadolint)
Docker Build and Push / lint (push) Successful in 8s
Docker Build and Push / lint (pull_request) Successful in 8s
Docker Build and Push / build (push) Successful in 16s
Docker Build and Push / build (pull_request) Successful in 16s
Docker Build and Push / test (push) Failing after 12s
Docker Build and Push / push (push) Has been skipped
Docker Build and Push / test (pull_request) Failing after 11s
Docker Build and Push / push (pull_request) Has been skipped
2026-06-08 19:06:58 -04:00
cloudix_mcp_server b6b4d56300 fix: add hadolint ignore DL3018 for apk add
Docker Build and Push / lint (push) Failing after 8s
Docker Build and Push / lint (pull_request) Failing after 5s
Docker Build and Push / build (push) Has been skipped
Docker Build and Push / test (push) Has been skipped
Docker Build and Push / build (pull_request) Has been skipped
Docker Build and Push / test (pull_request) Has been skipped
Docker Build and Push / push (push) Has been skipped
Docker Build and Push / push (pull_request) Has been skipped
2026-06-08 19:02:39 -04:00
cloudix_mcp_server 618aadeb1e ci: add daemon smoke test for crond
Docker Build and Push / lint (push) Failing after 7s
Docker Build and Push / build (push) Has been skipped
Docker Build and Push / test (push) Has been skipped
Docker Build and Push / push (push) Has been skipped
Docker Build and Push / lint (pull_request) Failing after 5s
Docker Build and Push / build (pull_request) Has been skipped
Docker Build and Push / test (pull_request) Has been skipped
Docker Build and Push / push (pull_request) Has been skipped
2026-06-08 18:57:55 -04:00
cloudix_mcp_server a5e88e3c5b ci: migrate to 4-job pipeline (lint/build/test/push)
Docker Build and Push / lint (push) Failing after 6s
Docker Build and Push / build (push) Has been skipped
Docker Build and Push / test (push) Has been skipped
Docker Build and Push / push (push) Has been skipped
2026-06-08 18:57:25 -04:00
jcabillot 2d9ab14d0a feat: add Gitea Actions workflow
Docker Build and Push / build (push) Successful in 32s
feat: add Gitea Actions workflow
2026-05-29 16:22:18 -04:00
9 changed files with 286 additions and 53 deletions
+60
View File
@@ -0,0 +1,60 @@
name: Nightly Rebuild
on:
schedule:
- cron: '0 0 * * *'
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@34e114876b0b11c390a56381ad16ebd13914f8d5 # v4
- name: Build image
run: docker build -t ci-image:${{ github.sha }} .
- name: Save image
run: docker save ci-image:${{ github.sha }} > image.tar
- name: Upload artifact
uses: ChristopherHX/gitea-upload-artifact@62ac910c5d3dfa85c7cb2df15afe2e342b2407c2 # main
with:
name: docker-image
path: image.tar
test:
runs-on: ubuntu-latest
needs: build
steps:
- name: Checkout
uses: actions/checkout@34e114876b0b11c390a56381ad16ebd13914f8d5 # v4
- name: Download artifact
uses: ChristopherHX/gitea-download-artifact@75635f32b4c1c41c4b3d64e8f85210112ed4c9c7 # main
with:
name: docker-image
- name: Load image
run: docker load < image.tar
- name: Run tests
run: bash tests/test.sh ci-image:${{ github.sha }}
push:
runs-on: ubuntu-latest
needs: test
steps:
- name: Checkout
uses: actions/checkout@34e114876b0b11c390a56381ad16ebd13914f8d5 # v4
with:
fetch-depth: 0
- name: Download artifact
uses: ChristopherHX/gitea-download-artifact@75635f32b4c1c41c4b3d64e8f85210112ed4c9c7 # main
with:
name: docker-image
- name: Load image
run: docker load < image.tar
- name: Login to Docker Hub
uses: docker/login-action@c94ce9fb468520275223c153574b00df6fe4bcc9 # v3
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Tag and push latest
run: |
docker tag ci-image:${{ github.sha }} jcabillot/crond:latest
docker push jcabillot/crond:latest
-46
View File
@@ -1,46 +0,0 @@
name: Docker Build and Push
on:
pull_request:
branches: [master]
push:
branches: [master]
schedule:
- cron: '0 0 * * *'
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v6
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v4
- name: Login to Docker Hub
if: github.event_name != 'pull_request'
uses: docker/login-action@v4
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Docker metadata
id: meta
uses: docker/metadata-action@v6
with:
images: jcabillot/crond
tags: |
#type=ref,event=branch
#type=ref,event=pr
#type=sha
type=raw,value=latest,enable=${{ github.ref == 'refs/heads/master' }}
- name: Build and push
uses: docker/build-push-action@v7
with:
context: .
push: ${{ github.event_name != 'pull_request' }}
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
pull: true
+80
View File
@@ -0,0 +1,80 @@
name: Main Branch
on:
push:
branches: [master]
jobs:
lint:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@34e114876b0b11c390a56381ad16ebd13914f8d5 # v4
- name: Hadolint
uses: hadolint/hadolint-action@2332a7b74a6de0dda2e2221d575162eba76ba5e5 # v3.3.0
continue-on-error: true
build:
runs-on: ubuntu-latest
needs: lint
steps:
- name: Checkout
uses: actions/checkout@34e114876b0b11c390a56381ad16ebd13914f8d5 # v4
- name: Build image
run: docker build -t ci-image:${{ github.sha }} .
- name: Save image
run: docker save ci-image:${{ github.sha }} > image.tar
- name: Upload artifact
uses: ChristopherHX/gitea-upload-artifact@62ac910c5d3dfa85c7cb2df15afe2e342b2407c2 # main
with:
name: docker-image
path: image.tar
test:
runs-on: ubuntu-latest
needs: build
steps:
- name: Checkout
uses: actions/checkout@34e114876b0b11c390a56381ad16ebd13914f8d5 # v4
- name: Download artifact
uses: ChristopherHX/gitea-download-artifact@75635f32b4c1c41c4b3d64e8f85210112ed4c9c7 # main
with:
name: docker-image
- name: Load image
run: docker load < image.tar
- name: Run tests
run: bash tests/test.sh ci-image:${{ github.sha }}
push:
runs-on: ubuntu-latest
needs: test
if: github.event_name != 'pull_request'
steps:
- name: Checkout
uses: actions/checkout@34e114876b0b11c390a56381ad16ebd13914f8d5 # v4
with:
fetch-depth: 0
- name: Download artifact
uses: ChristopherHX/gitea-download-artifact@75635f32b4c1c41c4b3d64e8f85210112ed4c9c7 # main
with:
name: docker-image
- name: Load image
run: docker load < image.tar
- name: Login to Docker Hub
uses: docker/login-action@c94ce9fb468520275223c153574b00df6fe4bcc9 # v3
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Tag and push latest
run: |
docker tag ci-image:${{ github.sha }} jcabillot/crond:latest
docker push jcabillot/crond:latest
- name: Bump version and push tag
if: github.event_name == 'push'
uses: anothrNick/github-tag-action@4ed44965e0db8dab2b466a16da04aec3cc312fd8 # v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
DEFAULT_BUMP: patch
RELEASE_BRANCHES: master
WITH_V: true
GIT_API_TAGGING: false
+34
View File
@@ -0,0 +1,34 @@
name: PR Checks
on:
pull_request:
jobs:
lint:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@34e114876b0b11c390a56381ad16ebd13914f8d5 # v4
- name: Hadolint
uses: hadolint/hadolint-action@2332a7b74a6de0dda2e2221d575162eba76ba5e5 # v3.3.0
continue-on-error: true
build:
runs-on: ubuntu-latest
needs: lint
steps:
- name: Checkout
uses: actions/checkout@34e114876b0b11c390a56381ad16ebd13914f8d5 # v4
- name: Build image
run: docker build -t ci-image:${{ github.sha }} .
test:
runs-on: ubuntu-latest
needs: build
steps:
- name: Checkout
uses: actions/checkout@34e114876b0b11c390a56381ad16ebd13914f8d5 # v4
- name: Build image
run: docker build -t ci-image:${{ github.sha }} .
- name: Run tests
run: bash tests/test.sh ci-image:${{ github.sha }}
+65
View File
@@ -0,0 +1,65 @@
name: Tag Release
on:
push:
tags:
- 'v*'
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@34e114876b0b11c390a56381ad16ebd13914f8d5 # v4
- name: Build image
run: docker build -t ci-image:${{ github.sha }} .
- name: Save image
run: docker save ci-image:${{ github.sha }} > image.tar
- name: Upload artifact
uses: ChristopherHX/gitea-upload-artifact@62ac910c5d3dfa85c7cb2df15afe2e342b2407c2 # main
with:
name: docker-image
path: image.tar
test:
runs-on: ubuntu-latest
needs: build
steps:
- name: Checkout
uses: actions/checkout@34e114876b0b11c390a56381ad16ebd13914f8d5 # v4
- name: Download artifact
uses: ChristopherHX/gitea-download-artifact@75635f32b4c1c41c4b3d64e8f85210112ed4c9c7 # main
with:
name: docker-image
- name: Load image
run: docker load < image.tar
- name: Run tests
run: bash tests/test.sh ci-image:${{ github.sha }}
push:
runs-on: ubuntu-latest
needs: test
steps:
- name: Checkout
uses: actions/checkout@34e114876b0b11c390a56381ad16ebd13914f8d5 # v4
with:
fetch-depth: 0
- name: Download artifact
uses: ChristopherHX/gitea-download-artifact@75635f32b4c1c41c4b3d64e8f85210112ed4c9c7 # main
with:
name: docker-image
- name: Load image
run: docker load < image.tar
- name: Login to Docker Hub
uses: docker/login-action@c94ce9fb468520275223c153574b00df6fe4bcc9 # v3
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Extract tag name
run: echo "TAG=${GITHUB_REF#refs/tags/}" >> $GITHUB_ENV
- name: Tag and push with version
run: |
docker tag ci-image:${{ github.sha }} jcabillot/crond:${{ env.TAG }}
docker tag ci-image:${{ github.sha }} jcabillot/crond:latest
docker push jcabillot/crond:${{ env.TAG }}
docker push jcabillot/crond:latest
+6 -6
View File
@@ -1,16 +1,16 @@
FROM "alpine:3.23" FROM alpine:3.24
LABEL maintainer="Julien Cabillot <dockerimages@cabillot.eu>" LABEL maintainer="Julien Cabillot <dockerimages@cabillot.eu>"
# Ce projet tourne en root, mais je ne voit pas encore comment l'en empecher. # Ce projet tourne en root, mais je ne vois pas encore comment l'en empecher.
# Par défaut cron doit pouvoir changer de user pour lire chaque crontab. # Par défaut cron doit pouvoir changer de user pour lire chaque crontab.
# En forcant un user comme guest, même avec un shell cela ne fonctionne pas. # En forçant un user comme guest, même avec un shell cela ne fonctionne pas.
# hadolint ignore=DL3018
RUN apk add --no-cache tini curl RUN apk add --no-cache tini curl
COPY "run.sh" "/" COPY "run.sh" "/"
#ENTRYPOINT [ "/sbin/tini", "--" ] #ENTRYPOINT [ "/sbin/tini", "--" ]
CMD [ "/run.sh" ] CMD [ "/run.sh" ]
HEALTHCHECK --interval=10s \
HEALTHCHECK --interval="10s" \ CMD pgrep crond || exit 1
CMD pgrep crond || exit 1
+6
View File
@@ -0,0 +1,6 @@
{
"$schema": "https://docs.renovatebot.com/renovate-schema.json",
"gitlabci": {
"enabled": false
}
}
+1 -1
View File
@@ -2,5 +2,5 @@
set -o pipefail -o nounset -o errexit set -o pipefail -o nounset -o errexit
echo "${crond_line}" > "/etc/crontabs/root" echo "${crond_line:-}" > "/etc/crontabs/root"
crond -f -L /dev/stdout crond -f -L /dev/stdout
+34
View File
@@ -0,0 +1,34 @@
#!/bin/bash
set -euo pipefail
IMAGE="$1"
FAILED=0
PASSED=0
TMPDIR="$(mktemp -d)"
trap 'rm -rf "$TMPDIR"' EXIT
CONTAINER_NAME="test-crond-$$"
# Test 1: Container starts and crond is running
docker run -d --name "$CONTAINER_NAME" "$IMAGE"
sleep 4
if [ "$(docker inspect "$CONTAINER_NAME" --format='{{.State.Running}}')" != "true" ]; then
echo "FAIL: container exited prematurely"
echo "=== Container logs ==="
docker logs "$CONTAINER_NAME" 2>&1 || true
FAILED=$((FAILED + 1))
elif docker exec "$CONTAINER_NAME" pgrep crond > /dev/null 2>&1; then
echo "PASS: crond is running"
PASSED=$((PASSED + 1))
else
echo "FAIL: crond is not running"
FAILED=$((FAILED + 1))
fi
docker rm -f "$CONTAINER_NAME" > /dev/null 2>&1 || true
echo ""
echo "$PASSED/$((PASSED + FAILED)) tests passed"
if [ "$FAILED" -gt 0 ]; then
exit 1
fi