Skip to content

Commit

Permalink
Trying fo fix cpp-linux-arm64 job.
Browse files Browse the repository at this point in the history
It seems that cleaning the Conan cache is effective.
I have added it as a preventive measure to the cpp-tests/actions.yaml.
This will only be of some effect for the self-hosted runners.
But, since the self-hosted runners use containers that cache Conan packages from previous runs,
and that can cause different type of problems,
it looks like a sensible setup step to perform.

Enabled all the jobs.
  • Loading branch information
rturrado committed Dec 19, 2023
1 parent 8eabbac commit 0522005
Show file tree
Hide file tree
Showing 3 changed files with 170 additions and 172 deletions.
4 changes: 4 additions & 0 deletions .github/actions/cpp-tests/action.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -19,9 +19,13 @@ runs:
shell: ${{ inputs.shell }}
- name: Get latest CMake
uses: lukka/get-cmake@latest
# We clean the Conan cache as a preventive measure for our runs in self-hosted runners
# Self-hosted runners use containers that cache Conan packages from previous runs,
# and that can cause different type of problems
- name: Configure and build
run: |
conan profile detect --force
conan remove -c "*/*"
conan_profile=${{ inputs.conan_profile }}
lowercase_conan_profile=$(echo ${conan_profile} | tr '[:upper:]' '[:lower:]')
conan build . -pr=conan/profiles/${lowercase_conan_profile} -b missing
Expand Down
3 changes: 2 additions & 1 deletion .github/workflows/assets.yml
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,7 @@ jobs:
echo "${conan_installation_folder}" >> $GITHUB_PATH
- name: Build wheel
run: |
conan remove -c "*/*"
/opt/python/${{ matrix.cpython_version }}/bin/python setup.py bdist_wheel
/opt/python/${{ matrix.cpython_version }}/bin/python -m auditwheel repair pybuild/dist/*.whl
- name: Wheel path
Expand Down Expand Up @@ -158,7 +159,7 @@ jobs:
echo "${conan_installation_folder}" >> $GITHUB_PATH
- name: Build wheel
run: |
conan remove -c "libqasm/*"
conan remove -c "*/*"
/opt/python/${{ matrix.cpython_version }}/bin/python setup.py bdist_wheel
/opt/python/${{ matrix.cpython_version }}/bin/python -m auditwheel repair pybuild/dist/*.whl
- name: Wheel path
Expand Down
335 changes: 164 additions & 171 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -7,65 +7,63 @@ on:
pull_request:

jobs:
# cpp-linux-x64:
# name: "C++ tests (gcc-clang/Linux/x64)"
# runs-on: ubuntu-latest
# strategy:
# fail-fast: false
# matrix:
# build_type:
# - Debug
# - Release
# compiler:
# - clang
# - gcc
# steps:
# - name: Checkout
# uses: actions/checkout@v4
# - uses: ./.github/actions/cpp-tests
# with:
# build_type: ${{ matrix.build_type }}
# conan_profile: tests-${{ matrix.build_type }}-${{ matrix.compiler }}-linux-x64
# shell: bash
#
# cpp-macos-x64:
# name: "C++ tests (clang/MacOS/x64)"
# runs-on: macos-latest
# strategy:
# fail-fast: false
# matrix:
# build_type:
# - Debug
# - Release
# steps:
# - name: Checkout
# uses: actions/checkout@v4
# - uses: ./.github/actions/cpp-tests
# with:
# build_type: ${{ matrix.build_type }}
# conan_profile: tests-${{ matrix.build_type }}-apple_clang-macos-x64
# shell: bash
#
# cpp-windows-x64:
# name: "C++ tests (msvc/Windows/x64)"
# runs-on: windows-latest
# strategy:
# fail-fast: false
# matrix:
# build_type:
# - Debug
# - Release
# steps:
# - name: Checkout
# uses: actions/checkout@v4
# - uses: ./.github/actions/cpp-tests
# with:
# build_type: ${{ matrix.build_type }}
# conan_profile: tests-${{ matrix.build_type }}-msvc-windows-x64
# shell: bash
cpp-linux-x64:
name: "C++ tests (gcc-clang/Linux/x64)"
runs-on: ubuntu-latest
strategy:
fail-fast: false
matrix:
build_type:
- Debug
- Release
compiler:
- clang
- gcc
steps:
- name: Checkout
uses: actions/checkout@v4
- uses: ./.github/actions/cpp-tests
with:
build_type: ${{ matrix.build_type }}
conan_profile: tests-${{ matrix.build_type }}-${{ matrix.compiler }}-linux-x64
shell: bash

cpp-macos-x64:
name: "C++ tests (clang/MacOS/x64)"
runs-on: macos-latest
strategy:
fail-fast: false
matrix:
build_type:
- Debug
- Release
steps:
- name: Checkout
uses: actions/checkout@v4
- uses: ./.github/actions/cpp-tests
with:
build_type: ${{ matrix.build_type }}
conan_profile: tests-${{ matrix.build_type }}-apple_clang-macos-x64
shell: bash

cpp-windows-x64:
name: "C++ tests (msvc/Windows/x64)"
runs-on: windows-latest
strategy:
fail-fast: false
matrix:
build_type:
- Debug
- Release
steps:
- name: Checkout
uses: actions/checkout@v4
- uses: ./.github/actions/cpp-tests
with:
build_type: ${{ matrix.build_type }}
conan_profile: tests-${{ matrix.build_type }}-msvc-windows-x64
shell: bash

# We are observing an internal compiler error when building with gcc
# So we are changing to clang for the Linux/ARM64 builds
cpp-linux-arm64:
name: "C++ tests (gcc/Linux/ARM64)"
runs-on: [self-hosted, ARM64, Linux]
Expand All @@ -74,7 +72,7 @@ jobs:
fail-fast: false
matrix:
build_type:
# - Debug
- Debug
- Release
steps:
- name: Checkout
Expand All @@ -88,123 +86,118 @@ jobs:
- name: Install dependencies
run: |
apt-get update
apt-get install -y bison flex default-jre clang
python3 -m pip install --upgrade pip conan
apt-get install -y bison flex default-jre
shell: bash
- name: Clean Conan cache
- uses: ./.github/actions/cpp-tests
with:
build_type: ${{ matrix.build_type }}
conan_profile: tests-${{ matrix.build_type }}-gcc-linux-arm64
shell: bash

cpp-macos-arm64:
name: "C++ tests (clang/macos/ARM64)"
runs-on: [self-hosted, ARM64, macOS]
strategy:
fail-fast: false
matrix:
build_type:
- Debug
- Release
steps:
- name: Checkout
uses: actions/checkout@v4
# We are having problems when using the m4 and zulu-opendjk Conan packages on an armv8 architecture
# m4 is required by flex/bison and zulu-openjdk provides the Java JRE required by the ANTLR generator
# So, for the time being, we are installing flex/bison and java manually for this platform
- name: Install bison, flex and java
run: |
conan remove -c "*/*"
brew install bison flex java
echo "$(brew --prefix bison)/bin" >> $GITHUB_PATH
echo "$(brew --prefix flex)/bin" >> $GITHUB_PATH
echo "$(brew --prefix java)/bin" >> $GITHUB_PATH
shell: bash
- uses: ./.github/actions/cpp-tests
with:
build_type: ${{ matrix.build_type }}
conan_profile: tests-${{ matrix.build_type }}-gcc-linux-arm64
conan_profile: tests-${{ matrix.build_type }}-apple_clang-macos-arm64
shell: bash

python-linux-x64:
name: "Python tests (Linux/x64)"
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Install SWIG
run: |
sudo apt-get install -y swig
shell: bash
- name: Export env vars
run: |
echo "LIBQASM_BUILD_TYPE=Debug" >> $GITHUB_ENV
echo "OPENQL_DISABLE_UNITARY=true" >> $GITHUB_ENV
shell: bash
- uses: ./.github/actions/python-tests
with:
shell: bash

# cpp-macos-arm64:
# name: "C++ tests (clang/macos/ARM64)"
# runs-on: [self-hosted, ARM64, macOS]
# strategy:
# fail-fast: false
# matrix:
# build_type:
# - Debug
# - Release
# steps:
# - name: Checkout
# uses: actions/checkout@v4
# # We are having problems when using the m4 and zulu-opendjk Conan packages on an armv8 architecture
# # m4 is required by flex/bison and zulu-openjdk provides the Java JRE required by the ANTLR generator
# # So, for the time being, we are installing flex/bison and java manually for this platform
# - name: Install bison, flex and java
# run: |
# brew install bison flex java
# echo "$(brew --prefix bison)/bin" >> $GITHUB_PATH
# echo "$(brew --prefix flex)/bin" >> $GITHUB_PATH
# echo "$(brew --prefix java)/bin" >> $GITHUB_PATH
# shell: bash
# - uses: ./.github/actions/cpp-tests
# with:
# build_type: ${{ matrix.build_type }}
# conan_profile: tests-${{ matrix.build_type }}-apple_clang-macos-arm64
# shell: bash
#
# python-linux-x64:
# name: "Python tests (Linux/x64)"
# runs-on: ubuntu-latest
# steps:
# - name: Checkout
# uses: actions/checkout@v4
# - name: Install SWIG
# run: |
# sudo apt-get install -y swig
# shell: bash
# - name: Export env vars
# run: |
# echo "LIBQASM_BUILD_TYPE=Debug" >> $GITHUB_ENV
# echo "OPENQL_DISABLE_UNITARY=true" >> $GITHUB_ENV
# shell: bash
# - uses: ./.github/actions/python-tests
# with:
# shell: bash
#
# python-macos-x64:
# name: "Python tests (macOS/x64)"
# runs-on: macos-latest
# steps:
# - name: Checkout
# uses: actions/checkout@v4
# - name: Install SWIG
# run: |
# brew install swig
# shell: bash
# - name: Export env vars
# run: |
# echo "LIBQASM_BUILD_TYPE=Debug" >> $GITHUB_ENV
# echo "OPENQL_DISABLE_UNITARY=true" >> $GITHUB_ENV
# shell: bash
# - uses: ./.github/actions/python-tests
# with:
# shell: bash
#
# python-windows-x64:
# name: "Python tests (Windows/x64)"
# runs-on: windows-latest
# steps:
# - name: Checkout
# uses: actions/checkout@v4
# - name: Export env vars
# run: |
# echo "LIBQASM_BUILD_TYPE=Release" >> $env:GITHUB_ENV
# echo "OPENQL_BUILD_TYPE=Release" >> $env:GITHUB_ENV
# echo "OPENQL_DISABLE_UNITARY=true" >> $env:GITHUB_ENV
# shell: powershell
# - uses: ./.github/actions/python-tests
# with:
# shell: bash
#
# complete:
# # see https://github.community/t/status-check-for-a-matrix-jobs/127354/7
# name: Report status
# needs:
# - cpp-linux-x64
# - cpp-macos-x64
# - cpp-windows-x64
# - cpp-linux-arm64
# - cpp-macos-arm64
# - python-linux-x64
# - python-macos-x64
# - python-windows-x64
# if: ${{ always() }}
# runs-on: ubuntu-latest
# steps:
# - name: Check all job status
# # see https://docs.github.com/en/actions/reference/context-and-expression-syntax-for-github-actions#needs-context
# # see https://stackoverflow.com/a/67532120/4907315
# if: >-
# ${{
# contains(needs.*.result, 'failure')
# || contains(needs.*.result, 'cancelled')
# || contains(needs.*.result, 'skipped')
# }}
# run: exit 1
python-macos-x64:
name: "Python tests (macOS/x64)"
runs-on: macos-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Install SWIG
run: |
brew install swig
shell: bash
- name: Export env vars
run: |
echo "LIBQASM_BUILD_TYPE=Debug" >> $GITHUB_ENV
echo "OPENQL_DISABLE_UNITARY=true" >> $GITHUB_ENV
shell: bash
- uses: ./.github/actions/python-tests
with:
shell: bash

python-windows-x64:
name: "Python tests (Windows/x64)"
runs-on: windows-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Export env vars
run: |
echo "LIBQASM_BUILD_TYPE=Release" >> $env:GITHUB_ENV
echo "OPENQL_BUILD_TYPE=Release" >> $env:GITHUB_ENV
echo "OPENQL_DISABLE_UNITARY=true" >> $env:GITHUB_ENV
shell: powershell
- uses: ./.github/actions/python-tests
with:
shell: bash

complete:
# see https://github.community/t/status-check-for-a-matrix-jobs/127354/7
name: Report status
needs:
- cpp-linux-x64
- cpp-macos-x64
- cpp-windows-x64
- cpp-linux-arm64
- cpp-macos-arm64
- python-linux-x64
- python-macos-x64
- python-windows-x64
if: ${{ always() }}
runs-on: ubuntu-latest
steps:
- name: Check all job status
# see https://docs.github.com/en/actions/reference/context-and-expression-syntax-for-github-actions#needs-context
# see https://stackoverflow.com/a/67532120/4907315
if: >-
${{
contains(needs.*.result, 'failure')
|| contains(needs.*.result, 'cancelled')
|| contains(needs.*.result, 'skipped')
}}
run: exit 1

0 comments on commit 0522005

Please sign in to comment.