K Framework Release feature/pypi-publishing #1308
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: 'Release' | |
run-name: K Framework Release ${{ github.ref_name }} | |
on: | |
push: | |
branches: | |
- feature/pypi-publishing | |
release: | |
types: | |
- prereleased | |
# concurrency: | |
# group: ${{ github.workflow }} | |
jobs: | |
set-release-id: | |
name: 'Set Release ID' | |
runs-on: ubuntu-20.04 | |
steps: | |
- name: 'Get release_id' | |
run: echo "release_id=$(jq --raw-output '.release.id' $GITHUB_EVENT_PATH)" >> ${GITHUB_OUTPUT} | |
id: release | |
outputs: | |
release_id: ${{ steps.release.outputs.release_id }} | |
source-tarball: | |
name: 'Create source tarball' | |
runs-on: ubuntu-latest | |
environment: production | |
steps: | |
- name: 'Check out code' | |
uses: actions/checkout@v4 | |
with: | |
submodules: recursive | |
# - name: 'Create source tarball' | |
# env: | |
# GITHUB_TOKEN: ${{ secrets.JENKINS_GITHUB_PAT }} | |
# run: | | |
# set -x | |
# version=$(cat package/version) | |
# tarball=kframework-${version}-src.tar.gz | |
# find . -name .git | xargs rm -r | |
# CURDIR=$(pwd) | |
# cd .. | |
# tar czvf ${tarball} $(basename ${CURDIR}) | |
# mv ${tarball} ${CURDIR}/ | |
# cd ${CURDIR} | |
# gh release upload --repo runtimeverification/k --clobber v${version} ${tarball} | |
# cachix-release: | |
# name: 'k-framework-binary cachix release' | |
# strategy: | |
# matrix: | |
# include: | |
# - runner: ubuntu-20.04 | |
# os: ubuntu-20.04 | |
# - runner: macos-13 | |
# os: macos-13 | |
# - runner: MacM1 | |
# os: self-macos-12 | |
# runs-on: ${{ matrix.runner }} | |
# timeout-minutes: 120 | |
# steps: | |
# - name: 'Check out code' | |
# uses: actions/checkout@v4 | |
# - name: 'Install Nix' | |
# if: ${{ !startsWith(matrix.os, 'self') }} | |
# uses: cachix/install-nix-action@v22 | |
# with: | |
# install_url: https://releases.nixos.org/nix/nix-2.13.3/install | |
# extra_nix_config: | | |
# access-tokens = github.com=${{ secrets.GITHUB_TOKEN }} | |
# substituters = http://cache.nixos.org https://hydra.iohk.io | |
# trusted-public-keys = cache.nixos.org-1:6NCHdD59X431o0gWypbMrAURkbJ16ZPMQFGspcDShjY= hydra.iohk.io:f/Ea+s+dFdN+3Y/G+FDgSq+a5NEWhJGzdjvKNGv0/EQ= | |
# - name: 'Install Cachix' | |
# if: ${{ !startsWith(matrix.os, 'self') }} | |
# uses: cachix/cachix-action@v14 | |
# with: | |
# name: k-framework-binary | |
# - name: 'Publish K to k-framework-binary cache' | |
# uses: workflow/[email protected] | |
# env: | |
# CACHIX_AUTH_TOKEN: '${{ secrets.CACHIX_PRIVATE_KFB_TOKEN }}' | |
# GC_DONT_GC: '1' | |
# with: | |
# packages: jq | |
# script: | | |
# export PATH="$(nix build github:runtimeverification/kup --no-link --json | jq -r '.[].outputs | to_entries[].value')/bin:$PATH" | |
# kup publish k-framework-binary .#k --keep-days 180 | |
# kup publish k-framework-binary .#k.openssl.procps.secp256k1 --keep-days 180 | |
# ubuntu-jammy: | |
# name: 'K Ubuntu Jammy Package' | |
# runs-on: [self-hosted, linux, normal] | |
# timeout-minutes: 90 | |
# steps: | |
# - uses: actions/checkout@v4 | |
# - name: 'Build and Test Package' | |
# uses: ./.github/actions/test-package | |
# with: | |
# os: ubuntu | |
# distro: jammy | |
# llvm: 15 | |
# pkg-name: kframework_amd64_ubuntu_jammy.deb | |
# build-package: package/debian/build-package jammy | |
# test-package: package/debian/test-package | |
# - name: 'Upload Package to Release' | |
# env: | |
# GITHUB_TOKEN: ${{ secrets.JENKINS_GITHUB_PAT }} | |
# run: | | |
# set -x | |
# version=$(cat package/version) | |
# cp kframework_amd64_ubuntu_jammy.deb kframework_${version}_amd64_ubuntu_jammy.deb | |
# gh release upload --repo runtimeverification/k --clobber v${version} kframework_${version}_amd64_ubuntu_jammy.deb | |
# - name: 'Build, Test, and Push Dockerhub Image' | |
# shell: bash {0} | |
# env: | |
# DOCKERHUB_PASSWORD: ${{ secrets.DOCKERHUB_PASSWORD }} | |
# DOCKERHUB_REPO: runtimeverificationinc/kframework-k | |
# run: | | |
# set -euxo pipefail | |
# version=$(cat package/version) | |
# version_tag=ubuntu-jammy-${version} | |
# docker login --username rvdockerhub --password ${DOCKERHUB_PASSWORD} | |
# docker image build . --file package/docker/Dockerfile.ubuntu-jammy --tag ${DOCKERHUB_REPO}:${version_tag} | |
# docker run --name k-package-docker-test-jammy-${GITHUB_SHA} --rm -it --detach ${DOCKERHUB_REPO}:${version_tag} | |
# docker exec -t k-package-docker-test-jammy-${GITHUB_SHA} bash -c 'cd ~ && echo "module TEST imports BOOL endmodule" > test.k' | |
# docker exec -t k-package-docker-test-jammy-${GITHUB_SHA} bash -c 'cd ~ && kompile test.k --backend llvm' | |
# docker exec -t k-package-docker-test-jammy-${GITHUB_SHA} bash -c 'cd ~ && kompile test.k --backend haskell' | |
# docker exec -t k-package-docker-test-jammy-${GITHUB_SHA} bash -c 'cd ~ && pykframework kompile test.k --backend llvm' | |
# docker exec -t k-package-docker-test-jammy-${GITHUB_SHA} bash -c 'cd ~ && pykframework kompile test.k --backend haskell' | |
# docker image push ${DOCKERHUB_REPO}:${version_tag} | |
# - name: 'Clean up Docker Container' | |
# if: always() | |
# run: | | |
# docker stop --time=0 k-package-docker-test-jammy-${GITHUB_SHA} | |
# - name: On Failure, Upload the kore-exec.tar.gz file to the Summary Page | |
# if: failure() | |
# uses: actions/upload-artifact@v4 | |
# with: | |
# name: kore-exec.tar.gz | |
# path: | | |
# **/kore-exec.tar.gz | |
# macos-build: | |
# name: 'Build MacOS Package' | |
# runs-on: macos-14 | |
# timeout-minutes: 120 | |
# environment: production | |
# needs: [set-release-id, source-tarball] | |
# steps: | |
# - name: Check out code | |
# uses: actions/checkout@v4 | |
# with: | |
# submodules: recursive | |
# path: kframework | |
# - name: Check out matching homebrew repo branch | |
# uses: actions/checkout@v4 | |
# id: checkout | |
# with: | |
# repository: runtimeverification/homebrew-k | |
# path: homebrew-k | |
# ref: staging | |
# continue-on-error: true | |
# - name: Check out homebrew repo master branch | |
# uses: actions/checkout@v4 | |
# if: ${{ steps.checkout.outcome == 'failure' }} | |
# with: | |
# repository: runtimeverification/homebrew-k | |
# path: homebrew-k | |
# - name: Cache maven | |
# uses: actions/cache@v4 | |
# with: | |
# path: ~/.m2/repository | |
# key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }}- | |
# restore-keys: | | |
# ${{ runner.os }}-maven- | |
# - name: Mac Dependencies | |
# run: | | |
# # Via: https://github.com/ledger/ledger/commit/1eec9f86667cad3b0bbafb82a83739a0d30ca09f | |
# # Unlink and re-link to prevent errors when github mac runner images | |
# # install python outside of brew, for example: | |
# # https://github.com/orgs/Homebrew/discussions/3895 | |
# # https://github.com/actions/setup-python/issues/577 | |
# # https://github.com/actions/runner-images/issues/6459 | |
# # https://github.com/actions/runner-images/issues/6507 | |
# # https://github.com/actions/runner-images/issues/2322 | |
# brew list -1 | grep python | while read formula; do brew unlink $formula; brew link --overwrite $formula; done | |
# - name: Build brew bottle | |
# id: build | |
# env: | |
# HOMEBREW_NO_INSTALLED_DEPENDENTS_CHECK: 1 | |
# MAVEN_OPTS: >- | |
# -Dhttp.keepAlive=false | |
# -Dmaven.wagon.http.pool=false | |
# -Dmaven.wagon.httpconnectionManager.ttlSeconds=30 | |
# run: | | |
# PACKAGE=kframework | |
# VERSION=$(cat kframework/package/version) | |
# ROOT_URL='https://github.com/runtimeverification/k/releases/download' | |
# wget "$ROOT_URL/v${VERSION}/kframework-${VERSION}-src.tar.gz" | |
# cd homebrew-k | |
# ../kframework/package/macos/brew-update-to-local ${PACKAGE} ${VERSION} | |
# git commit Formula/$PACKAGE.rb -m "Update ${PACKAGE} to ${VERSION}: part 1" | |
# ../kframework/package/macos/brew-build-and-update-to-local-bottle ${PACKAGE} ${VERSION} ${ROOT_URL} | |
# git reset HEAD^ | |
# LOCAL_BOTTLE_NAME=$(basename $(find . -name "kframework--${VERSION}.arm64_sonoma.bottle*.tar.gz")) | |
# BOTTLE_NAME=$(echo ${LOCAL_BOTTLE_NAME#./} | sed 's!kframework--!kframework-!') | |
# ../kframework/package/macos/brew-update-to-final ${PACKAGE} ${VERSION} ${ROOT_URL} | |
# echo "path=${LOCAL_BOTTLE_NAME}" >> ${GITHUB_OUTPUT} | |
# echo "path_remote=${BOTTLE_NAME}" >> ${GITHUB_OUTPUT} | |
# echo "version=${VERSION}" >> ${GITHUB_OUTPUT} | |
# - name: Upload bottle | |
# uses: actions/upload-artifact@v4 | |
# with: | |
# name: homebrew | |
# path: homebrew-k | |
# - name: Delete Release | |
# if: failure() | |
# uses: actions/github-script@v7 | |
# with: | |
# github-token: ${{secrets.GITHUB_TOKEN}} | |
# script: | | |
# const { owner, repo } = context.repo | |
# await github.rest.repos.deleteRelease({ owner, repo, release_id: ${{ needs.set-release-id.outputs.release_id }} }) | |
# outputs: | |
# bottle_path: ${{ steps.build.outputs.path }} | |
# bottle_path_remote: ${{ steps.build.outputs.path_remote }} | |
# version: ${{ steps.build.outputs.version }} | |
# macos-test: | |
# name: 'Test MacOS Package' | |
# runs-on: macos-14 | |
# timeout-minutes: 60 | |
# environment: production | |
# needs: [macos-build, set-release-id] | |
# steps: | |
# - name: 'Check out matching homebrew repo branch' | |
# uses: actions/checkout@v4 | |
# id: checkout | |
# with: | |
# repository: runtimeverification/homebrew-k | |
# token: ${{ secrets.JENKINS_GITHUB_PAT }} | |
# path: homebrew-k | |
# ref: staging | |
# continue-on-error: true | |
# - name: 'Check out homebrew repo master branch' | |
# uses: actions/checkout@v4 | |
# if: ${{ steps.checkout.outcome == 'failure' }} | |
# with: | |
# repository: runtimeverification/homebrew-k | |
# token: ${{ secrets.JENKINS_GITHUB_PAT }} | |
# path: homebrew-k | |
# - name: 'Download bottle' | |
# uses: actions/download-artifact@v4 | |
# with: | |
# name: homebrew | |
# path: homebrew-k-old | |
# - name: Mac Dependencies | |
# run: | | |
# # Via: https://github.com/ledger/ledger/commit/1eec9f86667cad3b0bbafb82a83739a0d30ca09f | |
# # Unlink and re-link to prevent errors when github mac runner images | |
# # install python outside of brew, for example: | |
# # https://github.com/orgs/Homebrew/discussions/3895 | |
# # https://github.com/actions/setup-python/issues/577 | |
# # https://github.com/actions/runner-images/issues/6459 | |
# # https://github.com/actions/runner-images/issues/6507 | |
# # https://github.com/actions/runner-images/issues/2322 | |
# brew list -1 | grep python | while read formula; do brew unlink $formula; brew link --overwrite $formula; done | |
# - name: 'Test brew bottle' | |
# id: test | |
# env: | |
# # github actions sets the JAVA_HOME variable to Java 8 explicitly for | |
# # some reason. There doesn't seem to be a way to tell it to unset the | |
# # variable, so instead we just have to tell it to use Java 17 | |
# # explicitly instead. | |
# JAVA_HOME: ${{ env.JAVA_HOME_17_X64 }} | |
# HOMEBREW_NO_INSTALLED_DEPENDENTS_CHECK: 1 | |
# run: | | |
# # The macOS public runners are prone to flakiness when running this | |
# # test suite, so the PL-tutorial is disabled for now. | |
# # - https://github.com/runtimeverification/k/issues/3705 | |
# cd homebrew-k-old | |
# brew tap runtimeverification/k "file:///$(pwd)" | |
# brew install ${{ needs.macos-build.outputs.bottle_path }} -v | |
# # cp -R /usr/local/share/kframework/pl-tutorial ~ | |
# # WD=`pwd` | |
# # cd | |
# # echo 'Starting kserver...' | |
# # spawn-kserver $WD/kserver.log | |
# # cd pl-tutorial | |
# # echo 'Testing tutorial in user environment...' | |
# # make -j`sysctl -n hw.ncpu` ${MAKE_EXTRA_ARGS} | |
# # cd ~ | |
# echo 'module TEST imports BOOL endmodule' > test.k | |
# kompile test.k --backend llvm | |
# kompile test.k --backend haskell | |
# - name: 'Check out code' | |
# uses: actions/checkout@v4 | |
# with: | |
# path: k-homebrew-checkout | |
# token: ${{ secrets.JENKINS_GITHUB_PAT }} | |
# - name: 'Upload Package to Release' | |
# env: | |
# GITHUB_TOKEN: ${{ secrets.JENKINS_GITHUB_PAT }} | |
# BOTTLE_NAME: ${{ needs.macos-build.outputs.bottle_path }} | |
# REMOTE_BOTTLE_NAME: ${{ needs.macos-build.outputs.bottle_path_remote }} | |
# run: | | |
# set -x | |
# version=$(cat k-homebrew-checkout/package/version) | |
# mv homebrew-k-old/${BOTTLE_NAME} homebrew-k-old/${REMOTE_BOTTLE_NAME} | |
# gh release upload --repo runtimeverification/k --clobber v${version} homebrew-k-old/${REMOTE_BOTTLE_NAME} | |
# - run: | | |
# git config --global user.name rv-jenkins | |
# git config --global user.email [email protected] | |
# - name: 'Commit changes' | |
# run: | | |
# cp homebrew-k-old/Formula/kframework.rb homebrew-k/Formula/kframework.rb | |
# cd homebrew-k | |
# git commit -m 'Update brew package version' Formula/kframework.rb | |
# git push origin master | |
# - name: 'Delete Release' | |
# if: failure() | |
# uses: actions/github-script@v7 | |
# with: | |
# github-token: ${{secrets.GITHUB_TOKEN}} | |
# script: | | |
# const { owner, repo } = context.repo | |
# await github.rest.repos.deleteRelease({ owner, repo, release_id: ${{ needs.set-release-id.outputs.release_id }} }) | |
pykframework-publish: | |
name: 'Publish pykframework' | |
runs-on: [self-hosted, linux, flyweight] | |
environment: production | |
permissions: | |
id-token: write | |
needs: [set-release-id, source-tarball] | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: Setup Python | |
uses: actions/[email protected] | |
with: | |
python-version: '3.10' | |
- name: Install Poetry | |
uses: Gr1N/setup-poetry@v9 | |
with: | |
python-version: '3.10' | |
- name: Setup Caching | |
uses: actions/cache@v4 | |
with: | |
path: ~/.cache/poetry/virtualenvs | |
key: ${{ runner.os }}-poetry-${{ hashFiles('pykframework/pyproject.toml') }} | |
restore-keys: | | |
${{ runner.os }}-poetry- | |
- name: Build pykframework | |
working-directory: pykframeworkframework | |
run: | | |
make build | |
- name: Publish pykframework to PypI | |
uses: pypa/[email protected] | |
with: | |
packages-dir: pykframework/dist | |
user: __token__ | |
password: ${{ secrets.PYPI_TOKEN }} | |
# release: | |
# name: 'Publish Release' | |
# runs-on: [self-hosted, linux, normal] | |
# environment: production | |
# needs: [cachix-release, macos-build, macos-test, source-tarball, ubuntu-jammy, set-release-id] | |
# steps: | |
# - name: 'Check out code' | |
# uses: actions/checkout@v4 | |
# with: | |
# submodules: recursive | |
# - name: Set up Java for publishing to GitHub Maven Packages | |
# uses: actions/setup-java@v4 | |
# with: | |
# java-version: '11' | |
# distribution: 'adopt' | |
# overwrite-settings: true | |
# server-id: runtime.verification.snapshots | |
# server-username: MAVEN_USERNAME | |
# server-password: MAVEN_PASSWORD | |
# # Build and Run Tests in Docker | |
# - name: 'Set up Docker' | |
# uses: ./.github/actions/with-docker | |
# with: | |
# tag: k-release-ci-${{ github.sha }} | |
# os: ubuntu | |
# distro: jammy | |
# llvm: 15 | |
# - name: 'Push Maven Packages' | |
# shell: bash {0} | |
# continue-on-error: true | |
# env: | |
# MAVEN_USERNAME: [email protected] | |
# MAVEN_PASSWORD: ${{ secrets.CLOUDREPO_PASSWORD }} | |
# run: | | |
# cat ~/.m2/settings.xml | |
# docker exec -t k-release-ci-${GITHUB_SHA} bash -c 'mkdir -p /home/github-runner/.m2' | |
# docker cp ~/.m2/settings.xml k-release-ci-${GITHUB_SHA}:/tmp/settings.xml | |
# docker exec -t k-release-ci-${GITHUB_SHA} bash -c 'mv /tmp/settings.xml /home/github-runner/.m2/settings.xml' | |
# docker exec -e MAVEN_USERNAME -e MAVEN_PASSWORD -t k-release-ci-${GITHUB_SHA} bash -c "mvn --batch-mode deploy" | |
# - name: 'Tear down Docker' | |
# if: always() | |
# run: | | |
# docker stop --time=0 k-release-ci-${GITHUB_SHA} | |
# docker container rm --force k-release-ci-${GITHUB_SHA} || true | |
# - name: Publish release | |
# uses: actions/github-script@v7 | |
# with: | |
# github-token: ${{secrets.GITHUB_TOKEN}} | |
# script: | | |
# const { owner, repo } = context.repo | |
# await github.rest.repos.updateRelease({ owner, repo, release_id: ${{ needs.set-release-id.outputs.release_id }}, prerelease: false }) | |
# - name: 'Update dependents' | |
# env: | |
# GITHUB_TOKEN: ${{ secrets.JENKINS_GITHUB_PAT }} | |
# VERSION: ${{ needs.macos-build.outputs.version }} | |
# run: | | |
# set -x | |
# version=v"${VERSION}" | |
# curl --fail \ | |
# -X POST \ | |
# -H "Accept: application/vnd.github+json" \ | |
# -H "Authorization: Bearer ${GITHUB_TOKEN}" \ | |
# -H "X-GitHub-Api-Version: 2022-11-28" \ | |
# https://api.github.com/repos/runtimeverification/devops/dispatches \ | |
# -d '{"event_type":"on-demand-test","client_payload":{"repo":"runtimeverification/k","version":"'${VERSION}'"}}' | |
# gh-pages: | |
# name: 'GitHub Pages deployment' | |
# runs-on: ubuntu-20.04 | |
# timeout-minutes: 30 | |
# needs: [release] | |
# steps: | |
# - name: 'Install pandoc/texlive/calibre' | |
# run: | | |
# sudo apt update --yes | |
# sudo apt install --yes wget texlive-xetex libegl1 libopengl0 | |
# sudo wget -nv -O- https://download.calibre-ebook.com/linux-installer.sh | sh /dev/stdin version=6.29.0 | |
# sudo wget https://github.com/jgm/pandoc/releases/download/2.18/pandoc-2.18-1-amd64.deb -O /tmp/pandoc.deb | |
# sudo dpkg -i /tmp/pandoc.deb | |
# - name: 'Checkout code and set up web build' | |
# uses: actions/checkout@v4 | |
# with: | |
# submodules: recursive | |
# path: gh-pages | |
# token: ${{ secrets.JENKINS_GITHUB_PAT }} | |
# fetch-depth: 0 | |
# - name: 'Install Python' | |
# uses: actions/setup-python@v5 | |
# with: | |
# python-version: '3.10' | |
# - name: 'Install Poetry' | |
# uses: Gr1N/setup-poetry@v9 | |
# - name: 'Checkout PL Tutorial code' | |
# uses: actions/checkout@v4 | |
# with: | |
# repository: runtimeverification/pl-tutorial | |
# path: gh-pages/k-distribution/pl-tutorial | |
# token: ${{ secrets.JENKINS_GITHUB_PAT }} | |
# - working-directory: gh-pages | |
# run: | | |
# git config --global user.name rv-jenkins | |
# git config --global user.email [email protected] | |
# git checkout --orphan gh-pages origin/master | |
# - name: 'Build webpage' | |
# working-directory: gh-pages | |
# run: | | |
# export PATH="$PATH":/opt/calibre | |
# cd web | |
# npm install | |
# npm run build | |
# npm run build-book | |
# npm run build-sitemap | |
# cd - | |
# mv web/public_content ./ | |
# cd pykframework | |
# make docs | |
# cd - | |
# mkdir public_content/pykframework | |
# cp -r pykframework/docs/build/html/* public_content/pykframework | |
# rm -rf $(find . -maxdepth 1 -not -name public_content -a -not -name .git -a -not -path . -a -not -path .. -a -not -name CNAME) | |
# mv public_content/* ./ | |
# rm -rf public_content | |
# touch .nojekyll | |
# - name: 'Push gh-pages branch' | |
# working-directory: gh-pages | |
# run: | | |
# set -x | |
# git add ./ | |
# git commit -m 'gh-pages: Updated the website' | |
# git push --force origin gh-pages |