use object store instead of github releases #515
This file contains hidden or 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: 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 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 }} |