Skip to content

use object store instead of github releases #513

use object store instead of github releases

use object store instead of github releases #513

Workflow file for this run

name: Build
on:
- push
- pull_request
- workflow_dispatch
env:
PKG_URL: https://nbg1.your-objectstorage.com/ipyvue3-packages/packages
permissions:
contents: read
jobs:
lint:
runs-on: ubuntu-22.04
steps:
- uses: actions/checkout@v4
- uses: actions/setup-python@v5
with:
python-version: "3.10"
- uses: pre-commit/action@v3.0.1
build:
runs-on: ubuntu-22.04
steps:
- uses: actions/checkout@v4
- uses: actions/setup-python@v5
with:
python-version: "3.10"
- uses: actions/setup-node@v4
with:
node-version: 18.x
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install "reacton[generate]" ipyvue "jupyterlab<4" build
- name: build wheel
run: python -m build
- name: Build component file
run: |
cp ipyvuetify/components.py ipyvuetify/components-previous.py
python -m ipyvuetify.components
diff ipyvuetify/components.py ipyvuetify/components-previous.py
- name: Package js
run: (cd js && npm pack)
- name: Upload build artifacts
uses: actions/upload-artifact@v4
with:
name: ipyvuetify-dist-${{ github.run_number }}
path: |
./dist
./js/*.tgz
- name: Publish dev artifacts to object storage
if: github.event_name == 'push' && github.ref == 'refs/heads/vuetify3'
env:
AWS_ACCESS_KEY_ID: ${{ secrets.S3_ACCESS_KEY_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.S3_SECRET_ACCESS_KEY }}
AWS_REGION: nbg1
AWS_ENDPOINT_URL_S3: https://nbg1.your-objectstorage.com
S3_BUCKET: ipyvue3-packages
run: |
python -m pip install --upgrade awscli
aws s3 cp dist/ "s3://${S3_BUCKET}/packages/ipyvuetify/" \
--recursive \
--exclude "*" \
--include "*.whl" \
--endpoint-url "$AWS_ENDPOINT_URL_S3" \
--region "$AWS_REGION"
- name: Upload components
uses: actions/upload-artifact@v4
with:
name: ipyvuetify-components-${{ github.run_number }}
path: |
./ipyvuetify/components.py
test:
needs: [lint, build]
runs-on: ubuntu-22.04
strategy:
fail-fast: false
matrix:
python-version: ["3.7", "3.8", "3.9", "3.10", "3.11", "3.12", "3.13"]
steps:
- uses: actions/checkout@v4
- uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
- uses: actions/download-artifact@v4
with:
name: ipyvuetify-dist-${{ github.run_number }}
- name: Install ipyvuetify
run: |
python -m pip install jupyter_core jupyter-packaging "jupyterlab<4" "$(find dist -name '*.whl')"
- name: test import
run: (mkdir test-install; cd test-install; python -c "from ipyvuetify import Btn")
ui-test:
needs: [lint, build]
runs-on: ubuntu-22.04
steps:
- uses: actions/checkout@v4
- uses: actions/setup-python@v5
with:
python-version: "3.10"
- uses: actions/download-artifact@v4
with:
name: ipyvuetify-dist-${{ github.run_number }}
- name: Install ipyvuetify
run: |
python -m pip install pillow==10.4.0 pixelmatch==0.3.0 jupyter_core jupyter-packaging "jupyterlab<4" "$(find dist -name '*.whl')"
python -m pip install pytest "pytest-playwright<0.6"
python -m pip install "solara-ui[all] @ ${PKG_URL}/solara/solara_ui-1.57.3-py3-none-any.whl"
python -m pip install "solara-server[starlette,dev] @ ${PKG_URL}/solara-server/solara_server-1.57.3-py3-none-any.whl"
python -m pip install "pytest-ipywidgets[all] @ ${PKG_URL}/pytest-ipywidgets/pytest_ipywidgets-1.57.3-py3-none-any.whl"
- name: Install chromium
run: playwright install chromium
- name: Run ui-tests
run: pytest tests/ui/ --video=retain-on-failure -s
- name: Upload Test artifacts
if: always()
uses: actions/upload-artifact@v4
with:
name: ipyvuetify-test-results
path: test-results
release-dry-run:
needs: [test]
runs-on: ubuntu-22.04
steps:
- uses: actions/download-artifact@v4
with:
name: ipyvuetify-dist-${{ github.run_number }}
- name: Install node
uses: actions/setup-node@v4
with:
node-version: "18.x"
registry-url: "https://registry.npmjs.org"
# No --dry-run available for twine
# - name: Publish the Python package
- name: Publish the NPM package
run: |
cd js
echo $PRE_RELEASE
if [[ $PRE_RELEASE == "true" ]]; then export TAG="next"; else export TAG="latest"; fi
npm publish --dry-run --tag ${TAG} --access public *.tgz
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
PRE_RELEASE: ${{ github.event.release.prerelease }}
release:
if: startsWith(github.event.ref, 'refs/tags/v')
needs: [release-dry-run]
runs-on: ubuntu-22.04
steps:
- uses: actions/download-artifact@v4
with:
name: ipyvuetify-dist-${{ github.run_number }}
- name: Install node
uses: actions/setup-node@v4
with:
node-version: "18.x"
registry-url: "https://registry.npmjs.org"
- name: Install Python
uses: actions/setup-python@v5
with:
python-version: 3.8
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install twine wheel jupyter-packaging jupyterlab
- name: Publish the Python package
env:
TWINE_USERNAME: __token__
TWINE_PASSWORD: ${{ secrets.PYPI_API_TOKEN }}
run: twine upload --skip-existing dist/*
- name: Publish the NPM package
run: |
cd js
echo $PRE_RELEASE
if [[ $PRE_RELEASE == "true" ]]; then export TAG="next"; else export TAG="latest"; fi
npm publish --tag ${TAG} --access public *.tgz
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
PRE_RELEASE: ${{ github.event.release.prerelease }}