. #7
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: CI | |
on: | |
push: | |
pull_request: | |
workflow_dispatch: | |
concurrency: | |
group: ci-${{ github.ref }} | |
cancel-in-progress: true | |
jobs: | |
hadolint: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v5 | |
- name: Lint Dockerfile | |
run: docker run --rm -i hadolint/hadolint < Dockerfile | |
ruby: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v5 | |
- uses: ruby/setup-ruby@v1 | |
with: | |
ruby-version-file: ".tool-versions" | |
bundler-cache: true | |
- name: Run RuboCop | |
run: bundle exec rubocop -F | |
- name: Verify Yard documentation | |
run: bundle exec yard doc --fail-on-warning --no-output | |
- name: Run RSpec | |
run: bundle exec rspec | |
- name: Upload coverage report | |
uses: actions/upload-artifact@v4 | |
if: always() | |
with: | |
name: coverage-report | |
path: coverage/ | |
retention-days: 30 | |
frontend: | |
runs-on: ubuntu-latest | |
defaults: | |
run: | |
working-directory: frontend | |
steps: | |
- uses: actions/checkout@v5 | |
- name: Setup Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version-file: ".tool-versions" | |
cache: npm | |
cache-dependency-path: frontend/package-lock.json | |
- name: Install dependencies | |
run: npm ci | |
- name: Check formatting | |
run: npm run format:check | |
- name: Audit dependencies | |
run: npm audit --audit-level=moderate | |
- name: Run frontend tests | |
run: npm run test:ci | |
- name: Build frontend | |
run: npm run build | |
docker-test: | |
if: github.event_name == 'push' | |
needs: | |
- hadolint | |
- ruby | |
- frontend | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v5 | |
- uses: ruby/setup-ruby@v1 | |
with: | |
ruby-version-file: ".tool-versions" | |
bundler-cache: true | |
- name: Setup Node.js for Docker smoke test | |
uses: actions/setup-node@v4 | |
with: | |
node-version-file: ".tool-versions" | |
cache: npm | |
cache-dependency-path: frontend/package-lock.json | |
- name: Install frontend dependencies | |
run: npm ci | |
working-directory: frontend | |
- name: Build frontend | |
run: npm run build | |
working-directory: frontend | |
- name: Run Docker smoke test | |
run: bundle exec rake | |
docker-publish: | |
if: github.event_name == 'push' && github.ref == 'refs/heads/master' | |
needs: | |
- docker-test | |
runs-on: ubuntu-latest | |
permissions: | |
contents: read | |
packages: write | |
env: | |
IMAGE_NAME: gilcreator/html2rss-web | |
TAG_SHA: ${{ github.sha }} | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v5 | |
- name: Setup Node.js for Docker build | |
uses: actions/setup-node@v4 | |
with: | |
node-version-file: ".tool-versions" | |
cache: npm | |
cache-dependency-path: frontend/package-lock.json | |
- name: Install frontend dependencies | |
run: npm ci | |
working-directory: frontend | |
- name: Build frontend | |
run: npm run build | |
working-directory: frontend | |
- name: Set up QEMU | |
uses: docker/setup-qemu-action@v3 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v3 | |
- name: Get Git commit timestamps | |
run: echo "TIMESTAMP=$(git log -1 --pretty=%ct)" >> $GITHUB_ENV | |
- name: Extract metadata | |
id: meta | |
uses: docker/metadata-action@v5 | |
with: | |
images: ${{ env.IMAGE_NAME }} | |
- name: Log in to DockerHub | |
uses: docker/login-action@v3 | |
with: | |
username: ${{ secrets.DOCKER_USERNAME }} | |
password: ${{ secrets.DOCKER_PASSWORD }} | |
- name: Cache Docker layers | |
uses: actions/cache@v4 | |
with: | |
path: /tmp/.buildx-cache | |
key: ${{ runner.os }}-buildx-${{ github.sha }} | |
restore-keys: | | |
${{ runner.os }}-buildx- | |
- name: Build and push Docker image | |
uses: docker/build-push-action@v6 | |
env: | |
SOURCE_DATE_EPOCH: ${{ env.TIMESTAMP }} | |
with: | |
context: . | |
push: true | |
tags: | | |
gilcreator/html2rss-web:latest | |
gilcreator/html2rss-web:${{ github.sha }} | |
${{ steps.meta.outputs.tags }} | |
platforms: linux/amd64,linux/arm64 | |
cache-from: type=local,src=/tmp/.buildx-cache | |
cache-to: type=local,dest=/tmp/.buildx-cache-new | |
provenance: true | |
sbom: true | |
labels: | | |
org.opencontainers.image.source=https://github.com/${{ github.repository }} | |
org.opencontainers.image.created=${{ github.event.head_commit.timestamp }} | |
org.opencontainers.image.revision=${{ github.sha }} | |
org.opencontainers.image.title=html2rss-web | |
org.opencontainers.image.description=Generates RSS feeds of any website & serves to the web! | |
org.opencontainers.image.sbom=https://github.com/${{ github.repository }}/actions/runs/${{ github.run_id }}/artifacts | |
- name: Move updated cache into place | |
run: | | |
rm -rf /tmp/.buildx-cache | |
mv /tmp/.buildx-cache-new /tmp/.buildx-cache |