From eefbdc24c0bf0564111ec503c367a02438b3ed0d Mon Sep 17 00:00:00 2001 From: Sviatoslav Sydorenko Date: Thu, 19 Jan 2023 03:14:18 +0100 Subject: [PATCH] Test sdist contents instead of Git checkout in CI This patch helps make sure that sdist contents is enough to run tests downstream. --- .github/workflows/ci.yml | 116 ++++++++++++++++++++++++++++++++++++--- MANIFEST.in | 8 ++- 2 files changed, 114 insertions(+), 10 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index cb00ff85bb..11ca9901e5 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -14,9 +14,75 @@ concurrency: group: ${{ github.ref }}-${{ github.workflow }}-${{ github.event_name }}${{ github.ref == format('refs/heads/{0}', github.event.repository.default_branch) && format('-{0}', github.sha) || '' }} cancel-in-progress: true +env: + dists-artifact-name: python-package-distributions + dist-name: trio + jobs: + build: + name: 👷 dists + + runs-on: ubuntu-latest + + outputs: + dist-version: ${{ steps.dist-version.outputs.version }} + sdist-artifact-name: ${{ steps.artifact-name.outputs.sdist }} + wheel-artifact-name: ${{ steps.artifact-name.outputs.wheel }} + + steps: + - name: Switch to using Python 3.11 + uses: actions/setup-python@v5 + with: + python-version: 3.11 + + - name: Grab the source from Git + uses: actions/checkout@v4 + + - name: Get the dist version + id: dist-version + run: >- + echo "version=$( + grep ^__version__ src/trio/_version.py + | sed 's#__version__ = "\([^"]\+\)"#\1#' + )" + >> "${GITHUB_OUTPUT}" + + - name: Set the expected dist artifact names + id: artifact-name + run: | + echo 'sdist=${{ env.dist-name }}-*.tar.gz' >> "${GITHUB_OUTPUT}" + echo 'wheel=${{ + env.dist-name + }}-*-py3-none-any.whl' >> "${GITHUB_OUTPUT}" + + - name: Install build + run: python -Im pip install build + + - name: Build dists + run: python -Im build + - name: Verify that the artifacts with expected names got created + run: >- + ls -1 + dist/${{ steps.artifact-name.outputs.sdist }} + dist/${{ steps.artifact-name.outputs.wheel }} + - name: Store the distribution packages + uses: actions/upload-artifact@v4 + with: + name: ${{ env.dists-artifact-name }} + # NOTE: Exact expected file names are specified here + # NOTE: as a safety measure — if anything weird ends + # NOTE: up being in this dir or not all dists will be + # NOTE: produced, this will fail the workflow. + path: | + dist/${{ steps.artifact-name.outputs.sdist }} + dist/${{ steps.artifact-name.outputs.wheel }} + retention-days: 5 + Windows: name: 'Windows (${{ matrix.python }}, ${{ matrix.arch }}${{ matrix.extra_name }})' + needs: + - build + timeout-minutes: 20 runs-on: 'windows-latest' strategy: @@ -58,8 +124,11 @@ jobs: || false }} steps: - - name: Checkout - uses: actions/checkout@v4 + - name: Retrieve the project source from an sdist inside the GHA artifact + uses: re-actors/checkout-python-sdist@release/v2 + with: + source-tarball-name: ${{ needs.build.outputs.sdist-artifact-name }} + workflow-artifact-name: ${{ env.dists-artifact-name }} - name: Setup python uses: actions/setup-python@v5 with: @@ -94,6 +163,9 @@ jobs: Ubuntu: name: 'Ubuntu (${{ matrix.python }}${{ matrix.extra_name }})' + needs: + - build + timeout-minutes: 10 runs-on: 'ubuntu-latest' strategy: @@ -121,7 +193,14 @@ jobs: || false }} steps: - - name: Checkout + - name: Retrieve the project source from an sdist inside the GHA artifact + if: matrix.check_formatting != '1' + uses: re-actors/checkout-python-sdist@release/v2 + with: + source-tarball-name: ${{ needs.build.outputs.sdist-artifact-name }} + workflow-artifact-name: ${{ env.dists-artifact-name }} + - name: Grab the source from Git + if: matrix.check_formatting == '1' uses: actions/checkout@v4 - name: Setup python uses: actions/setup-python@v5 @@ -146,6 +225,9 @@ jobs: macOS: name: 'macOS (${{ matrix.python }})' + needs: + - build + timeout-minutes: 15 runs-on: 'macos-latest' strategy: @@ -162,8 +244,11 @@ jobs: || false }} steps: - - name: Checkout - uses: actions/checkout@v4 + - name: Retrieve the project source from an sdist inside the GHA artifact + uses: re-actors/checkout-python-sdist@release/v2 + with: + source-tarball-name: ${{ needs.build.outputs.sdist-artifact-name }} + workflow-artifact-name: ${{ env.dists-artifact-name }} - name: Setup python uses: actions/setup-python@v5 with: @@ -183,17 +268,24 @@ jobs: # run CI on a musl linux Alpine: name: "Alpine" + needs: + - build + runs-on: ubuntu-latest container: alpine steps: - - name: Checkout - uses: actions/checkout@v4 - name: Install necessary packages # can't use setup-python because that python doesn't seem to work; # `python3-dev` (rather than `python:alpine`) for some ctypes reason, # `nodejs` for pyright (`node-env` pulls in nodejs but that takes a while and can time out the test). # `perl` for a platform independent `sed -i` alternative run: apk update && apk add python3-dev bash nodejs perl + - name: Retrieve the project source from an sdist inside the GHA artifact + # must be after `apk add` because it relies on `bash` existing + uses: re-actors/checkout-python-sdist@release/v2 + with: + source-tarball-name: ${{ needs.build.outputs.sdist-artifact-name }} + workflow-artifact-name: ${{ env.dists-artifact-name }} - name: Enter virtual environment run: python -m venv .venv - name: Run tests @@ -211,6 +303,9 @@ jobs: Cython: name: "Cython" + needs: + - build + runs-on: ubuntu-latest strategy: fail-fast: false @@ -225,8 +320,11 @@ jobs: - python: '3.13' # We support running cython3 on 3.13 cython: '>=3' # cython 3 (or greater) steps: - - name: Checkout - uses: actions/checkout@v4 + - name: Retrieve the project source from an sdist inside the GHA artifact + uses: re-actors/checkout-python-sdist@release/v2 + with: + source-tarball-name: ${{ needs.build.outputs.sdist-artifact-name }} + workflow-artifact-name: ${{ env.dists-artifact-name }} - name: Setup python uses: actions/setup-python@v5 with: diff --git a/MANIFEST.in b/MANIFEST.in index 440994e43a..5ab28eabbd 100644 --- a/MANIFEST.in +++ b/MANIFEST.in @@ -1,8 +1,14 @@ +include .codecov.yml +include check.sh +include ci.sh include LICENSE LICENSE.MIT LICENSE.APACHE2 include README.rst include CODE_OF_CONDUCT.md CONTRIBUTING.md -include test-requirements.txt +include *-requirements.in +include *-requirements.txt include src/trio/py.typed +include src/trio/_tests/astrill-codesigning-cert.cer recursive-include src/trio/_tests/test_ssl_certs *.pem recursive-include docs * +recursive-include tests * prune docs/build