add release note (#11395) #11
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: Documentation | |
on: | |
push: | |
branches: | |
- main | |
tags: | |
# Only match non-prerelease tags. | |
- '[0-9]+.[0-9]+.[0-9]' | |
workflow_dispatch: | |
inputs: | |
deploy_prefix: | |
description: "Deployment prefix (leave blank for the root): https://qiskit.org/documentation/<prefix>." | |
required: false | |
type: string | |
do_deployment: | |
description: "Push to qiskit.org?" | |
required: false | |
type: boolean | |
jobs: | |
build: | |
if: github.repository_owner == 'Qiskit' | |
name: Build | |
runs-on: ubuntu-latest | |
outputs: | |
latest_tag: ${{ steps.latest_tag.outputs.latest_tag }} | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
# We need to fetch the whole history so 'reno' can do its job and we can inspect tags. | |
fetch-depth: 0 | |
- name: Determine latest full release tag | |
id: latest_tag | |
run: | | |
set -e | |
latest_tag=$(git tag --list --sort=-version:refname | sed -n '/^[0-9]\+\.[0-9]\+\.[0-9]\+$/p' | head -n 1) | |
echo "Latest release tag: '$latest_tag'" | |
echo "latest_tag=$latest_tag" >> "$GITHUB_OUTPUT" | |
- uses: actions/setup-python@v4 | |
name: Install Python | |
with: | |
# Sync with 'documentationPythonVersion' in 'azure-pipelines.yml'. | |
python-version: '3.9' | |
- name: Install dependencies | |
run: tools/install_ubuntu_docs_dependencies.sh | |
- name: Build documentation | |
run: tox run -e docs | |
- name: Store built documentation artifact | |
uses: actions/upload-artifact@v3 | |
with: | |
name: qiskit-docs | |
path: | | |
./docs/_build/html/* | |
!**/.doctrees | |
!**/.buildinfo | |
if-no-files-found: error | |
deploy: | |
if: github.event_name != 'workflow_dispatch' || inputs.do_deployment | |
name: Deploy to qiskit.org | |
needs: [build] | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
path: qiskit | |
- uses: actions/download-artifact@v3 | |
with: | |
name: qiskit-docs | |
path: deploy | |
- id: choose | |
name: Choose deployment location(s) | |
run: | | |
set -e | |
declare -a prefixes | |
case ${{ github.event_name }} in | |
push) | |
case ${{ github.ref_type }} in | |
branch) | |
if [[ "$GITHUB_REF_NAME" != "main" ]]; then | |
echo "Push to unhandled branch '$GITHUB_REF_NAME'" >&2 | |
exit 1 | |
fi | |
prefixes+=( "dev" ) | |
;; | |
tag) | |
tag=$GITHUB_REF_NAME | |
echo "Full tag: ${tag}" | |
IFS=. read -ra version <<< "$tag" | |
minor_version="${version[0]}.${version[1]}" | |
echo "Minor version: ${minor_version}" | |
prefixes+=( "stable/${minor_version}" ) | |
if [[ "$tag" == "$LATEST_TAG" ]]; then | |
# Deploy to the root as well. | |
prefixes+=( "" ) | |
fi | |
;; | |
*) | |
echo "Unhandled reference type '${{ github.ref_type }}'" >&2 | |
exit 1 | |
;; | |
esac | |
;; | |
workflow_dispatch) | |
prefixes+=( "$WORKFLOW_DISPATCH_PREFIX" ) | |
;; | |
*) | |
echo "Unhandled GitHub event ${{ github.event_name }}" >&2 | |
exit 1 | |
;; | |
esac | |
# Join the array of prefixes into a colon-delimited list for | |
# serialisation. This includes a trailing colon, so we can detect | |
# the presence of the empty string, even if it's the only prefix. | |
if [[ "${#prefixes[@]}" -gt 0 ]]; then | |
joined_prefixes=$(printf "%s:" "${prefixes[@]}") | |
echo "Chosen deployment prefixes: '$joined_prefixes'" | |
echo "joined_prefixes=$joined_prefixes" >> "$GITHUB_OUTPUT" | |
else | |
echo "Nothing to deploy to." | |
fi | |
env: | |
LATEST_TAG: ${{ needs.build.outputs.latest_tag }} | |
GITHUB_REF_NAME: ${{ github.ref_name }} | |
WORKFLOW_DISPATCH_PREFIX: ${{ inputs.deploy_prefix }} | |
- name: Install rclone | |
run: | | |
set -e | |
curl https://downloads.rclone.org/rclone-current-linux-amd64.deb -o rclone.deb | |
sudo apt-get install -y ./rclone.deb | |
- name: Deploy to qiskit.org | |
if: ${{ steps.choose.outputs.joined_prefixes != '' }} | |
run: | | |
set -e | |
RCLONE_CONFIG=$(rclone config file | tail -1) | |
openssl aes-256-cbc -K "$RCLONE_KEY" -iv "$RCLONE_IV" -in qiskit/tools/rclone.conf.enc -out "$RCLONE_CONFIG" -d | |
IFS=: read -ra prefixes <<< "$JOINED_PREFIXES" | |
for prefix in "${prefixes[@]}"; do | |
# The 'documentation' bit of the prefix is hard-coded in this step | |
# rather than being chosen during the prefix-choosing portion | |
# because we don't want to allow the 'workflow_dispatch' event | |
# trigger to accidentally allow a deployment to a dodgy prefix that | |
# wipes out _everything_ on qiskit.org. | |
location=documentation/$prefix | |
echo "Deploying to 'qiskit.org/$location'" | |
rclone sync --progress --exclude-from qiskit/tools/docs_exclude.txt deploy "IBMCOS:qiskit-org-web-resources/$location" | |
done | |
env: | |
JOINED_PREFIXES: ${{ steps.choose.outputs.joined_prefixes }} | |
RCLONE_KEY: ${{ secrets.ENCRYPTED_RCLONE_KEY}} | |
RCLONE_IV: ${{ secrets.ENCRYPTED_RCLONE_IV }} |