-
Notifications
You must be signed in to change notification settings - Fork 25
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add scripting and documentation for pushing releases to PyPI. (#519)
Progress on #400. This scripting allows us to publish .whl files from https://github.com/nod-ai/SHARK-Platform/releases/tag/dev-wheels to [PyPI](https://pypi.org/). Here are the basic steps: 1. Download wheels for a specific pre-release (e.g. `2.9.1rc20241114`) 2. Edit the versions in the downloaded wheels to remove the `rcYYYYMMDD` suffix 3. Build the `shark-ai` meta package using the versions in those whls (NOTE: currently this uses the versions _in the source tree_, see below) 4. Upload all wheels to PyPI Logs of this running: https://gist.github.com/ScottTodd/9c7418d5bbbebc8aea72a39bc2ac37b0 (to push 2.9.1 to PyPI) The new `pypi_deploy.sh` script is based on the similar script we maintain in IREE: https://github.com/iree-org/iree/blob/main/build_tools/python_deploy/pypi_deploy.sh . The `README.md` file is also forked from IREE. Known sharp edges with the publishing process: * This currently mixes local information (versions from the source tree where this is running) with remote information (versions from the nightly release packages). Publishing nightly meta packages will let us simplify and make this safer to run from arbitrary working trees * The local build of the shark-ai meta package copies _all_ files in `shark-ai/build_tools/wheelhouse/` to the working directory that gets sent to `twine upload *`. If there are preexisting files in that directory they will be published. * The step that downloads releases from GitHub uses `pip download` so it can leverage PyPI's version resolution logic, but I couldn't figure out a way to download 3.13t wheels without running a 3.13t python interpreter. I happen to have 3.13t installed on my system, but we shouldn't require that in the scripting for all release engineers. We could try using the `gh` tool as in IREE, if we properly filter the download to just the version we want: https://github.com/iree-org/iree/blob/9eaa4ef7d6b439d8c444b533beddd82146578e25/build_tools/python_deploy/pypi_deploy.sh#L69-L72 (that has one release per nightly, while here we have a single release shared between all nightlies) --------- Co-authored-by: Marius Brehler <[email protected]>
- Loading branch information
Showing
8 changed files
with
205 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,48 @@ | ||
# Python Deployment | ||
|
||
These scripts assist with building Python packages and pushing them to | ||
[PyPI (the Python Package Index)](https://pypi.org/). See also | ||
|
||
* The Python Packaging User Guide: <https://packaging.python.org/en/latest/> | ||
|
||
## Overview | ||
|
||
See comments in scripts for canonical usage. This page includes additional | ||
notes. | ||
|
||
### Package building | ||
|
||
These scripts build packages: | ||
|
||
* [`/shark-ai/build_tools/build_linux_package.sh`](/shark-ai/build_tools/build_linux_package.sh) | ||
* [`/sharktank/build_tools/build_linux_package.sh`](/sharktank/build_tools/build_linux_package.sh) | ||
* [`/shortfin/build_tools/build_linux_package.sh`](/shortfin/build_tools/build_linux_package.sh) | ||
|
||
### Version management | ||
|
||
These scripts handle versioning across packages, including considerations like | ||
major, minor, and patch levels (`X.Y.Z`), as well as suffixes like | ||
`rc20241107`: | ||
|
||
* [`compute_common_version.py`](./compute_common_version.py) | ||
* [`compute_local_version.py`](./compute_local_version.py) | ||
* [`promote_whl_from_rc_to_final.py`](./promote_whl_from_rc_to_final.py) | ||
* [`write_requirements.py`](./write_requirements.py) | ||
|
||
### PyPI deployment | ||
|
||
These scripts handle promoting nightly releases packages to stable and pushing | ||
to PyPI: | ||
|
||
* [`promote_whl_from_rc_to_final.py`](./promote_whl_from_rc_to_final.py) | ||
* [`pypi_deploy.sh`](./pypi_deploy.sh) | ||
|
||
Both of these scripts expect to have the dependencies from | ||
[`requirements-pypi-deploy.txt`](./requirements-pypi-deploy.txt) installed. | ||
This can be easily managed by using a Python virtual environment: | ||
|
||
```bash | ||
python -m venv .venv | ||
source .venv/bin/activate | ||
python -m pip install -r ./requirements-pypi-deploy.txt | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Empty file.
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,126 @@ | ||
#!/bin/bash | ||
|
||
# Copyright 2024 Advanced Micro Devices, Inc. | ||
# | ||
# Licensed under the Apache License v2.0 with LLVM Exceptions. | ||
# See https://llvm.org/LICENSE.txt for license information. | ||
# SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception | ||
|
||
# This script promotes Python packages from nightly releases to PyPI. | ||
# | ||
# Prerequisites: | ||
# * You will need to have PyPI credentials set up. See | ||
# https://packaging.python.org/en/latest/tutorials/packaging-projects/#uploading-the-distribution-archives | ||
# * Install requirements, e.g. in a Python virtual environment (venv): | ||
# `pip install -r requirements-pypi-deploy.txt` | ||
# * Install python3.13t and install pip. On Ubuntu: | ||
# ```bash | ||
# sudo add-apt-repository ppa:deadsnakes | ||
# sudo apt-get update | ||
# sudo apt-get install python3.13-nogil | ||
# python3.13t -m ensurepip --upgrade | ||
# ``` | ||
# * Choose a release candidate to promote from | ||
# https://github.com/nod-ai/SHARK-Platform/releases/tag/dev-wheels | ||
# | ||
# Usage: | ||
# ./pypi_deploy.sh 2.9.0rc20241108 | ||
|
||
set -euo pipefail | ||
|
||
RELEASE="$1" | ||
|
||
SCRIPT_DIR="$(dirname -- "$( readlink -f -- "$0"; )")"; | ||
REPO_ROOT="$(cd "$SCRIPT_DIR"/../../ && pwd)" | ||
TMPDIR="$(mktemp --directory --tmpdir shark_platform_pypi_wheels.XXXXX)" | ||
ASSETS_PAGE="https://github.com/nod-ai/SHARK-Platform/releases/expanded_assets/dev-wheels" | ||
|
||
# TODO: rewrite in Python? | ||
|
||
function download_wheels() { | ||
echo "" | ||
echo "Downloading wheels for '${RELEASE}'..." | ||
|
||
# sharktank | ||
python -m pip download sharktank==${RELEASE} \ | ||
--no-deps --python-version 3.11 -f ${ASSETS_PAGE} | ||
|
||
# shortfin | ||
python -m pip download shortfin==${RELEASE} \ | ||
--no-deps --python-version 3.11 -f ${ASSETS_PAGE} | ||
python -m pip download shortfin==${RELEASE} \ | ||
--no-deps --python-version 3.12 -f ${ASSETS_PAGE} | ||
python -m pip download shortfin==${RELEASE} \ | ||
--no-deps --python-version 3.13 -f ${ASSETS_PAGE} | ||
python -m pip download shortfin==${RELEASE} \ | ||
--no-deps --python-version 3.13 -f ${ASSETS_PAGE} | ||
# TODO: fetch 3.13t using the same `python` somehow | ||
# * https://pip.pypa.io/en/stable/cli/pip_download/ | ||
# * https://py-free-threading.github.io/installing_cpython/ | ||
# * https://pip.pypa.io/en/stable/installation/ | ||
python3.13t -m pip download shortfin==${RELEASE} --no-deps -f ${ASSETS_PAGE} | ||
|
||
# TODO: shark-ai meta package when it is published to nightlies | ||
|
||
echo "" | ||
echo "Downloaded wheels:" | ||
ls | ||
} | ||
|
||
function edit_release_versions() { | ||
echo "" | ||
echo "Editing release versions..." | ||
for file in * | ||
do | ||
${SCRIPT_DIR}/promote_whl_from_rc_to_final.py ${file} --delete-old-wheel | ||
done | ||
|
||
echo "Edited wheels:" | ||
ls | ||
} | ||
|
||
function upload_wheels() { | ||
# TODO: list packages that would be uploaded, pause, prompt to continue | ||
echo "" | ||
echo "Uploading wheels:" | ||
ls | ||
twine upload --verbose * | ||
} | ||
|
||
function build_shark_ai_meta_package() { | ||
# TODO: download meta package from nightly releases instead of this | ||
# Be aware that nightly releases pin other dependencies via the | ||
# generated `requirements.txt` compared to stable releases. | ||
echo "" | ||
|
||
# TODO: rework `write_requirements.py` to use the versions from the downloaded whls? | ||
echo "Computing local versions for sharktank and shortfin..." | ||
${SCRIPT_DIR}/compute_local_version.py ${REPO_ROOT}/sharktank | ||
${SCRIPT_DIR}/compute_local_version.py ${REPO_ROOT}/shortfin | ||
|
||
echo "Computing common version for shark-ai meta package..." | ||
${SCRIPT_DIR}/compute_common_version.py --stable-release --write-json | ||
|
||
echo "Writing requirements for shark-ai meta package..." | ||
${SCRIPT_DIR}/write_requirements.py | ||
|
||
echo "Building shark-ai meta package..." | ||
${REPO_ROOT}/shark-ai/build_tools/build_linux_package.sh | ||
|
||
# TODO: This is error-prone. We only want to publish the whl for this release. | ||
# Copy instead? Specify exact file name? Clear directory before building? | ||
mv ${REPO_ROOT}/shark-ai/build_tools/wheelhouse/* . | ||
} | ||
|
||
function main() { | ||
echo "Changing into ${TMPDIR}" | ||
cd "${TMPDIR}" | ||
# TODO: check_requirements (using pip) | ||
|
||
download_wheels | ||
edit_release_versions | ||
build_shark_ai_meta_package | ||
upload_wheels | ||
} | ||
|
||
main |
File renamed without changes.
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
#!/bin/bash | ||
|
||
# Copyright 2024 Advanced Micro Devices, Inc. | ||
# | ||
# Licensed under the Apache License v2.0 with LLVM Exceptions. | ||
# See https://llvm.org/LICENSE.txt for license information. | ||
# SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception | ||
|
||
# build_linux_package.sh | ||
# | ||
# Builds shark-ai Python package for Linux. | ||
# | ||
# Usage: | ||
# ./build_tools/build_linux_package.sh | ||
|
||
set -xeu -o errtrace | ||
|
||
THIS_DIR="$(cd $(dirname $0) && pwd)" | ||
REPO_ROOT="$(cd "$THIS_DIR"/../../ && pwd)" | ||
OUTPUT_DIR="${OUTPUT_DIR:-${THIS_DIR}/wheelhouse}" | ||
|
||
python -m pip wheel --disable-pip-version-check --no-deps -v -w "${OUTPUT_DIR}" "${REPO_ROOT}/shark-ai" | ||
|
||
wheel_output="$(echo "${OUTPUT_DIR}/shark_ai-"*".whl")" | ||
ls "${wheel_output}" |