docs #618
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: docs | |
on: | |
pull_request: | |
push: | |
branches: | |
- main | |
schedule: | |
- cron: '40 14 * * *' | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.ref }} | |
cancel-in-progress: true | |
jobs: | |
build-and-test: | |
runs-on: "ubuntu-latest" | |
steps: | |
- uses: actions/checkout@v4 | |
- name: set path | |
run: echo "/opt/mambaforge/bin" >> $GITHUB_PATH | |
- name: Fetch conda install script | |
run: | | |
wget https://raw.githubusercontent.com/bioconda/bioconda-common/master/{common,install-and-set-up-conda,configure-conda}.sh | |
- name: Set up bioconda-utils | |
run: bash install-and-set-up-conda.sh | |
- name: Install docs requirements | |
run: | | |
source common.sh | |
eval "$(conda shell.bash hook)" | |
conda activate bioconda | |
conda install -y --file https://raw.githubusercontent.com/bioconda/bioconda-utils/$BIOCONDA_UTILS_TAG/bioconda_utils/bioconda_utils-requirements-docs.txt | |
# This script can be used to reconfigure conda to use the right channel setup. | |
- name: Configure conda | |
run: bash configure-conda.sh | |
- name: restrict number of built recipes | |
if: >- | |
${{ | |
(github.ref != 'refs/heads/main') && | |
(!contains(github.event.head_commit.message, '[build all recipes]')) | |
}} | |
run: | | |
# For testing, use BIOCONDA_FILTER_RECIPES=10 or some small-ish number, | |
# or BIOCONDA_FILTER_RECIPES=".*" or other regex. If these are set, | |
# you'll get warnings like "Problem in conda domain: field is supposed | |
# to use role 'depends', but that role is not in the domain', which is | |
# expected. | |
# | |
# If unset, pages will be built for all recipes. | |
# export BIOCONDA_FILTER_RECIPES=10 | |
echo "BIOCONDA_FILTER_RECIPES=10" >> $GITHUB_ENV | |
- name: build docs | |
run: | | |
eval "$(conda shell.bash hook)" | |
export BIOCONDA_FILTER_RECIPES=${{env.BIOCONDA_FILTER_RECIPES}} | |
conda activate bioconda | |
make clean html SPHINXOPTS="-T -j1" | |
touch build/html/.nojekyll | |
tar -cf docs.tar build/html | |
# Upload the built docs as an artifact for inspection (even on PRs). This | |
# will show up in the Actions web interface. | |
- name: push artifact | |
uses: actions/upload-artifact@v4 | |
with: | |
name: doc | |
path: docs.tar | |
# Start the SSH agent so that subsequent steps don't need additional SSH | |
# setup. The private key has been added as a secret to this repo (the one | |
# running these tests), and the public key has been added as an allowed | |
# deploy key for the bioconda.github.io repo (the one accepting pushes from | |
# this test). Note that this method ensures that the key is never saved to | |
# disk, and GitHub Actions automatically protects the secrets from being | |
# echoed. | |
- name: ssh setup | |
if: ${{ (github.ref == 'refs/heads/main') }} | |
env: | |
SSH_AUTH_SOCK: /tmp/ssh_agent.sock | |
run: | | |
mkdir -p ~/.ssh | |
ssh-keyscan github.com >> ~/.ssh/known_hosts | |
ssh-agent -a $SSH_AUTH_SOCK > /dev/null | |
ssh-add - <<< "${{ secrets.SSH_DEPLOY_KEY }}" | |
# Clone the bioconda.github.io repo, clean it out completely, then copy the | |
# docs just built above into the repo and commit. Uses SSH as set up above. | |
- name: push docs to bioconda.github.io repo | |
if: ${{ (github.ref == 'refs/heads/main') }} | |
env: | |
SSH_AUTH_SOCK: /tmp/ssh_agent.sock | |
run: | | |
here=$(pwd) | |
REPODIR=/tmp/bioconda.github.io | |
git clone [email protected]:bioconda/bioconda.github.io $REPODIR | |
cd $REPODIR | |
git checkout master | |
git rm -rf $REPODIR/* | |
cp -r $here/build/html/* $REPODIR | |
git add -f . | |
# Only commit and push if there are changes. | |
if git diff origin/master --quiet; then | |
echo "no changes to push to docs repo"; | |
else | |
echo "Diffs will be pushed to bioconda.github.io" | |
git config --global user.email "[email protected]" | |
git config --global user.name "GitHub Action" | |
git commit -m "Updated docs to commit ${GITHUB_SHA}" | |
git push origin master --force | |
fi |