diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 94be4a8d13..62e47f93bf 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -29,11 +29,11 @@ jobs: matrix: os: [ # Use v24 beta for now to get newer SWIG; TODO: change back to ubuntu-latest once it points to v24 - ubuntu-24.04, + # ubuntu-24.04, # latest available X86_64 target macos-15, # latest is ARM - macos-latest, + # macos-latest, ] steps: - name: Checkout @@ -134,389 +134,389 @@ jobs: name: ${{ matrix.os }}-PerformanceTestResults.txt path: ./out/SoarPerformanceTests/PerformanceTestResults.txt - # Using powershell means we need to explicitly stop on failure - Windows: - name: build-windows - runs-on: [windows-latest] - env: - TCL_HOME: c:\progra~1\tcl - TCL_DOWNLOAD_URL: https://kumisystems.dl.sourceforge.net/project/tcl/Tcl/8.6.13/tcl8613-src.zip - EXPECTED_TCL_HASH: 8999fcafab2d85473280e0bf6e390480496dfd53 - - steps: - - name: Checkout - uses: actions/checkout@v1 - - name: Setup Python - uses: actions/setup-python@v4 - with: - python-version: '3.12' - - name: Setup Java - uses: actions/setup-java@v3 - with: - distribution: 'temurin' - java-version: '11' - - # This does not install MSVC or Visual Studio! We rely on the software installed already on the - # GH action runner, and this step just prepares the environment. We pin the VS version here because - # the error messages are much more helpful than the mess we get from SCons, which automatically - # falls back on a combo of Mingw with MSVC libs and then fails to build. - - name: switch to VS command prompt - uses: ilammy/msvc-dev-cmd@v1 - - - name: Cache Tcl build - id: tcl-msvc-cache - uses: actions/cache@v3 - with: - path: ${{ env.TCL_HOME }} - key: tcl-build-windows-${{ env.TCL_DOWNLOAD_URL }} - - # No easy/quick way to install TCL on Windows, so we download and build it ourselves. - - name: download, build and install Tcl - if: steps.tcl-msvc-cache.outputs.cache-hit != 'true' - run: | - (new-object System.Net.WebClient).DownloadFile($Env:TCL_DOWNLOAD_URL, 'tcl8613-src.zip') - # check that the file hash matches what we expect - $FileHash = Get-FileHash -Algorithm SHA1 tcl8613-src.zip - if ( $FileHash.Hash -ne $Env:EXPECTED_TCL_HASH ) { - throw "tcl download hash mismatch: $($FileHash.Hash)" - } - - Expand-Archive tcl8613-src.zip -DestinationPath tcl8613-src - cd tcl8613-src\tcl8.6.13\win - # Build and install must be done in two steps: https://core.tcl-lang.org/tcl/tktview/aa6e42643794ecff2f3508d7306c702baf4f4c0f - nmake /D /f makefile.vc INSTALLDIR="$env:TCL_HOME" - if ($lastexitcode -ne 0) { - throw "nmake build exit code: $lastexitcode" - } - nmake /D /f makefile.vc INSTALLDIR="$env:TCL_HOME" install - if ($lastexitcode -ne 0) { - throw "nmake install exit code: $lastexitcode" - } - - - name: build - env: - # instructs SCons to print debug statements to stdout - SCONS_MSCOMMON_DEBUG: '-' - run: | - ./build.bat --scu --opt --verbose --tcl="$env:TCL_HOME" all performance_tests sml_tcl - if ($lastexitcode -ne 0) { - throw "build.bat exit code: $lastexitcode" - } - - - name: Pack artifacts - shell: bash - run: tar -czvf build.tar.gz out/ - - name: upload artifacts - uses: actions/upload-artifact@v3 - with: - name: Soar-Windows - path: ./build.tar.gz - - - name: unit tests - working-directory: ./out - # TODO: why do these fail? Make them pass. - run: | - ./UnitTests -e PRIMS_Sanity1 -e PRIMS_Sanity2 -f testSmemArithmetic - if ($lastexitcode -ne 0) { - throw "UnitTests exit code: $lastexitcode" - } - - - name: SML Java tests - working-directory: ./out - run: | - java -jar java/soar-smljava.jar - if ($lastexitcode -ne 0) { - throw "soar-smljava exit code: $lastexitcode" - } - - - name: SML Python tests - working-directory: ./out - env: - PYTHONUTF8: 1 - run: | - python3 TestPythonSML.py - if ($lastexitcode -ne 0) { - throw "TestPythonSML.py exit code: $lastexitcode" - } - - - name: SML Tcl tests - working-directory: ./out - run: | - # have to add Tcl to path every time we use it (permanent add is possible but troublesome) - $env:path += "$env:path;$env:TCL_HOME\bin" - tclsh86t TestTclSML.tcl - if ($lastexitcode -ne 0) { - throw "TestTclSML.tcl exit code: $lastexitcode" - } - - # TODO: run additional tests for CSharp - - # reports JUnit test results as GitHub PR check. - - name: publish test report - uses: mikepenz/action-junit-report@v3 - # always run even if the previous step fails - if: always() - with: - report_paths: './out/TestResults.xml' - # disabled until https://github.com/mikepenz/action-junit-report/issues/40 is resolved - # fail_on_failure: true - annotate_only: true - - - name: performance tests - working-directory: ./out - run: | - bash ./do_performance_test.sh - if ($lastexitcode -ne 0) { - throw "do_performance_test exit code: $lastexitcode" - } - - - name: upload performance test results - uses: actions/upload-artifact@v3 - with: - name: Windows-PerformanceTestResults.txt - path: ./out/SoarPerformanceTests/PerformanceTestResults.txt - - python_wheels: - name: wheel-*nix - runs-on: ${{ matrix.os }} - strategy: - fail-fast: true - matrix: - os: [ - # 20.04 to preserve compatibility with testing stage - ubuntu-20.04, - # latest available X86_64 target - macos-15, - # latest is ARM - macos-latest, - - windows-latest, - ] - steps: - - name: Checkout - uses: actions/checkout@v4 - with: - # Do a complete clone, not a shallow one. - # https://github.com/actions/checkout/#usage - # - # We need a complete clone, as versioningit uses `git describe`, - # which requires a commit tree to determine the latest tag. - fetch-depth: 0 - - - name: Show tags - run: git describe --long --dirty --always --tags - - - name: Setup Python - uses: actions/setup-python@v4 - with: - python-version: "3.12" - - # - name: Setup tcl (ubuntu) - # if: matrix.os == 'ubuntu-latest' - # run: sudo apt-get update && sudo apt-get install tcl-dev - - # - name: Setup tcl (macos-latest) - # if: startsWith(matrix.os, 'macos') - # run: brew install tcl-tk - - - name: Setup SWIG (macos) - if: startsWith(matrix.os, 'macos') - run: brew install swig - - - name: Setup SWIG (windows-latest) - if: matrix.os == 'windows-latest' - uses: MinoruSekine/setup-scoop@v4 - with: - apps: swig - - - name: Build wheels - uses: pypa/cibuildwheel@v2.17.0 - with: - package-dir: Core/ClientSMLSWIG/Python/ - - - name: Ensure unit tests built (ubuntu-20.04) - if: matrix.os == 'ubuntu-20.04' - # On Ubuntu, we run cibuildwheel inside docker containers, which don't retain the outputs. - # However, we want out/SoarUnitTests/ to be availible for future tests, so we build it again here. - run: python scons/scons.py tests - - # Save out/SoarUnitTests/ - - uses: actions/cache/save@v3 - id: cache - with: - path: out/SoarUnitTests/ - key: ${{ runner.os }}-${{ github.sha }} - - - name: ABI3Audit (*nix) - if: matrix.os != 'windows-latest' - run: pipx run abi3audit -S -v wheelhouse/* - - - name: ABI3Audit (Windows) - if: matrix.os == 'windows-latest' - # For windows we can't use glob expansion, so we need to enumerate the files manually. - # https://stackoverflow.com/a/16804630/8700553 - run: Get-ChildItem -File wheelhouse | Foreach {pipx run abi3audit -S -v $_.fullname} - - - uses: actions/upload-artifact@v4 - with: - name: cibw-wheels-${{ matrix.os }}-${{ strategy.job-index }} - path: ./wheelhouse/*.whl - - test_python: - name: Test wheel on all python versions - runs-on: ${{ matrix.os }} - strategy: - fail-fast: false - matrix: - os: - # linux target which supports all python versions we want to install for - - ubuntu-20.04 - # latest available X86_64 target - - macos-15 - # latest is ARM - - macos-latest - - windows-latest - python-minor: - - 5 - - 6 - - 7 - - 8 - - 9 - - 10 - - 11 - - 12 - - # for macos-latest, we can't use python 3.5 - 3.7 - exclude: - - os: macos-latest - python-minor: 5 - - os: macos-latest - python-minor: 6 - - os: macos-latest - python-minor: 7 - - needs: - # We depend on the python wheel builds because we need their artifacts - - python_wheels - - # We depend on the builds themselves to gatekeep the upload if build + testing fails, - # usually then also the python wheel build should fail, but the normal builds do more thorough checking. - - Posix - - Windows - steps: - - name: Checkout - uses: actions/checkout@v4 - - - uses: actions/download-artifact@v4 - with: - pattern: cibw-wheels-* - path: wheelhouse/ - merge-multiple: true - - - name: Setup Base Python - uses: actions/setup-python@v4 - with: - python-version: 3.${{ matrix.python-minor }} - env: - # Older python versions fail install if we dont do this: https://github.com/actions/setup-python/issues/866 - PIP_TRUSTED_HOST: "pypi.python.org pypi.org files.pythonhosted.org" - - # Restore out/SoarUnitTests/ - - uses: actions/cache/restore@v3 - id: cache - with: - path: out/SoarUnitTests/ - key: ${{ runner.os }}-${{ github.sha }} - fail-on-cache-miss: true - - - name: Install soar-sml - run: | - pip3.${{ matrix.python-minor }} install soar-sml -f wheelhouse --no-index - - - name: Run test command (Non-Windows) - if: matrix.os != 'windows-latest' - env: - # Ensures unicode outputs properly on all versions - PYTHONUTF8: 1 - PYTHONIOENCODING: utf-8 - run: python3.${{ matrix.python-minor }} Core/ClientSMLSWIG/Python/TestPythonSML.py - - - name: Run test command (Windows) - if: matrix.os == 'windows-latest' - env: - # Ensures unicode outputs properly on all versions - PYTHONUTF8: 1 - PYTHONIOENCODING: utf-8 - run: py -3.${{ matrix.python-minor }} Core/ClientSMLSWIG/Python/TestPythonSML.py - - python_push_dev: - name: Publish to test.pypi.org - runs-on: ubuntu-latest - # - Upload only every monday to prevent spamming the index with too many build artifacts. - # - Allow uploading on manual workflow dispatch, to enable quick dev releases. - if: github.event_name == 'schedule' || github.event_name == 'workflow_dispatch' - # Alternative, to upload on every commit to development; - # if: github.event_name != 'schedule' && github.event_name != 'release' - - needs: test_python - - # We use Trusted Publishing to manage our access to pypi: - # https://github.com/marketplace/actions/pypi-publish#trusted-publishing - environment: - name: test-pypi - url: https://test.pypi.org/p/soar-sml/ - permissions: - id-token: write - - steps: - - name: Setup Python - uses: actions/setup-python@v4 - with: - python-version: "3.12" - - - uses: actions/download-artifact@v4 - with: - pattern: cibw-wheels-* - path: wheelhouse/ - merge-multiple: true - - - name: Publish package distributions to PyPI - uses: pypa/gh-action-pypi-publish@release/v1 - with: - repository-url: https://test.pypi.org/legacy/ - packages-dir: wheelhouse - skip-existing: true - verbose: true - - python_push_release: - name: Publish to pypi.org - runs-on: ubuntu-latest - if: github.event_name == 'release' - needs: test_python - - # We use Trusted Publishing to manage our access to pypi: - # https://github.com/marketplace/actions/pypi-publish#trusted-publishing - environment: - name: pypi - url: https://pypi.org/p/soar-sml/ - permissions: - id-token: write - - steps: - - name: Setup Python - uses: actions/setup-python@v4 - with: - python-version: "3.12" - - - uses: actions/download-artifact@v4 - with: - pattern: cibw-wheels-* - path: wheelhouse/ - merge-multiple: true - - - name: Publish package distributions to PyPI - uses: pypa/gh-action-pypi-publish@release/v1 - with: - packages-dir: wheelhouse - skip-existing: true - verbose: true + # # Using powershell means we need to explicitly stop on failure + # Windows: + # name: build-windows + # runs-on: [windows-latest] + # env: + # TCL_HOME: c:\progra~1\tcl + # TCL_DOWNLOAD_URL: https://kumisystems.dl.sourceforge.net/project/tcl/Tcl/8.6.13/tcl8613-src.zip + # EXPECTED_TCL_HASH: 8999fcafab2d85473280e0bf6e390480496dfd53 + + # steps: + # - name: Checkout + # uses: actions/checkout@v1 + # - name: Setup Python + # uses: actions/setup-python@v4 + # with: + # python-version: '3.12' + # - name: Setup Java + # uses: actions/setup-java@v3 + # with: + # distribution: 'temurin' + # java-version: '11' + + # # This does not install MSVC or Visual Studio! We rely on the software installed already on the + # # GH action runner, and this step just prepares the environment. We pin the VS version here because + # # the error messages are much more helpful than the mess we get from SCons, which automatically + # # falls back on a combo of Mingw with MSVC libs and then fails to build. + # - name: switch to VS command prompt + # uses: ilammy/msvc-dev-cmd@v1 + + # - name: Cache Tcl build + # id: tcl-msvc-cache + # uses: actions/cache@v3 + # with: + # path: ${{ env.TCL_HOME }} + # key: tcl-build-windows-${{ env.TCL_DOWNLOAD_URL }} + + # # No easy/quick way to install TCL on Windows, so we download and build it ourselves. + # - name: download, build and install Tcl + # if: steps.tcl-msvc-cache.outputs.cache-hit != 'true' + # run: | + # (new-object System.Net.WebClient).DownloadFile($Env:TCL_DOWNLOAD_URL, 'tcl8613-src.zip') + # # check that the file hash matches what we expect + # $FileHash = Get-FileHash -Algorithm SHA1 tcl8613-src.zip + # if ( $FileHash.Hash -ne $Env:EXPECTED_TCL_HASH ) { + # throw "tcl download hash mismatch: $($FileHash.Hash)" + # } + + # Expand-Archive tcl8613-src.zip -DestinationPath tcl8613-src + # cd tcl8613-src\tcl8.6.13\win + # # Build and install must be done in two steps: https://core.tcl-lang.org/tcl/tktview/aa6e42643794ecff2f3508d7306c702baf4f4c0f + # nmake /D /f makefile.vc INSTALLDIR="$env:TCL_HOME" + # if ($lastexitcode -ne 0) { + # throw "nmake build exit code: $lastexitcode" + # } + # nmake /D /f makefile.vc INSTALLDIR="$env:TCL_HOME" install + # if ($lastexitcode -ne 0) { + # throw "nmake install exit code: $lastexitcode" + # } + + # - name: build + # env: + # # instructs SCons to print debug statements to stdout + # SCONS_MSCOMMON_DEBUG: '-' + # run: | + # ./build.bat --scu --opt --verbose --tcl="$env:TCL_HOME" all performance_tests sml_tcl + # if ($lastexitcode -ne 0) { + # throw "build.bat exit code: $lastexitcode" + # } + + # - name: Pack artifacts + # shell: bash + # run: tar -czvf build.tar.gz out/ + # - name: upload artifacts + # uses: actions/upload-artifact@v3 + # with: + # name: Soar-Windows + # path: ./build.tar.gz + + # - name: unit tests + # working-directory: ./out + # # TODO: why do these fail? Make them pass. + # run: | + # ./UnitTests -e PRIMS_Sanity1 -e PRIMS_Sanity2 -f testSmemArithmetic + # if ($lastexitcode -ne 0) { + # throw "UnitTests exit code: $lastexitcode" + # } + + # - name: SML Java tests + # working-directory: ./out + # run: | + # java -jar java/soar-smljava.jar + # if ($lastexitcode -ne 0) { + # throw "soar-smljava exit code: $lastexitcode" + # } + + # - name: SML Python tests + # working-directory: ./out + # env: + # PYTHONUTF8: 1 + # run: | + # python3 TestPythonSML.py + # if ($lastexitcode -ne 0) { + # throw "TestPythonSML.py exit code: $lastexitcode" + # } + + # - name: SML Tcl tests + # working-directory: ./out + # run: | + # # have to add Tcl to path every time we use it (permanent add is possible but troublesome) + # $env:path += "$env:path;$env:TCL_HOME\bin" + # tclsh86t TestTclSML.tcl + # if ($lastexitcode -ne 0) { + # throw "TestTclSML.tcl exit code: $lastexitcode" + # } + + # # TODO: run additional tests for CSharp + + # # reports JUnit test results as GitHub PR check. + # - name: publish test report + # uses: mikepenz/action-junit-report@v3 + # # always run even if the previous step fails + # if: always() + # with: + # report_paths: './out/TestResults.xml' + # # disabled until https://github.com/mikepenz/action-junit-report/issues/40 is resolved + # # fail_on_failure: true + # annotate_only: true + + # - name: performance tests + # working-directory: ./out + # run: | + # bash ./do_performance_test.sh + # if ($lastexitcode -ne 0) { + # throw "do_performance_test exit code: $lastexitcode" + # } + + # - name: upload performance test results + # uses: actions/upload-artifact@v3 + # with: + # name: Windows-PerformanceTestResults.txt + # path: ./out/SoarPerformanceTests/PerformanceTestResults.txt + + # python_wheels: + # name: wheel-*nix + # runs-on: ${{ matrix.os }} + # strategy: + # fail-fast: true + # matrix: + # os: [ + # # 20.04 to preserve compatibility with testing stage + # ubuntu-20.04, + # # latest available X86_64 target + # macos-15, + # # latest is ARM + # macos-latest, + + # windows-latest, + # ] + # steps: + # - name: Checkout + # uses: actions/checkout@v4 + # with: + # # Do a complete clone, not a shallow one. + # # https://github.com/actions/checkout/#usage + # # + # # We need a complete clone, as versioningit uses `git describe`, + # # which requires a commit tree to determine the latest tag. + # fetch-depth: 0 + + # - name: Show tags + # run: git describe --long --dirty --always --tags + + # - name: Setup Python + # uses: actions/setup-python@v4 + # with: + # python-version: "3.12" + + # # - name: Setup tcl (ubuntu) + # # if: matrix.os == 'ubuntu-latest' + # # run: sudo apt-get update && sudo apt-get install tcl-dev + + # # - name: Setup tcl (macos-latest) + # # if: startsWith(matrix.os, 'macos') + # # run: brew install tcl-tk + + # - name: Setup SWIG (macos) + # if: startsWith(matrix.os, 'macos') + # run: brew install swig + + # - name: Setup SWIG (windows-latest) + # if: matrix.os == 'windows-latest' + # uses: MinoruSekine/setup-scoop@v4 + # with: + # apps: swig + + # - name: Build wheels + # uses: pypa/cibuildwheel@v2.17.0 + # with: + # package-dir: Core/ClientSMLSWIG/Python/ + + # - name: Ensure unit tests built (ubuntu-20.04) + # if: matrix.os == 'ubuntu-20.04' + # # On Ubuntu, we run cibuildwheel inside docker containers, which don't retain the outputs. + # # However, we want out/SoarUnitTests/ to be availible for future tests, so we build it again here. + # run: python scons/scons.py tests + + # # Save out/SoarUnitTests/ + # - uses: actions/cache/save@v3 + # id: cache + # with: + # path: out/SoarUnitTests/ + # key: ${{ runner.os }}-${{ github.sha }} + + # - name: ABI3Audit (*nix) + # if: matrix.os != 'windows-latest' + # run: pipx run abi3audit -S -v wheelhouse/* + + # - name: ABI3Audit (Windows) + # if: matrix.os == 'windows-latest' + # # For windows we can't use glob expansion, so we need to enumerate the files manually. + # # https://stackoverflow.com/a/16804630/8700553 + # run: Get-ChildItem -File wheelhouse | Foreach {pipx run abi3audit -S -v $_.fullname} + + # - uses: actions/upload-artifact@v4 + # with: + # name: cibw-wheels-${{ matrix.os }}-${{ strategy.job-index }} + # path: ./wheelhouse/*.whl + + # test_python: + # name: Test wheel on all python versions + # runs-on: ${{ matrix.os }} + # strategy: + # fail-fast: false + # matrix: + # os: + # # linux target which supports all python versions we want to install for + # - ubuntu-20.04 + # # latest available X86_64 target + # - macos-15 + # # latest is ARM + # - macos-latest + # - windows-latest + # python-minor: + # - 5 + # - 6 + # - 7 + # - 8 + # - 9 + # - 10 + # - 11 + # - 12 + + # # for macos-latest, we can't use python 3.5 - 3.7 + # exclude: + # - os: macos-latest + # python-minor: 5 + # - os: macos-latest + # python-minor: 6 + # - os: macos-latest + # python-minor: 7 + + # needs: + # # We depend on the python wheel builds because we need their artifacts + # - python_wheels + + # # We depend on the builds themselves to gatekeep the upload if build + testing fails, + # # usually then also the python wheel build should fail, but the normal builds do more thorough checking. + # - Posix + # - Windows + # steps: + # - name: Checkout + # uses: actions/checkout@v4 + + # - uses: actions/download-artifact@v4 + # with: + # pattern: cibw-wheels-* + # path: wheelhouse/ + # merge-multiple: true + + # - name: Setup Base Python + # uses: actions/setup-python@v4 + # with: + # python-version: 3.${{ matrix.python-minor }} + # env: + # # Older python versions fail install if we dont do this: https://github.com/actions/setup-python/issues/866 + # PIP_TRUSTED_HOST: "pypi.python.org pypi.org files.pythonhosted.org" + + # # Restore out/SoarUnitTests/ + # - uses: actions/cache/restore@v3 + # id: cache + # with: + # path: out/SoarUnitTests/ + # key: ${{ runner.os }}-${{ github.sha }} + # fail-on-cache-miss: true + + # - name: Install soar-sml + # run: | + # pip3.${{ matrix.python-minor }} install soar-sml -f wheelhouse --no-index + + # - name: Run test command (Non-Windows) + # if: matrix.os != 'windows-latest' + # env: + # # Ensures unicode outputs properly on all versions + # PYTHONUTF8: 1 + # PYTHONIOENCODING: utf-8 + # run: python3.${{ matrix.python-minor }} Core/ClientSMLSWIG/Python/TestPythonSML.py + + # - name: Run test command (Windows) + # if: matrix.os == 'windows-latest' + # env: + # # Ensures unicode outputs properly on all versions + # PYTHONUTF8: 1 + # PYTHONIOENCODING: utf-8 + # run: py -3.${{ matrix.python-minor }} Core/ClientSMLSWIG/Python/TestPythonSML.py + + # python_push_dev: + # name: Publish to test.pypi.org + # runs-on: ubuntu-latest + # # - Upload only every monday to prevent spamming the index with too many build artifacts. + # # - Allow uploading on manual workflow dispatch, to enable quick dev releases. + # if: github.event_name == 'schedule' || github.event_name == 'workflow_dispatch' + # # Alternative, to upload on every commit to development; + # # if: github.event_name != 'schedule' && github.event_name != 'release' + + # needs: test_python + + # # We use Trusted Publishing to manage our access to pypi: + # # https://github.com/marketplace/actions/pypi-publish#trusted-publishing + # environment: + # name: test-pypi + # url: https://test.pypi.org/p/soar-sml/ + # permissions: + # id-token: write + + # steps: + # - name: Setup Python + # uses: actions/setup-python@v4 + # with: + # python-version: "3.12" + + # - uses: actions/download-artifact@v4 + # with: + # pattern: cibw-wheels-* + # path: wheelhouse/ + # merge-multiple: true + + # - name: Publish package distributions to PyPI + # uses: pypa/gh-action-pypi-publish@release/v1 + # with: + # repository-url: https://test.pypi.org/legacy/ + # packages-dir: wheelhouse + # skip-existing: true + # verbose: true + + # python_push_release: + # name: Publish to pypi.org + # runs-on: ubuntu-latest + # if: github.event_name == 'release' + # needs: test_python + + # # We use Trusted Publishing to manage our access to pypi: + # # https://github.com/marketplace/actions/pypi-publish#trusted-publishing + # environment: + # name: pypi + # url: https://pypi.org/p/soar-sml/ + # permissions: + # id-token: write + + # steps: + # - name: Setup Python + # uses: actions/setup-python@v4 + # with: + # python-version: "3.12" + + # - uses: actions/download-artifact@v4 + # with: + # pattern: cibw-wheels-* + # path: wheelhouse/ + # merge-multiple: true + + # - name: Publish package distributions to PyPI + # uses: pypa/gh-action-pypi-publish@release/v1 + # with: + # packages-dir: wheelhouse + # skip-existing: true + # verbose: true