-
Notifications
You must be signed in to change notification settings - Fork 50
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #683 from lukpueh/add-cd
build: automate release
- Loading branch information
Showing
5 changed files
with
198 additions
and
67 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,73 @@ | ||
on: | ||
workflow_call: | ||
# Permissions inherited from caller workflow | ||
|
||
permissions: {} | ||
|
||
jobs: | ||
test: | ||
strategy: | ||
fail-fast: false | ||
# Run tests on each OS/Python combination | ||
matrix: | ||
python-version: ["3.8", "3.9", "3.10", "3.11"] | ||
os: [ubuntu-latest, macos-latest, windows-latest] | ||
toxenv: [py] | ||
|
||
include: | ||
- python-version: "3.11" | ||
os: ubuntu-latest | ||
toxenv: purepy311 | ||
- python-version: "3.11" | ||
os: ubuntu-latest | ||
toxenv: py311-no-gpg | ||
- python-version: "3.11" | ||
os: ubuntu-latest | ||
toxenv: py311-test-gpg-fails | ||
- python-version: "3.11" | ||
os: ubuntu-latest | ||
toxenv: lint | ||
|
||
runs-on: ${{ matrix.os }} | ||
|
||
steps: | ||
- name: Checkout securesystemslib | ||
uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 | ||
|
||
- name: Set up Python ${{ matrix.python-version }} | ||
uses: actions/setup-python@65d7f2d534ac1bc67fcd62888c5f4f3d2cb2b236 | ||
with: | ||
python-version: ${{ matrix.python-version }} | ||
cache: "pip" | ||
cache-dependency-path: "requirements*.txt" | ||
|
||
- name: Install dependencies | ||
run: | | ||
python -m pip install --upgrade pip | ||
pip install --upgrade tox | ||
- name: Install system dependencies | ||
shell: bash | ||
run: | | ||
# NOTE: HSM tests are skipped silently, if PYKCS11LIB is unset. | ||
if [ "$RUNNER_OS" == "Linux" ]; then | ||
sudo apt-get install -y softhsm2 | ||
echo "PYKCS11LIB=/usr/lib/softhsm/libsofthsm2.so" >> $GITHUB_ENV | ||
elif [ "$RUNNER_OS" == "macOS" ]; then | ||
brew install softhsm | ||
echo "PYKCS11LIB=$(brew --prefix softhsm)/lib/softhsm/libsofthsm2.so" >> $GITHUB_ENV | ||
elif [ "$RUNNER_OS" == "Windows" ]; then | ||
echo "Skipping HSM tests on Windows" | ||
# see https://github.com/secure-systems-lab/securesystemslib/issues/520 | ||
else | ||
echo "$RUNNER_OS not supported" | ||
exit 1 | ||
fi | ||
- name: Run tox | ||
run: tox -e ${{ matrix.toxenv }} |
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,118 @@ | ||
name: CD | ||
concurrency: cd | ||
|
||
on: | ||
push: | ||
tags: | ||
- v* | ||
|
||
permissions: {} | ||
|
||
jobs: | ||
test: | ||
name: Test | ||
uses: ./.github/workflows/_test.yml | ||
|
||
build: | ||
name: Build | ||
runs-on: ubuntu-latest | ||
needs: test | ||
steps: | ||
- name: Checkout release tag | ||
uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 | ||
with: | ||
ref: ${{ github.event.workflow_run.head_branch }} | ||
|
||
- name: Set up Python | ||
uses: actions/setup-python@65d7f2d534ac1bc67fcd62888c5f4f3d2cb2b236 # v4.7.1 | ||
with: | ||
python-version: '3.x' | ||
|
||
- name: Install build dependency | ||
run: python3 -m pip install -r requirements-build.txt | ||
|
||
- name: Build binary wheel and source tarball | ||
run: python3 -m build --sdist --wheel --outdir dist/ . | ||
|
||
- name: Store build artifacts | ||
uses: actions/upload-artifact@a8a3f3ad30e3422c9c7b888a15615d19a852ae32 # v3.1.3 | ||
# NOTE: The GitHub release page contains the release artifacts too, but using | ||
# GitHub upload/download actions seems robuster: there is no need to compute | ||
# download URLs and tampering with artifacts between jobs is more limited. | ||
with: | ||
name: build-artifacts | ||
path: dist | ||
|
||
candidate_release: | ||
name: Release candidate on Github for review | ||
runs-on: ubuntu-latest | ||
needs: build | ||
permissions: | ||
contents: write # to modify GitHub releases | ||
outputs: | ||
release_id: ${{ steps.gh-release.outputs.result }} | ||
steps: | ||
- name: Fetch build artifacts | ||
uses: actions/download-artifact@9bc31d5ccc31df68ecc42ccf4149144866c47d8a # v3.0.2 | ||
with: | ||
name: build-artifacts | ||
path: dist | ||
|
||
- id: gh-release | ||
name: Publish GitHub release draft | ||
uses: actions/github-script@60a0d83039c74a4aee543508d2ffcb1c3799cdea # v7.0.1 | ||
with: | ||
script: | | ||
fs = require('fs') | ||
res = await github.rest.repos.createRelease({ | ||
owner: context.repo.owner, | ||
repo: context.repo.repo, | ||
name: '${{ github.ref_name }}-rc', | ||
tag_name: '${{ github.ref }}', | ||
body: 'Release waiting for review...', | ||
}); | ||
fs.readdirSync('dist/').forEach(file => { | ||
github.rest.repos.uploadReleaseAsset({ | ||
owner: context.repo.owner, | ||
repo: context.repo.repo, | ||
release_id: res.data.id, | ||
name: file, | ||
data: fs.readFileSync('dist/' + file), | ||
}); | ||
}); | ||
return res.data.id | ||
release: | ||
name: Release | ||
runs-on: ubuntu-latest | ||
needs: candidate_release | ||
environment: release | ||
permissions: | ||
contents: write # to modify GitHub releases | ||
id-token: write # to authenticate as Trusted Publisher to pypi.org | ||
steps: | ||
- name: Fetch build artifacts | ||
uses: actions/download-artifact@9bc31d5ccc31df68ecc42ccf4149144866c47d8a # v3.0.2 | ||
with: | ||
name: build-artifacts | ||
path: dist | ||
|
||
- name: Publish binary wheel and source tarball on PyPI | ||
# Only attempt pypi upload in upstream repository | ||
if: github.repository == 'secure-systems-lab/securesystemslib' | ||
uses: pypa/gh-action-pypi-publish@b7f401de30cb6434a1e19f805ff006643653240e # v1.8.10 | ||
|
||
- name: Finalize GitHub release | ||
uses: actions/github-script@60a0d83039c74a4aee543508d2ffcb1c3799cdea # v7.0.1 | ||
with: | ||
script: | | ||
github.rest.repos.updateRelease({ | ||
owner: context.repo.owner, | ||
repo: context.repo.repo, | ||
release_id: '${{ needs.candidate_release.outputs.release_id }}', | ||
name: '${{ github.ref_name }}', | ||
body: 'See [CHANGELOG.md](https://github.com/' + | ||
context.repo.owner + '/' + context.repo.repo + | ||
'/blob/${{ github.ref_name }}/CHANGELOG.md) for details.' | ||
}) |
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
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
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 @@ | ||
build==1.0.3 |