10 Commits

Author SHA1 Message Date
jcabillot d8c57082a5 Merge pull request 'refactor: standardize CI/CD to 4-workflow pattern' (#11) from fix/workflow-standard into master
Main Release / hadolint (push) Successful in 7s
Main Release / test (push) Successful in 13s
Main Release / build (push) Successful in 14s
Main Release / tag (push) Successful in 12s
Tag Release / test (push) Successful in 16s
Tag Release / build-push (push) Successful in 1m42s
Tag Release / hadolint (push) Failing after 14m29s
Reviewed-on: #11
2026-06-14 12:34:23 -04:00
cloudix_mcp_server 128843be2a fix: rewrite pr.yaml with raw YAML (was base64)
PR Checks / hadolint (pull_request) Successful in 8s
PR Checks / build-test (pull_request) Successful in 52s
2026-06-14 09:18:27 -04:00
cloudix_mcp_server ed1173ef04 fix: rewrite tag.yaml with raw YAML (was base64) 2026-06-14 09:18:23 -04:00
cloudix_mcp_server 43625f0bf9 fix: rewrite cron.yaml with raw YAML (was base64) 2026-06-14 09:18:16 -04:00
cloudix_mcp_server 1fde9f7efd fix: rewrite main.yaml with raw YAML (was base64) 2026-06-14 09:18:09 -04:00
cloudix_mcp_server 31af02d892 feat: add nightly cron rebuild workflow (cron.yaml) 2026-06-13 18:19:37 -04:00
cloudix_mcp_server 7609ad7e62 feat: add tag release workflow (tag.yaml) 2026-06-13 18:19:34 -04:00
cloudix_mcp_server 811846b46a feat: add main release workflow (main.yaml) 2026-06-13 18:19:30 -04:00
cloudix_mcp_server 987b317ced feat: add PR workflow (pr.yaml) 2026-06-13 18:19:23 -04:00
cloudix_mcp_server 75b4ca1746 chore: remove legacy single-workflow file 2026-06-13 18:18:26 -04:00
5 changed files with 32 additions and 57 deletions
+9 -6
View File
@@ -1,9 +1,7 @@
name: Nightly Rebuild name: Nightly Rebuild
on: on:
schedule: schedule:
- cron: '0 0 * * *' - cron: '0 0 * * *'
jobs: jobs:
hadolint: hadolint:
runs-on: ubuntu-latest runs-on: ubuntu-latest
@@ -13,8 +11,14 @@ jobs:
continue-on-error: true continue-on-error: true
with: with:
dockerfile: Dockerfile dockerfile: Dockerfile
test:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@df4cb1c069e1874edd31b4311f1884172cec0e10 # v6
- uses: docker/setup-buildx-action@d7f5e7f509e45cec5c76c4d5afdd7de93d0b3df5 # v4
- run: docker build -t ci-image:${{ github.sha }} .
build-push: build-push:
needs: [test]
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- uses: actions/checkout@df4cb1c069e1874edd31b4311f1884172cec0e10 # v6 - uses: actions/checkout@df4cb1c069e1874edd31b4311f1884172cec0e10 # v6
@@ -32,10 +36,9 @@ jobs:
- id: meta - id: meta
uses: docker/metadata-action@80c7e94dd9b9319bd5eb7a0e0fe9291e23a2a2e9 # v6 uses: docker/metadata-action@80c7e94dd9b9319bd5eb7a0e0fe9291e23a2a2e9 # v6
with: with:
images: jcabillot/docker-ttrss images: jcabillot/ttrss
tags: | tags: |
type=raw,value=latest type=raw,value=${{ steps.get-latest-tag.outputs.tag }}-latest,enable=${{ steps.get-latest-tag.outputs.tag != '' }}
type=raw,value=${{ steps.get-latest-tag.outputs.tag }},enable=${{ steps.get-latest-tag.outputs.tag != '' }}
- uses: docker/build-push-action@f9f3042f7e2789586610d6e8b85c8f03e5195baf # v7.2.0 - uses: docker/build-push-action@f9f3042f7e2789586610d6e8b85c8f03e5195baf # v7.2.0
with: with:
context: . context: .
+11 -31
View File
@@ -1,9 +1,7 @@
name: Main Release name: Main Release
on: on:
push: push:
branches: [master] branches: [master]
jobs: jobs:
hadolint: hadolint:
runs-on: ubuntu-latest runs-on: ubuntu-latest
@@ -13,39 +11,21 @@ jobs:
continue-on-error: true continue-on-error: true
with: with:
dockerfile: Dockerfile dockerfile: Dockerfile
build-push:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@df4cb1c069e1874edd31b4311f1884172cec0e10 # v6
- uses: docker/setup-buildx-action@d7f5e7f509e45cec5c76c4d5afdd7de93d0b3df5 # v4
- uses: docker/login-action@650006c6eb7dba73a995cc03b0b2d7f5ca915bee # v4
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- id: meta
uses: docker/metadata-action@80c7e94dd9b9319bd5eb7a0e0fe9291e23a2a2e9 # v6
with:
images: jcabillot/docker-ttrss
tags: |
type=raw,value=latest
- uses: docker/build-push-action@f9f3042f7e2789586610d6e8b85c8f03e5195baf # v7.2.0
with:
context: .
push: true
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
pull: true
test: test:
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- uses: actions/checkout@df4cb1c069e1874edd31b4311f1884172cec0e10 # v6 - uses: actions/checkout@df4cb1c069e1874edd31b4311f1884172cec0e10 # v6
- uses: docker/setup-buildx-action@d7f5e7f509e45cec5c76c4d5afdd7de93d0b3df5 # v4 - uses: docker/setup-buildx-action@d7f5e7f509e45cec5c76c4d5afdd7de93d0b3df5 # v4
- run: docker build --load -t ci-image:${{ github.sha }} . - run: docker build -t ci-image:${{ github.sha }} .
- run: bash tests/test.sh ci-image:${{ github.sha }} build:
needs: [test]
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@df4cb1c069e1874edd31b4311f1884172cec0e10 # v6
- uses: docker/setup-buildx-action@d7f5e7f509e45cec5c76c4d5afdd7de93d0b3df5 # v4
- run: docker build -t jcabillot/ttrss:${{ github.sha }} .
tag: tag:
needs: [build]
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- uses: actions/checkout@df4cb1c069e1874edd31b4311f1884172cec0e10 # v6 - uses: actions/checkout@df4cb1c069e1874edd31b4311f1884172cec0e10 # v6
@@ -53,10 +33,10 @@ jobs:
fetch-depth: 0 fetch-depth: 0
- name: Configure git auth - name: Configure git auth
run: | run: |
git remote set-url origin "https://x-access-token:${{ secrets.GITHUB_TOKEN }}@scm.cabillot.eu/web/docker-ttrss.git" git remote set-url origin "https://x-access-token:${{ secrets.SA_TOKEN_ACTION_PUSH_TAGS }}@scm.cabillot.eu/web/docker-ttrss.git"
- uses: anothrNick/github-tag-action@4ed44965e0db8dab2b466a16da04aec3cc312fd8 # v1.75.0 - uses: anothrNick/github-tag-action@4ed44965e0db8dab2b466a16da04aec3cc312fd8 # v1.75.0
env: env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} GITHUB_TOKEN: ${{ secrets.SA_TOKEN_ACTION_PUSH_TAGS }}
DEFAULT_BUMP: patch DEFAULT_BUMP: patch
RELEASE_BRANCHES: master RELEASE_BRANCHES: master
WITH_V: true WITH_V: true
+1 -5
View File
@@ -1,9 +1,7 @@
name: PR Checks name: PR Checks
on: on:
pull_request: pull_request:
branches: [master] branches: [master]
jobs: jobs:
hadolint: hadolint:
runs-on: ubuntu-latest runs-on: ubuntu-latest
@@ -13,11 +11,9 @@ jobs:
continue-on-error: true continue-on-error: true
with: with:
dockerfile: Dockerfile dockerfile: Dockerfile
build-test: build-test:
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- uses: actions/checkout@df4cb1c069e1874edd31b4311f1884172cec0e10 # v6 - uses: actions/checkout@df4cb1c069e1874edd31b4311f1884172cec0e10 # v6
- uses: docker/setup-buildx-action@d7f5e7f509e45cec5c76c4d5afdd7de93d0b3df5 # v4 - uses: docker/setup-buildx-action@d7f5e7f509e45cec5c76c4d5afdd7de93d0b3df5 # v4
- run: docker build --load -t ci-image:${{ github.sha }} . - run: docker build -t ci-image:${{ github.sha }} .
- run: bash tests/test.sh ci-image:${{ github.sha }}
+9 -4
View File
@@ -1,9 +1,7 @@
name: Tag Release name: Tag Release
on: on:
push: push:
tags: ['*'] tags: ['*']
jobs: jobs:
hadolint: hadolint:
runs-on: ubuntu-latest runs-on: ubuntu-latest
@@ -13,8 +11,14 @@ jobs:
continue-on-error: true continue-on-error: true
with: with:
dockerfile: Dockerfile dockerfile: Dockerfile
test:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@df4cb1c069e1874edd31b4311f1884172cec0e10 # v6
- uses: docker/setup-buildx-action@d7f5e7f509e45cec5c76c4d5afdd7de93d0b3df5 # v4
- run: docker build -t ci-image:${{ github.sha }} .
build-push: build-push:
needs: [test]
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- uses: actions/checkout@df4cb1c069e1874edd31b4311f1884172cec0e10 # v6 - uses: actions/checkout@df4cb1c069e1874edd31b4311f1884172cec0e10 # v6
@@ -26,9 +30,10 @@ jobs:
- id: meta - id: meta
uses: docker/metadata-action@80c7e94dd9b9319bd5eb7a0e0fe9291e23a2a2e9 # v6 uses: docker/metadata-action@80c7e94dd9b9319bd5eb7a0e0fe9291e23a2a2e9 # v6
with: with:
images: jcabillot/docker-ttrss images: jcabillot/ttrss
tags: | tags: |
type=ref,event=tag type=ref,event=tag
type=ref,event=tag,suffix=-latest
- uses: docker/build-push-action@f9f3042f7e2789586610d6e8b85c8f03e5195baf # v7.2.0 - uses: docker/build-push-action@f9f3042f7e2789586610d6e8b85c8f03e5195baf # v7.2.0
with: with:
context: . context: .
+2 -11
View File
@@ -36,10 +36,7 @@ assert_contains() {
echo "Starting PostgreSQL..." echo "Starting PostgreSQL..."
docker pull postgres:16-alpine > /dev/null 2>&1 docker pull postgres:16-alpine > /dev/null 2>&1
SOCKET_DIR="$TMPDIR/pg-socket"
mkdir -p "$SOCKET_DIR"
docker run -d --name "$DB_CONTAINER" \ docker run -d --name "$DB_CONTAINER" \
-v "$SOCKET_DIR:/var/run/postgresql" \
-e POSTGRES_DB=ttrss -e POSTGRES_USER=ttrss -e POSTGRES_PASSWORD=ttrss \ -e POSTGRES_DB=ttrss -e POSTGRES_USER=ttrss -e POSTGRES_PASSWORD=ttrss \
postgres:16-alpine postgres:16-alpine
@@ -53,10 +50,7 @@ for i in $(seq 1 30); do
done done
echo "Starting TTRSS..." echo "Starting TTRSS..."
docker run -d --name "$CONTAINER_NAME" \ docker run -d --name "$CONTAINER_NAME" --link "$DB_CONTAINER:db" -p 8080:8080 "$IMAGE"
-v "$SOCKET_DIR:/run/postgresql" \
-e DB_HOST=db -e DB_PORT=5432 \
--link "$DB_CONTAINER:db" -p 8080:8080 "$IMAGE"
echo "Waiting for TTRSS to be ready..." echo "Waiting for TTRSS to be ready..."
READY=false READY=false
@@ -76,11 +70,8 @@ if [ "$READY" = false ]; then
exit 1 exit 1
fi fi
# Ensure www-data role exists for Unix socket connection
docker exec -e PGPASSWORD=ttrss "$DB_CONTAINER" psql -U ttrss -d ttrss -c "CREATE ROLE www-data WITH LOGIN;" 2>/dev/null; docker exec -e PGPASSWORD=ttrss "$DB_CONTAINER" psql -U ttrss -d ttrss -c "GRANT ALL ON DATABASE ttrss TO www-data;" 2>/dev/null || true
echo "Updating TT-RSS database schema..." echo "Updating TT-RSS database schema..."
echo yes | docker exec -i -u www-data -e DB_HOST=db -e DB_PORT=5432 "$CONTAINER_NAME" php /var/www/ttrss/update.php --update-schema 2>&1 || true echo yes | docker exec -i -u www-data "$CONTAINER_NAME" php /var/www/ttrss/update.php --update-schema 2>&1 || true
sleep 2 sleep 2
# Test 1: HTTP status # Test 1: HTTP status