Skip to content

Commit

Permalink
Resplitted workflows
Browse files Browse the repository at this point in the history
  • Loading branch information
perseoGI committed Dec 18, 2024
1 parent 9d4836e commit 70ddc5b
Show file tree
Hide file tree
Showing 7 changed files with 685 additions and 678 deletions.
50 changes: 50 additions & 0 deletions .github/actions/run-tests/action.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
name: Test code and manage coverage

inputs:
python-version:
description: "Python version to set up"
required: true

test-type:
description: "Tests type"
required: false

tests:
description: "Tests paths"
required: false

run_shell:
description: "Shell to execute in"
default: "bash"

runs:
using: "composite"
steps:
- name: Run tests
if: inputs.test-type != ""
shell: ${{ inputs.run_shell }}
run: |
pytest test/${{ inputs.test-type }} --durations=20 -n 4 --cov=conan
- name: Run tests
if: inputs.tests != ""
shell: ${{ inputs.run_shell }}
run: |
pytest ${{ inputs.tests }} --durations=20 -n 4 --cov=conan
- name: Rename coverage file (Linux/MacOS)
if: runner.os != 'Windows'
shell: bash
run: mv .coverage .coverage.${{ runner.os }}-${{ inputs.python-version }}-${{ inputs.test-type }}

- name: Rename coverage file (Windows)
if: runner.os == 'Windows'
shell: pwsh
run: powershell Rename-Item .coverage coverage-${{ runner.os }}-${{ inputs.python-version }}-${{ inputs.test-type }}.coverage

- name: Upload coverage artifact
uses: actions/upload-artifact@v4
with:
name: .coverage.${{ runner.os }}-${{ inputs.python-version }}-${{ inputs.test-type }}
path: .coverage.${{ runner.os }}-${{ inputs.python-version }}-${{ inputs.test-type }}
include-hidden-files: true
51 changes: 51 additions & 0 deletions .github/actions/setup-python/action.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
name: Configure python and run tests

inputs:
python-version:
description: "Python version to set up"
required: true

pip-cache-path:
description: "Pip cache path"
required: true

use-pyenv:
description: "Use pyenv or standard python installer"
required: false
default: false

run_shell:
description: "Shell to execute in"
default: "bash"

runs:
using: "composite"
steps:
- name: Set up Python ${{ inputs.python-version }}
if: inputs.use-pyenv == false
uses: actions/setup-python@v5
with:
python-version: ${{ inputs.python-version }}

- name: Set up Python ${{ inputs.python-version }}
if: inputs.use-pyenv == true
shell: ${{ inputs.run_shell }}
run: |
pyenv global ${{ inputs.python-version }}
python --version
- name: Cache pip dependencies
uses: actions/cache@v4
with:
path: ${{ inputs.pip-cache-path }}
key: ${{ runner.os }}-pip-${{ inputs.python-version }}-${{ hashFiles('**/requirements*.txt') }}
restore-keys: |
pip-packages-${{ runner.os }}-${{ inputs.python-version }}-
- name: Install Python dependencies
shell: ${{ inputs.run_shell }}
run: |
pip install --upgrade pip
pip install -r conans/requirements.txt -r conans/requirements_dev.txt -r conans/requirements_server.txt
pip install -r conans/requirements_runner.txt # TODO parametrize
pip install meson
141 changes: 141 additions & 0 deletions .github/workflows/linux-tests.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,141 @@
name: Linux tests

on:
workflow_call:

concurrency:
group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }}
cancel-in-progress: true

jobs:
build_container:
runs-on: ubuntu-latest
outputs:
image_tag: ${{ steps.dockerfile_hash.outputs.tag }}
steps:
- name: Checkout code
uses: actions/checkout@v4

- name: Log in to GitHub Container Registry
uses: docker/login-action@v3
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}

- name: Calculate Dockerfile checksum
id: dockerfile_hash
run: |
DOCKERFILE_HASH=$(find ./.ci/docker/conan-tests -type f -exec sha256sum {} \; | sha256sum | cut -d' ' -f1)
echo "tag=$DOCKERFILE_HASH" >> $GITHUB_OUTPUT
- name: Check if image exists
id: check_image
run: |
if docker manifest inspect ghcr.io/${{ github.repository_owner }}/conan-tests:${{ steps.dockerfile_hash.outputs.tag }} > /dev/null 2>&1; then
echo "status=exists" >> $GITHUB_OUTPUT
else
echo "status=no-image" >> $GITHUB_OUTPUT
fi
- name: Build and push image if not exists
if: steps.check_image.outputs.status == 'no-image'
run: |
docker build -t ghcr.io/${{ github.repository_owner }}/conan-tests:${{ steps.dockerfile_hash.outputs.tag }} -f ./.ci/docker/conan-tests .
docker push ghcr.io/${{ github.repository_owner }}/conan-tests:${{ steps.dockerfile_hash.outputs.tag }}
linux_tests:
needs: build_container
runs-on: ubuntu-latest
container:
image: ghcr.io/${{ github.repository_owner }}/conan-tests:${{ needs.build_container.outputs.image_tag }}
options: --user conan
strategy:
matrix:
# python-version: [3.12.3, 3.9.2, 3.8.6, 3.6.15]
# test-type: [unittests, integration, functional]
python-version: [3.12.3]
test-type: [unittests]
name: Conan ${{ matrix.test-type }} (${{ matrix.python-version }})
steps:
- name: Checkout code
uses: actions/checkout@v4

- name: Install dependencies
uses: ./.github/actions/setup-python
with:
python-version: ${{ matrix.python-version }}
pip-cache-path: ~/.cache/pip
use-pyenv: true

- name: Run tests
uses: ./.github/actions/run-tests
with:
python-version: ${{ matrix.python-version }}
test-type: ${{ matrix.test-type }}

# linux_docker_tests:
# needs: build_container
# runs-on: ubuntu-latest
# name: Docker Runner Tests
# strategy:
# matrix:
# python-version: [3.12, 3.9]
# steps:
# - name: Install dependencies and run tests
# uses: ./.github/actions/Install-and-test
# with:
# python-version: ${{ matrix.python-version }}
# test-type: ${{ matrix.test-type }}
# pip-cache-path: ~/.cache/pip
# # TODO
#
# # - name: Run tests
# # shell: bash
# # run: |
# # pytest -m docker_runner --durations=20 -rs

deploy_to_pypi_test:
# needs: [build_container, linux_test_suite, linux_docker_tests]
needs: [build_container, linux_tests]
runs-on: ubuntu-latest
if: github.ref == 'refs/heads/develop2'
name: Deploy to TestPyPI
steps:
- name: Checkout code
uses: actions/checkout@v4

- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: '3.9'

- name: Install dependencies
run: |
pip install --upgrade pip
pip install twine
- name: Bump Dev Version
run: |
python .ci/bump_dev_version.py
- name: Build Package
run: |
python setup.py sdist
- name: Upload to TestPyPI
env:
TWINE_USERNAME: ${{ secrets.TEST_PYPI_USERNAME }}
TWINE_PASSWORD: ${{ secrets.TEST_PYPI_PASSWORD }}
run: |
python -m twine upload --verbose --repository-url https://test.pypi.org/legacy/ dist/*
- name: Deploy conan-server to TestPyPI
env:
TWINE_USERNAME: ${{ secrets.TEST_PYPI_SERVER_USERNAME }}
TWINE_PASSWORD: ${{ secrets.TEST_PYPI_SERVER_PASSWORD }}
run: |
rm -rf dist/
mv setup_server.py setup.py
python setup.py sdist
python -m twine upload --verbose --repository-url https://test.pypi.org/legacy/ dist/*
42 changes: 42 additions & 0 deletions .github/workflows/main.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
name: Main Workflow
on:
push:
branches:
- develop2
- release/*
- '*'
pull_request:
branches:
- '*'
- 'release/*'
workflow_dispatch:

jobs:
linux_suite:
uses: ./.github/workflows/linux-tests.yml
name: Linux test suite
osx_suite:
uses: ./.github/workflows/osx-tests.yml
name: OSX test suite
windows_suite:
uses: ./.github/workflows/win-tests.yml
name: Windows test suite
code_coverage:
runs-on: ubuntu-latest
needs: [linux_suite, osx_suite, windows_suite]
steps:
- name: Checkout code
uses: actions/checkout@v4

- name: Download coverage artifacts
uses: actions/download-artifact@v4
with:
merge-multiple: true

- name: Merge coverage reports
run: |
pip install coverage
coverage combine
coverage report
coverage xml -o merged-coverage.xml
coverage html -d coverage-html
Loading

0 comments on commit 70ddc5b

Please sign in to comment.