debug 2
parent
255d4c23cc
commit
6ec9a4eff7
@ -1,11 +0,0 @@
|
|||||||
# To get started with Dependabot version updates, you'll need to specify which
|
|
||||||
# package ecosystems to update and where the package manifests are located.
|
|
||||||
# Please see the documentation for all configuration options:
|
|
||||||
# https://docs.github.com/github/administering-a-repository/configuration-options-for-dependency-updates
|
|
||||||
|
|
||||||
version: 2
|
|
||||||
updates:
|
|
||||||
- package-ecosystem: "pip" # See documentation for possible values
|
|
||||||
directory: "/" # Location of package manifests
|
|
||||||
schedule:
|
|
||||||
interval: "weekly"
|
|
@ -1,76 +0,0 @@
|
|||||||
name: tests
|
|
||||||
|
|
||||||
# https://docs.github.com/de/actions/using-workflows/workflow-syntax-for-github-actions
|
|
||||||
# https://docs.github.com/en/actions/using-workflows
|
|
||||||
# https://docs.github.com/en/actions/learn-github-actions/contexts
|
|
||||||
# https://docs.github.com/en/actions/learn-github-actions/expressions
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
paths-ignore:
|
|
||||||
- 'docs/**'
|
|
||||||
- '**.md'
|
|
||||||
# pull_request:
|
|
||||||
schedule:
|
|
||||||
# Run daily on default branch
|
|
||||||
- cron: '37 3 * * *'
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
|
|
||||||
strategy:
|
|
||||||
matrix:
|
|
||||||
python-version: ["3.12", "3.11", "3.10", "3.9", "3.8"]
|
|
||||||
platform: [ubuntu-latest, macos-latest, windows-latest]
|
|
||||||
# exclude:
|
|
||||||
|
|
||||||
runs-on: ${{ matrix.platform }}
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3
|
|
||||||
- name: Set up Python ${{ matrix.python-version }}
|
|
||||||
uses: actions/setup-python@v4
|
|
||||||
with:
|
|
||||||
python-version: ${{ matrix.python-version }}
|
|
||||||
check-latest: ${{ github.event_name == 'schedule' }}
|
|
||||||
- name: Install zbar shared lib for QReader (Linux)
|
|
||||||
if: runner.os == 'Linux'
|
|
||||||
run: |
|
|
||||||
sudo apt-get install -y libzbar0
|
|
||||||
- name: Install zbar shared lib for QReader (macOS)
|
|
||||||
if: runner.os == 'macOS'
|
|
||||||
run: |
|
|
||||||
brew install zbar
|
|
||||||
- name: Install dependencies
|
|
||||||
run: |
|
|
||||||
python -m pip install --upgrade pip
|
|
||||||
pip install -U -r requirements-dev.txt
|
|
||||||
pip install -U .
|
|
||||||
- name: Lint with flake8
|
|
||||||
run: |
|
|
||||||
# stop the build if there are Python syntax errors or undefined names
|
|
||||||
flake8 . --count --select=E9,F63,F7,F82 --show-source --statistics
|
|
||||||
# exit-zero treats all errors as warnings. The GitHub editor is 127 chars wide
|
|
||||||
flake8 . --count --exit-zero --max-complexity=10 --max-line-length=200 --statistics
|
|
||||||
if: matrix.python-version != '3.7'
|
|
||||||
- name: Type checking with mypy
|
|
||||||
run: |
|
|
||||||
mypy --install-types --non-interactive src/*.py tests/*.py
|
|
||||||
mypy --strict src/*.py tests/*.py
|
|
||||||
if: matrix.python-version == '3.x' && matrix.platform == 'ubuntu-latest'
|
|
||||||
- name: Test with pytest
|
|
||||||
run: pytest
|
|
||||||
if: (matrix.python-version != '3.x' || matrix.platform != 'ubuntu-latest') && (matrix.python-version != '3.10' && matrix.platform != 'macos-latest')
|
|
||||||
- name: Test with pytest (with code coverage)
|
|
||||||
run: pytest --cov=extract_otp_secrets_test --junitxml=pytest.xml --cov-report=term-missing | tee pytest-coverage.txt
|
|
||||||
if: matrix.python-version == '3.x' && matrix.platform == 'ubuntu-latest'
|
|
||||||
# https://github.com/marketplace/actions/pytest-coverage-comment
|
|
||||||
- name: Pytest coverage comment
|
|
||||||
uses: MishaKav/pytest-coverage-comment@main
|
|
||||||
with:
|
|
||||||
pytest-coverage-path: ./pytest-coverage.txt
|
|
||||||
junitxml-path: ./pytest.xml
|
|
||||||
if: |
|
|
||||||
false && matrix.python-version == '3.x' && matrix.platform == 'ubuntu-latest'
|
|
||||||
&& !contains(github.ref, 'refs/tags/')
|
|
||||||
|
|
@ -1,259 +0,0 @@
|
|||||||
name: docker
|
|
||||||
|
|
||||||
# https://docs.github.com/de/actions/using-workflows/workflow-syntax-for-github-actions
|
|
||||||
# https://docs.github.com/en/actions/using-workflows
|
|
||||||
# https://docs.github.com/en/actions/learn-github-actions/contexts
|
|
||||||
# https://docs.github.com/en/actions/learn-github-actions/expressions
|
|
||||||
|
|
||||||
# How to setup: https://event-driven.io/en/how_to_buid_and_push_docker_image_with_github_actions/
|
|
||||||
# How to run: https://aschmelyun.com/blog/using-docker-run-inside-of-github-actions/
|
|
||||||
|
|
||||||
on:
|
|
||||||
# run it on push to the default repository branch
|
|
||||||
push:
|
|
||||||
paths-ignore:
|
|
||||||
- 'docs/**'
|
|
||||||
- '**.md'
|
|
||||||
tags-ignore:
|
|
||||||
- '**'
|
|
||||||
# branches is needed if tags-ignore is used
|
|
||||||
branches:
|
|
||||||
- '**'
|
|
||||||
schedule:
|
|
||||||
# Run weekly on default branch
|
|
||||||
- cron: '47 3 * * 6'
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build-and-push-docker-debian-image:
|
|
||||||
name: Build Docker Bookworm image and push to repositories
|
|
||||||
# run only when code is compiling and tests are passing
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
# steps to perform in job
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v3
|
|
||||||
|
|
||||||
# avoid building if there are testing errors
|
|
||||||
- name: Run smoke test
|
|
||||||
run: |
|
|
||||||
sudo apt-get install -y libzbar0
|
|
||||||
python -m pip install --upgrade pip
|
|
||||||
pip install -U -r requirements-dev.txt
|
|
||||||
pip install -U .
|
|
||||||
pytest
|
|
||||||
|
|
||||||
- name: Set up QEMU
|
|
||||||
uses: docker/setup-qemu-action@v2
|
|
||||||
|
|
||||||
# setup Docker build action
|
|
||||||
- name: Set up Docker Buildx
|
|
||||||
id: buildx
|
|
||||||
uses: docker/setup-buildx-action@v2
|
|
||||||
# Workaround for failing builds: https://github.com/docker/build-push-action/issues/761#issuecomment-1383822381
|
|
||||||
# TODO remove workaround when fixed
|
|
||||||
with:
|
|
||||||
driver-opts: |
|
|
||||||
image=moby/buildkit:v0.10.6
|
|
||||||
|
|
||||||
- name: Login to DockerHub
|
|
||||||
uses: docker/login-action@v2
|
|
||||||
if: github.secret_source == 'Actions'
|
|
||||||
with:
|
|
||||||
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
|
||||||
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
|
||||||
|
|
||||||
- name: Login to Github Packages
|
|
||||||
uses: docker/login-action@v2
|
|
||||||
if: github.secret_source == 'Actions'
|
|
||||||
with:
|
|
||||||
registry: ghcr.io
|
|
||||||
username: ${{ github.actor }}
|
|
||||||
password: ${{ secrets.GHCR_IO_TOKEN }}
|
|
||||||
|
|
||||||
- name: "Build image and push to Docker Hub and GitHub Container Registry"
|
|
||||||
id: docker_build_qr_reader_latest
|
|
||||||
uses: docker/build-push-action@v3
|
|
||||||
with:
|
|
||||||
platforms: linux/amd64,linux/arm64
|
|
||||||
# relative path to the place where source code with Dockerfile is located
|
|
||||||
# TODO file:, move to docker/
|
|
||||||
context: .
|
|
||||||
file: docker/Dockerfile
|
|
||||||
# builder: ${{ steps.buildx.outputs.name }}
|
|
||||||
# Note: tags has to be all lower-case
|
|
||||||
build-args: |
|
|
||||||
BASE_IMAGE=python:3.12-slim-bookworm
|
|
||||||
pull: true
|
|
||||||
tags: |
|
|
||||||
scit0/extract_otp_secrets:latest
|
|
||||||
scit0/extract_otp_secrets:bookworm
|
|
||||||
ghcr.io/scito/extract_otp_secrets:latest
|
|
||||||
ghcr.io/scito/extract_otp_secrets:bookworm
|
|
||||||
# build on feature branches, push only on master branch
|
|
||||||
push: ${{ github.ref == 'refs/heads/master' && github.secret_source == 'Actions'}}
|
|
||||||
|
|
||||||
- name: Image digest
|
|
||||||
# TODO upload digests to assets
|
|
||||||
run: |
|
|
||||||
echo "extract_otp_secrets digests: ${{ steps.docker_build_qr_reader_latest.outputs.digest }}"
|
|
||||||
echo "${{ steps.docker_build_qr_reader_latest.outputs.digest }}" > digests.txt
|
|
||||||
- name: Save docker digests as artifacts
|
|
||||||
if: github.ref == 'refs/heads/master'
|
|
||||||
uses: actions/upload-artifact@v4
|
|
||||||
with:
|
|
||||||
name: debian_digests
|
|
||||||
path: digests.txt
|
|
||||||
|
|
||||||
build-and-push-docker-alpine-image:
|
|
||||||
name: Build Docker Alpine image and push to repositories
|
|
||||||
# run only when code is compiling and tests are passing
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
# steps to perform in job
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v3
|
|
||||||
|
|
||||||
# avoid building if there are testing errors
|
|
||||||
- name: Run smoke test
|
|
||||||
run: |
|
|
||||||
sudo apt-get install -y libzbar0
|
|
||||||
python -m pip install --upgrade pip
|
|
||||||
pip install -U -r requirements-dev.txt
|
|
||||||
pip install -U .
|
|
||||||
pytest
|
|
||||||
|
|
||||||
- name: Set up QEMU
|
|
||||||
uses: docker/setup-qemu-action@v2
|
|
||||||
|
|
||||||
# setup Docker build action
|
|
||||||
- name: Set up Docker Buildx
|
|
||||||
id: buildx
|
|
||||||
uses: docker/setup-buildx-action@v2
|
|
||||||
|
|
||||||
- name: Login to DockerHub
|
|
||||||
uses: docker/login-action@v2
|
|
||||||
if: github.secret_source == 'Actions'
|
|
||||||
with:
|
|
||||||
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
|
||||||
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
|
||||||
|
|
||||||
- name: Login to Github Packages
|
|
||||||
uses: docker/login-action@v2
|
|
||||||
if: github.secret_source == 'Actions'
|
|
||||||
with:
|
|
||||||
registry: ghcr.io
|
|
||||||
username: ${{ github.actor }}
|
|
||||||
password: ${{ secrets.GHCR_IO_TOKEN }}
|
|
||||||
|
|
||||||
- name: "only_txt: Build image and push to Docker Hub and GitHub Container Registry"
|
|
||||||
id: docker_build_only_txt
|
|
||||||
uses: docker/build-push-action@v3
|
|
||||||
with:
|
|
||||||
# relative path to the place where source code with Dockerfile is located
|
|
||||||
platforms: linux/amd64,linux/arm64
|
|
||||||
context: .
|
|
||||||
file: docker/Dockerfile_only_txt
|
|
||||||
# builder: ${{ steps.buildx.outputs.name }}
|
|
||||||
# Note: tags has to be all lower-case
|
|
||||||
pull: true
|
|
||||||
tags: |
|
|
||||||
scit0/extract_otp_secrets:only-txt
|
|
||||||
scit0/extract_otp_secrets:alpine
|
|
||||||
ghcr.io/scito/extract_otp_secrets:only-txt
|
|
||||||
ghcr.io/scito/extract_otp_secrets:alpine
|
|
||||||
# build on feature branches, push only on master branch
|
|
||||||
push: ${{ github.ref == 'refs/heads/master' && github.secret_source == 'Actions'}}
|
|
||||||
build-args: |
|
|
||||||
RUN_TESTS=true
|
|
||||||
|
|
||||||
- name: Image digest
|
|
||||||
# TODO upload digests to assets
|
|
||||||
run: |
|
|
||||||
echo "extract_otp_secrets:only-txt digests: ${{ steps.docker_build_only_txt.outputs.digest }}"
|
|
||||||
echo "${{ steps.docker_build_qr_reader_latest.outputs.digest }}" > digests.txt
|
|
||||||
|
|
||||||
- name: Save docker digests as artifacts
|
|
||||||
if: github.ref == 'refs/heads/master'
|
|
||||||
uses: actions/upload-artifact@v4
|
|
||||||
with:
|
|
||||||
name: alpine_digests
|
|
||||||
path: digests.txt
|
|
||||||
|
|
||||||
build-and-push-docker-bullseye-image:
|
|
||||||
name: Build Docker Bullseye image (for PyInstsaller) and push to repositories
|
|
||||||
# run only when code is compiling and tests are passing
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
# steps to perform in job
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v3
|
|
||||||
|
|
||||||
# avoid building if there are testing errors
|
|
||||||
- name: Run smoke test
|
|
||||||
run: |
|
|
||||||
sudo apt-get install -y libzbar0
|
|
||||||
python -m pip install --upgrade pip
|
|
||||||
pip install -U -r requirements-dev.txt
|
|
||||||
pip install -U .
|
|
||||||
pytest
|
|
||||||
|
|
||||||
- name: Set up QEMU
|
|
||||||
uses: docker/setup-qemu-action@v2
|
|
||||||
|
|
||||||
# setup Docker build action
|
|
||||||
- name: Set up Docker Buildx
|
|
||||||
id: buildx
|
|
||||||
uses: docker/setup-buildx-action@v2
|
|
||||||
# Workaround for failing builds: https://github.com/docker/build-push-action/issues/761#issuecomment-1383822381
|
|
||||||
# TODO remove workaround when fixed
|
|
||||||
with:
|
|
||||||
driver-opts: |
|
|
||||||
image=moby/buildkit:v0.10.6
|
|
||||||
|
|
||||||
- name: Login to DockerHub
|
|
||||||
uses: docker/login-action@v2
|
|
||||||
if: github.secret_source == 'Actions'
|
|
||||||
with:
|
|
||||||
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
|
||||||
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
|
||||||
|
|
||||||
- name: Login to Github Packages
|
|
||||||
uses: docker/login-action@v2
|
|
||||||
if: github.secret_source == 'Actions'
|
|
||||||
with:
|
|
||||||
registry: ghcr.io
|
|
||||||
username: ${{ github.actor }}
|
|
||||||
password: ${{ secrets.GHCR_IO_TOKEN }}
|
|
||||||
|
|
||||||
- name: "Build image from Bullseye and push to GitHub Container Registry"
|
|
||||||
id: docker_build_bullseye
|
|
||||||
if: github.ref == 'refs/heads/master'
|
|
||||||
uses: docker/build-push-action@v3
|
|
||||||
with:
|
|
||||||
platforms: linux/amd64,linux/arm64
|
|
||||||
# relative path to the place where source code with Dockerfile is located
|
|
||||||
context: .
|
|
||||||
file: docker/Dockerfile
|
|
||||||
# builder: ${{ steps.buildx.outputs.name }}
|
|
||||||
build-args: |
|
|
||||||
BASE_IMAGE=python:3.12-slim-bullseye
|
|
||||||
# Note: tags has to be all lower-case
|
|
||||||
pull: true
|
|
||||||
tags: |
|
|
||||||
scit0/extract_otp_secrets:bullseye
|
|
||||||
push: ${{ github.secret_source == 'Actions' }}
|
|
||||||
|
|
||||||
- name: Image digest
|
|
||||||
# TODO upload digests to assets
|
|
||||||
run: |
|
|
||||||
echo "extract_otp_secrets digests: ${{ steps.docker_build_qr_reader_latest.outputs.digest }}"
|
|
||||||
echo "${{ steps.docker_build_qr_reader_latest.outputs.digest }}" > digests.txt
|
|
||||||
- name: Save docker digests as artifacts
|
|
||||||
if: github.ref == 'refs/heads/master'
|
|
||||||
uses: actions/upload-artifact@v4
|
|
||||||
with:
|
|
||||||
name: bullseye_digests
|
|
||||||
path: digests.txt
|
|
Loading…
Reference in New Issue