Skip to content

Cache Docker CI

Cache Docker CI #256

Workflow file for this run

name: CI
on:
push:
jobs:
python-build:
name: πŸ—οΈ Build Python wheels
strategy:
matrix:
python:
- '3.10'
runs-on: ubuntu-latest
steps:
- name: πŸ“₯ Check-out
uses: actions/checkout@v3
- name: 🧰 Install Protoc
run: sudo apt install protobuf-compiler
- name: 🧰 Install Python
uses: actions/setup-python@v4
with:
python-version: ${{ matrix.python }}
cache: pip
cache-dependency-path: pyproject.toml
- name: 🧰 Install dependencies
run: pip install build twine
- name: πŸ—οΈ Build Python wheels
run: python -m build
- name: πŸ§ͺ Check package bundles
run: twine check dist/*
- name: πŸ“€ Upload Python wheels
uses: actions/upload-artifact@v3
if: matrix.python == '3.10'
with:
name: wheels
path: dist
python-code-check:
name: πŸ” Check Python code
strategy:
matrix:
python:
- '3.10'
runs-on: ubuntu-latest
steps:
- name: πŸ“₯ Check-out
uses: actions/checkout@v3
- name: 🧰 Install Protoc
run: sudo apt install protobuf-compiler
- name: 🧰 Install Python
uses: actions/setup-python@v4
with:
python-version: ${{ matrix.python }}
cache: pip
cache-dependency-path: pyproject.toml
- name: 🧰 Install dependencies
run: pip install .[tests]
- name: πŸ” Check Python code
run: ruff .
python-typing:
name: πŸ” Check Python static typing
strategy:
matrix:
python:
- '3.10'
runs-on: ubuntu-latest
steps:
- name: πŸ“₯ Check-out
uses: actions/checkout@v3
- name: 🧰 Install Protoc
run: sudo apt install protobuf-compiler
- name: 🧰 Install Python
uses: actions/setup-python@v4
with:
python-version: ${{ matrix.python }}
cache: pip
cache-dependency-path: pyproject.toml
- name: 🧰 Install dependencies
run: pip install .[tests]
- name: πŸ” Check Python static typing
run: mypy .
python-security:
name: πŸ” Check Python code security
strategy:
matrix:
python:
- '3.10'
runs-on: ubuntu-latest
steps:
- name: πŸ“₯ Check-out
uses: actions/checkout@v3
- name: 🧰 Install Protoc
run: sudo apt install protobuf-compiler
- name: 🧰 Install Python
uses: actions/setup-python@v4
with:
python-version: ${{ matrix.python }}
cache: pip
cache-dependency-path: pyproject.toml
- name: 🧰 Install dependencies
run: pip install .[tests]
- name: πŸ” Check Python code security
run: bandit -c pyproject.toml -r .
python-test:
name: πŸ§ͺ Test Python code
strategy:
matrix:
python:
- '3.10'
runs-on: ubuntu-latest
steps:
- name: πŸ“₯ Check-out
uses: actions/checkout@v3
- name: 🧰 Install Protoc
run: sudo apt install protobuf-compiler
- name: 🧰 Install Python
uses: actions/setup-python@v4
with:
python-version: ${{ matrix.python }}
cache: pip
cache-dependency-path: pyproject.toml
- name: 🧰 Install dependencies
run: pip install .[tests]
- name: πŸ§ͺ Test Python code
run: pytest --cov --cov-report=xml archive_query_log
- name: πŸ“€ Upload coverage to Codecov
uses: codecov/codecov-action@v3
if: matrix.python == '3.10'
with:
fail_ci_if_error: true
token: ${{ secrets.CODECOV_TOKEN }}
docker-build:
name: πŸ—οΈ Build Docker image
runs-on: ubuntu-latest
steps:
- name: πŸ“₯ Check-out
uses: actions/checkout@v3
- name: 🧰 Set up QEMU
uses: docker/setup-qemu-action@v2
- name: 🧰 Set up Docker Buildx
uses: docker/setup-buildx-action@v2
- name: πŸ—οΈ Build Docker image
uses: docker/build-push-action@v4
with:
context: .
push: false
cache-from: type=gha
cache-to: type=gha,mode=max
python-publish:
name: πŸš€ Publish Python wheels
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags')
needs:
- python-build
- python-code-check
- python-typing
- python-security
- python-test
- docker-build
runs-on: ubuntu-latest
permissions:
id-token: write
steps:
- name: πŸ“₯ Check-out
uses: actions/checkout@v3
- name: πŸ“₯ Download Python wheels
uses: actions/download-artifact@v3
with:
name: wheels
path: dist
- name: πŸš€ Publish Python wheels
uses: pypa/gh-action-pypi-publish@release/v1
docker-publish:
name: πŸš€ Publish Docker image
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags')
permissions:
packages: write
needs:
- python-build
- python-code-check
- python-typing
- python-security
- python-test
- docker-build
runs-on: ubuntu-latest
steps:
- name: πŸ“₯ Check-out
uses: actions/checkout@v3
- name: 🧰 Set up QEMU
uses: docker/setup-qemu-action@v2
- name: 🧰 Set up Docker Buildx
uses: docker/setup-buildx-action@v2
- name: πŸ”‘ Login to GitHub Packages
uses: docker/login-action@v2
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: ℹ️ Extract image metadata
id: meta
uses: docker/metadata-action@v4
with:
images: |
ghcr.io/${{ github.repository }}
- name: πŸš€ Build and push image
uses: docker/build-push-action@v4
with:
context: .
push: true
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
cache-from: type=gha
cache-to: type=gha,mode=max
github-release:
name: πŸš€ Create GitHub release
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags')
needs:
- python-build
- python-code-check
- python-typing
- python-security
- python-test
- docker-build
permissions:
contents: write
runs-on: ubuntu-latest
steps:
- name: πŸ“₯ Check-out
uses: actions/checkout@v3
- name: πŸ“₯ Download Python wheels
uses: actions/download-artifact@v3
with:
name: wheels
path: dist
- name: πŸš€ Create GitHub release
uses: softprops/action-gh-release@v1
with:
name: Release ${{ github.ref_name }}
files: dist/*
fail_on_unmatched_files: true
draft: false
prerelease: false
generate_release_notes: true