packages #741
Workflow file for this run
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
name: packages | ||
on: | ||
push: | ||
tags: | ||
- "v[0-9]+.[0-9]+.[0-9]+" | ||
- "v[0-9]+.[0-9]+.[0-9]+a[0-9]+" | ||
- "v[0-9]+.[0-9]+.[0-9]+b[0-9]+" | ||
- "v[0-9]+.[0-9]+.[0-9]+rc[0-9]+" | ||
# Dry-run only | ||
workflow_dispatch: | ||
schedule: | ||
- cron: "0 19 * * SUN" | ||
defaults: | ||
run: | ||
shell: bash -e {0} | ||
env: | ||
PACKAGE: "panel" | ||
PYTHON_VERSION: "3.11" | ||
NODE_VERSION: "20" | ||
jobs: | ||
waiting_room: | ||
name: Waiting Room | ||
runs-on: ubuntu-latest | ||
needs: [conda_build, pip_install, npm_build, cdn_build, verify_sizes] | ||
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags/') | ||
environment: | ||
name: publish | ||
steps: | ||
- run: echo "All builds have finished, have been approved, and ready to publish" | ||
verify_sizes: | ||
name: Verify sizes | ||
runs-on: ubuntu-latest | ||
needs: [conda_build, pip_build, npm_build, cdn_build] | ||
env: | ||
- GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}" | ||
- RUN_ID: ${{ github.run_id }} | ||
steps: | ||
- uses: actions/checkout@v4 | ||
with: | ||
fetch-depth: "1" | ||
- run: pipx run scripts/verify_build_sizes.py $RUN_ID | ||
pixi_lock: | ||
name: Pixi lock | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: holoviz-dev/holoviz_tasks/pixi_lock@v0 | ||
conda_build: | ||
name: Build Conda | ||
needs: [pixi_lock] | ||
runs-on: "ubuntu-latest" | ||
steps: | ||
- uses: holoviz-dev/holoviz_tasks/pixi_install@v0 | ||
with: | ||
environments: "build" | ||
install: false | ||
download-data: false | ||
- name: conda build | ||
run: pixi run -e build build-conda | ||
- uses: actions/upload-artifact@v4 | ||
if: always() | ||
with: | ||
name: conda | ||
path: dist/*tar.bz2 | ||
if-no-files-found: error | ||
conda_publish: | ||
name: Publish Conda | ||
runs-on: ubuntu-latest | ||
needs: [conda_build, waiting_room] | ||
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags/') | ||
defaults: | ||
run: | ||
shell: bash -el {0} | ||
steps: | ||
- uses: actions/download-artifact@v4 | ||
with: | ||
name: conda | ||
path: dist/ | ||
- name: Set environment variables | ||
run: | | ||
echo "TAG=${GITHUB_REF#refs/*/}" >> $GITHUB_ENV | ||
echo "CONDA_FILE=$(ls dist/*.tar.bz2)" >> $GITHUB_ENV | ||
- uses: conda-incubator/setup-miniconda@v3 | ||
with: | ||
miniconda-version: "latest" | ||
- name: conda setup | ||
run: | | ||
conda install -y anaconda-client | ||
- name: conda dev upload | ||
if: contains(env.TAG, 'a') || contains(env.TAG, 'b') || contains(env.TAG, 'rc') | ||
run: | | ||
anaconda --token ${{ secrets.CONDA_UPLOAD_TOKEN }} upload --user pyviz --label=dev $CONDA_FILE | ||
- name: conda main upload | ||
if: (!(contains(env.TAG, 'a') || contains(env.TAG, 'b') || contains(env.TAG, 'rc'))) | ||
run: | | ||
anaconda --token ${{ secrets.CONDA_UPLOAD_TOKEN }} upload --user pyviz --label=dev --label=main $CONDA_FILE | ||
pip_build: | ||
name: Build PyPI | ||
needs: [pixi_lock] | ||
runs-on: "ubuntu-latest" | ||
steps: | ||
- uses: holoviz-dev/holoviz_tasks/pixi_install@v0 | ||
with: | ||
environments: "build" | ||
install: false | ||
download-data: false | ||
- name: Build package | ||
run: pixi run -e build build-pip | ||
- uses: actions/upload-artifact@v4 | ||
if: always() | ||
with: | ||
name: pip | ||
path: dist/ | ||
if-no-files-found: error | ||
pip_install: | ||
name: Install PyPI | ||
runs-on: "ubuntu-latest" | ||
needs: [pip_build] | ||
steps: | ||
- uses: actions/setup-python@v5 | ||
with: | ||
python-version: ${{ env.PYTHON_VERSION }} | ||
- uses: actions/download-artifact@v4 | ||
with: | ||
name: pip | ||
path: dist/ | ||
- name: Install package | ||
run: python -m pip install dist/*.whl | ||
- name: Test package | ||
run: python -c "import $PACKAGE; print($PACKAGE.__version__)" | ||
pip_publish: | ||
name: Publish PyPI | ||
runs-on: ubuntu-latest | ||
needs: [pip_build, waiting_room] | ||
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags/') | ||
steps: | ||
- uses: actions/download-artifact@v4 | ||
with: | ||
name: pip | ||
path: dist/ | ||
- name: Publish to PyPI | ||
uses: pypa/gh-action-pypi-publish@release/v1 | ||
with: | ||
user: ${{ secrets.PPU }} | ||
password: ${{ secrets.PPP }} | ||
repository-url: "https://upload.pypi.org/legacy/" | ||
npm_build: | ||
name: Build NPM | ||
needs: [pixi_lock] | ||
runs-on: "ubuntu-latest" | ||
steps: | ||
- uses: holoviz-dev/holoviz_tasks/pixi_install@v0 | ||
with: | ||
environments: "build" | ||
download-data: false | ||
- name: npm build | ||
run: | | ||
TARBALL=$(pixi run build-npm) | ||
echo "TARBALL=$TARBALL" >> $GITHUB_ENV | ||
- name: npm publish dry-run | ||
run: | | ||
cd $PACKAGE | ||
npm publish --dry-run $TARBALL | ||
cd .. | ||
- uses: actions/upload-artifact@v4 | ||
if: always() | ||
with: | ||
name: npm | ||
if-no-files-found: error | ||
path: ./${{ env.PACKAGE }}/${{ env.TARBALL }} | ||
npm_publish: | ||
name: Publish NPM | ||
runs-on: "ubuntu-latest" | ||
needs: [npm_build, waiting_room] | ||
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags/') | ||
steps: | ||
- uses: actions/download-artifact@v4 | ||
with: | ||
name: npm | ||
- uses: actions/setup-node@v4 | ||
with: | ||
node-version: ${{ env.NODE_VERSION }} | ||
- name: Set environment variables | ||
run: | | ||
echo "TAG=${GITHUB_REF#refs/*/}" >> $GITHUB_ENV | ||
echo "TARBALL=$(ls *.tgz)" >> $GITHUB_ENV | ||
- name: npm setup | ||
run: | | ||
echo "//registry.npmjs.org/:_authToken=${{ secrets.NPM_API_TOKEN }}" > $HOME/.npmrc | ||
npm whoami | ||
npm -v | ||
- name: npm dev deploy | ||
if: contains(env.TAG, 'a') || contains(env.TAG, 'b') || contains(env.TAG, 'rc') | ||
run: | | ||
npm publish --tag dev $TARBALL | ||
- name: npm main deploy | ||
if: (!(contains(env.TAG, 'a') || contains(env.TAG, 'b') || contains(env.TAG, 'rc'))) | ||
run: | | ||
npm publish --tag latest $TARBALL | ||
cdn_build: | ||
name: Build CDN | ||
needs: [pixi_lock] | ||
runs-on: "ubuntu-latest" | ||
steps: | ||
- uses: holoviz-dev/holoviz_tasks/pixi_install@v0 | ||
with: | ||
environments: "build" | ||
install: false | ||
download-data: false | ||
- name: build pyodide wheels | ||
run: | | ||
pixi run build-pyodide --verify-clean | ||
- name: build CDN | ||
run: | | ||
pixi run build-pip | ||
- uses: actions/upload-artifact@v4 | ||
if: always() | ||
with: | ||
name: cdn | ||
if-no-files-found: error | ||
path: | | ||
./panel/dist/ | ||
./panel/package.json | ||
cdn_publish: | ||
name: Publish CDN | ||
runs-on: "ubuntu-latest" | ||
needs: [cdn_build, waiting_room] | ||
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags/') | ||
steps: | ||
- uses: actions/checkout@v4 | ||
with: | ||
fetch-depth: "1" | ||
- uses: actions/download-artifact@v4 | ||
with: | ||
name: cdn | ||
path: panel/ | ||
- name: Deploy to cdn.holoviz.org | ||
env: | ||
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | ||
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||
AWS_DEFAULT_REGION: "us-east-1" | ||
run: python scripts/cdn_upload.py |