d5a8444739
- pr.yaml: PR checks (hadolint + build-test) on PRs to main - main.yaml: lint → test → build → auto-tag on push to main - tag.yaml: lint → test → build-push with tag-based Docker metadata - cron.yaml: nightly rebuild (0 0 * * *) with latest semver tag Adapted from perso/htpasswd template with: - Image: jcabillot/docker-duplicacy - Git URL: scm.cabillot.eu/perso/docker-duplicacy.git - RELEASE_BRANCHES: main - Cron schedule: '0 0 * * *' (from original cron.yaml) - Secret: GITHUB_TOKEN (existing)
54 lines
1.8 KiB
YAML
54 lines
1.8 KiB
YAML
name: Nightly Rebuild
|
|
|
|
on:
|
|
schedule:
|
|
- cron: '0 0 * * *'
|
|
|
|
jobs:
|
|
hadolint:
|
|
runs-on: ubuntu-latest
|
|
continue-on-error: true
|
|
steps:
|
|
- uses: actions/checkout@df4cb1c069e1874edd31b4311f1884172cec0e10 # v6
|
|
- uses: hadolint/hadolint-action@2332a7b74a6de0da2e2221d575162eba76ba5e5 # v3.3.0
|
|
with:
|
|
dockerfile: Dockerfile
|
|
|
|
test:
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- uses: actions/checkout@df4cb1c069e1874edd31b4311f1884172cec0e10 # v6
|
|
- uses: docker/setup-buildx-action@d7f5e7f509e45cec5cecb5e8c5e9d93d0b3df5 # v4
|
|
- run: docker build -t ci-image:${{ github.sha }} .
|
|
- run: bash tests/test.sh ci-image:${{ github.sha }}
|
|
|
|
build-push:
|
|
needs: [test]
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- uses: actions/checkout@df4cb1c069e1874edd31b4311f1884172cec0e10 # v6
|
|
with:
|
|
fetch-depth: 0
|
|
- uses: docker/setup-buildx-action@d7f5e7f509e45cec5cecb5e8c5e9d93d0b3df5 # v4
|
|
- uses: docker/login-action@650006c6eb7dba73a99bccb3a05b00c5915beef # v4
|
|
with:
|
|
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
|
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
|
- id: get-latest-tag
|
|
run: |
|
|
TAG=$(git describe --tags --abbrev=0 2>/dev/null || echo "")
|
|
echo "tag=$TAG" >> $GITHUB_OUTPUT
|
|
- id: meta
|
|
uses: docker/metadata-action@80c7e94dd9b9319bdbe2fce5c64a5e2a2a2ea9 # v6
|
|
with:
|
|
images: jcabillot/docker-duplicacy
|
|
tags: |
|
|
type=raw,value=${{ steps.get-latest-tag.outputs.tag }}-latest,enable=${{ steps.get-latest-tag.outputs.tag != '' }}
|
|
- uses: docker/build-push-action@f9f3042f7e2789586a6e3e7f7a7c90f36b5baf # v7.2.0
|
|
with:
|
|
context: .
|
|
push: true
|
|
tags: ${{ steps.meta.outputs.tags }}
|
|
labels: ${{ steps.meta.outputs.labels }}
|
|
pull: true
|