Skip to content

Update dependencies. #1021

Update dependencies.

Update dependencies. #1021

Workflow file for this run

on: [push, pull_request]
name: Build & publish
jobs:
build:
if: ${{ !contains(github.event.head_commit.message, 'skip ci') }}
runs-on: ubuntu-latest
env:
RELEASE_BRANCH: ${{ startsWith(github.event.ref, 'refs/heads/develop-') || startsWith(github.event.ref, 'refs/heads/release-') }}
steps:
- name: Check out source code
uses: actions/checkout@v4
with:
fetch-depth: 0
submodules: recursive
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: '3.x'
- name: Install dependencies
run: |
python -m pip install --upgrade pip build
sudo apt update
sudo apt-get install flex bison ccache
- name: Set up caching
uses: actions/cache@v4
with:
path: ~/.cache/ccache
key: yosys-${{ hashFiles('yosys-src', 'SymbiYosys-src', 'build.sh') }}
restore-keys: |
yosys-${{ hashFiles('yosys-src', 'SymbiYosys-src', 'build.sh') }}
yosys-
- name: Set up ccache
run: |
ccache --max-size=2G -z
- name: Build WASM binaries
run: |
MAKEFLAGS=-j$(nproc) ./build.sh
- name: Build Python artifact
run: |
./package-pypi.sh
- name: Upload Python artifact
uses: actions/upload-artifact@v4
with:
name: dist-pypi
path: pypi/dist/
- name: Build JavaScript artifact
run: |
./package-npmjs.sh
cp npmjs/test/test_api.mjs npmjs/dist/
- name: Upload JavaScript artifact
uses: actions/upload-artifact@v4
with:
name: dist-npmjs
path: npmjs/dist/
- name: Print ccache statistics
run: |
ccache -s
test-python:
needs: build
runs-on: ubuntu-latest
strategy:
matrix:
python-version:
- '3.7'
- '3.8'
- '3.9'
- '3.10'
- '3.11'
- '3.12-dev'
steps:
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
- name: Download Python artifact
uses: actions/download-artifact@v4
with:
name: dist-pypi
path: dist/
- name: Test Python artifact
run: |
pip install dist/*.whl
yowasp-yosys --help
yowasp-sby --help
yowasp-yosys-smtbmc --help
yowasp-yosys-witness --help
test-javascript:
needs: build
runs-on: ubuntu-latest
strategy:
matrix:
node-version:
- 'v18.x'
- 'v20.x'
steps:
- name: Set up Node.js
uses: actions/setup-node@v4
with:
node-version: ${{ matrix.node-version }}
- name: Download JavaScript artifact
uses: actions/download-artifact@v4
with:
name: dist-npmjs
path: dist/
- name: Test JavaScript artifact
run: |
npm install ./dist/*.tgz
node dist/test_api.mjs
check: # group all `test (*)` workflows into one for the required status check
needs: [test-python, test-javascript]
if: ${{ always() && !contains(needs.*.result, 'cancelled') }}
runs-on: ubuntu-latest
steps:
- run: ${{ contains(needs.*.result, 'failure') && 'false' || 'true' }}
publish-python:
needs: check
runs-on: ubuntu-latest
environment: publish
permissions:
id-token: write
if: ${{ !contains(github.event.head_commit.message, 'skip py') }}
steps:
- name: Download Python artifact
uses: actions/download-artifact@v4
with:
name: dist-pypi
path: dist/
- name: Publish wheels to Test PyPI
if: ${{ github.event_name == 'push' && startsWith(github.event.ref, 'refs/heads/develop') }}
uses: pypa/gh-action-pypi-publish@release/v1
with:
repository-url: https://test.pypi.org/legacy/
- name: Publish wheels to PyPI
if: ${{ github.event_name == 'push' && startsWith(github.event.ref, 'refs/heads/release') }}
uses: pypa/gh-action-pypi-publish@release/v1
publish-javascript:
needs: check
runs-on: ubuntu-latest
environment: publish
permissions:
id-token: write
if: ${{ !contains(github.event.head_commit.message, 'skip js') }}
steps:
- name: Set up Node.js
uses: actions/setup-node@v4
with:
registry-url: 'https://registry.npmjs.org'
- name: Download JavaScript artifact
uses: actions/download-artifact@v4
with:
name: dist-npmjs
path: dist/
- name: Publish package to NPM (dry run)
if: ${{ github.event_name == 'push' && startsWith(github.event.ref, 'refs/heads/develop') }}
run: npm publish --access public $(find dist -name *.tgz -printf 'file:%p ') --dry-run
- name: Publish package to NPM
if: ${{ github.event_name == 'push' && startsWith(github.event.ref, 'refs/heads/release') }}
run: npm publish --access public $(find dist -name *.tgz -printf 'file:%p ') ${{ github.event.ref == 'refs/heads/release' && '--tag latest' || '--tag release' }}
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
NPM_CONFIG_PROVENANCE: true
release:
needs: check
runs-on: ubuntu-latest
if: ${{ contains(github.event.head_commit.message, 'autorelease') && github.event_name == 'push' && startsWith(github.event.ref, 'refs/heads/develop') }}
steps:
- name: Check out source code
uses: actions/checkout@v4
with:
fetch-depth: 0
token: ${{ secrets.PUSH_TOKEN }}
- name: Update release branch
run: |
release_branch=${{ github.event.ref }}
release_branch=${release_branch/develop/release}
git push origin HEAD:${release_branch}