pkgdown #377
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
# Deploys pkgdown for Pull Requests, tags, and pushes to main branch | |
# PRs are deployed to /preview/pr<number>/ | |
# Tags are deployed to /<tag>/ | |
on: | |
pull_request: | |
branches: | |
- main | |
types: | |
- opened | |
- reopened | |
- synchronize | |
- closed | |
paths: | |
- 'man/**' | |
- 'pkgdown/**' | |
- 'vignettes/**' | |
push: | |
tags: | |
- 'v[0-9]+.[0-9]+.[0-9]+' # build on version tags | |
- '!v[0-9]+.[0-9]+.[0-9]+.[0-9]+' # but not if version involves a dev component | |
branches: | |
- main | |
workflow_dispatch: | |
inputs: | |
tag: | |
description: Tag to deploy | |
required: true | |
default: '' | |
name: pkgdown | |
jobs: | |
pkgdown-build: | |
runs-on: ubuntu-latest | |
if: ${{ !(github.event_name == 'pull_request' && github.event.action == 'closed') }} | |
env: | |
GITHUB_PAT: ${{ secrets.GITHUB_TOKEN }} | |
steps: | |
- uses: actions/checkout@v2 | |
- name: Configure git | |
run: | | |
git config --local user.name "$GITHUB_ACTOR" | |
git config --local user.email "$GITHUB_ACTOR@users.noreply.github.com" | |
- uses: r-lib/actions/pr-fetch@v2 | |
if: ${{ github.event_name == 'pull_request' }} | |
with: | |
repo-token: ${{ github.token }} | |
- uses: r-lib/actions/setup-pandoc@v2 | |
- uses: r-lib/actions/setup-r@v2 | |
with: | |
use-public-rspm: true | |
- uses: r-lib/actions/setup-r-dependencies@v2 | |
with: | |
needs: | | |
connect | |
website | |
extra-packages: | | |
local::. | |
any::pkgdown | |
# If events is a PR, set subdir to 'preview/pr<pr_number>' | |
- name: "[PR] Set documentation subdirectory" | |
if: github.event_name == 'pull_request' | |
run: | | |
echo "subdir=preview/pr${{ github.event.number }}" >> $GITHUB_ENV | |
# If event is a tag, set subdir to '<tag_name>' | |
- name: "[tag] Set documentation subdirectory" | |
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags/v') | |
run: | | |
echo "subdir=${GITHUB_REF#refs/tags/}" >> $GITHUB_ENV | |
# If event is workflow_dispatch, set subdir to 'inputs.tag' | |
- name: '[dispatch] Set documentation subdirectory' | |
if: github.event_name == 'workflow_dispatch' | |
run: | | |
echo "subdir=${{ github.event.inputs.tag }}" >> $GITHUB_ENV | |
- name: Deploy pkgdown site | |
id: deploy | |
shell: Rscript {0} | |
run: | | |
subdir <- "${{ env.subdir }}" | |
pkg <- pkgdown::as_pkgdown(".") | |
# Deploy pkgdown site to branch | |
pkgdown::deploy_to_branch(subdir = if (nzchar(subdir)) subdir, clean = nzchar(subdir)) | |
# Report deployed site URL | |
deployed_url <- file.path(pkg$meta$url, subdir) | |
cat(sprintf('url=%s', deployed_url), file = Sys.getenv("GITHUB_OUTPUT"), append = TRUE) | |
- name: Notify pkgdown deployment | |
if: github.event_name == 'pull_request' | |
uses: hasura/comment-progress@v2.2.0 | |
with: | |
github-token: ${{ secrets.GITHUB_TOKEN }} | |
repository: ${{ github.repository }} | |
number: ${{ github.event.number }} | |
id: pkgdown-deploy | |
append: false | |
message: > | |
:book: ${{ steps.deploy.outputs.url }} | |
Preview documentation for this PR (at commit ${{ github.event.pull_request.head.sha }}) | |
pkgdown-clean: | |
if: ${{ github.event_name == 'pull_request' && github.event.action == 'closed' }} | |
runs-on: ubuntu-latest | |
env: | |
GITHUB_PAT: ${{ secrets.GITHUB_TOKEN }} | |
steps: | |
- uses: actions/checkout@v2 | |
with: | |
ref: "gh-pages" | |
- name: Clean up PR Preview | |
run: | | |
git config --local user.name "$GITHUB_ACTOR" | |
git config --local user.email "$GITHUB_ACTOR@users.noreply.github.com" | |
preview_dir="preview/pr${{ github.event.pull_request.number }}" | |
if [ -d "$preview_dir" ]; then | |
git rm -r $preview_dir | |
git commit -m "Remove $preview_dir (GitHub Actions)" || echo 'No preview to remove' | |
git push origin || echo 'No preview to remove' | |
else | |
echo 'No preview to remove' | |
fi | |
- name: Notify pkgdown cleanup | |
uses: hasura/comment-progress@v2.2.0 | |
with: | |
github-token: ${{ secrets.GITHUB_TOKEN }} | |
repository: ${{ github.repository }} | |
number: ${{ github.event.number }} | |
id: pkgdown-deploy | |
message: | | |
_:closed_book: Preview documentation for this PR has been cleaned up._ | |