Update "tested on" badge in README to include PHP v8.3 #69
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: Build website | |
on: | |
# Trigger the workflow whenever a new release is published. | |
# Using release->published rather than push->tag, as the GH API used within the GH Pages | |
# generation doesn't have access to the last tag, but does have access to the last release info. | |
release: | |
types: | |
- published | |
# And on PRs which update either this workflow or one of the associated files (for a dry-run). | |
pull_request: | |
paths: | |
- 'README.md' | |
- 'CHANGELOG.md' | |
- '.phpdoc.xml.dist' | |
- '.github/workflows/update-docs.yml' | |
- '.github/GHPages/**' | |
- 'docs/**' | |
# Also allow manually triggering the workflow. This will update the website (not do a dry-run)! | |
workflow_dispatch: | |
# Cancels all previous workflow runs for the same branch that have not yet completed. | |
concurrency: | |
# The concurrency group contains the workflow name and the branch name. | |
group: ${{ github.workflow }}-${{ github.ref }} | |
cancel-in-progress: true | |
# Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages | |
permissions: | |
contents: read | |
pages: write | |
id-token: write | |
env: | |
DEFAULT_BRANCH: 'stable' | |
jobs: | |
build: | |
name: "Build the website" | |
# Don't run on forks. | |
if: github.repository == 'PHPCSStandards/PHPCSUtils' | |
runs-on: ubuntu-latest | |
steps: | |
# By default use the `stable` branch as the published docs should always | |
# reflect the latest release. | |
# For testing changes to the workflow or the scripts, use the PR branch | |
# to have access to the latest version of the workflow/scripts/files. | |
- name: Determine branch to use | |
id: base_branch | |
env: | |
REF: ${{ github.ref }} | |
run: | | |
if [[ "${{ github.event_name }}" == "pull_request" ]]; then | |
echo "BRANCH=$REF" >> $GITHUB_OUTPUT | |
else | |
echo 'BRANCH=${{ env.DEFAULT_BRANCH }}' >> $GITHUB_OUTPUT | |
fi | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
with: | |
ref: ${{ steps.base_branch.outputs.BRANCH }} | |
# fetch-depth is needed to allow for retrieving the last tag for a non-tag workflow run. | |
fetch-depth: 0 | |
- name: Install PHP | |
uses: shivammathur/setup-php@v2 | |
with: | |
# Use a version known to be safe for last phpDocumentor release. | |
php-version: '8.1' | |
ini-file: 'development' | |
coverage: none | |
# Install the latest phpDocumentor release as a PHAR. | |
tools: phpdoc | |
env: | |
fail-fast: true | |
- name: "Ensure the phpdoc directory is empty (remove if it exists)" | |
run: rm -vrf ./docs/phpdoc/* | |
- name: Get the last tag reachable from current branch | |
id: get_last_tag | |
env: | |
REF_NAME: ${{ github.ref_name }} | |
# yamllint disable rule:line-length | |
run: | | |
if [[ "${{ github.event_name }}" == 'release' && "${{ github.ref_type }}" == 'published' && "$REF_NAME" == "${{ env.DEFAULT_BRANCH }}" ]]; then | |
echo "LAST_TAG=$REF_NAME" >> $GITHUB_OUTPUT | |
else # = Pushed tag. | |
echo "LAST_TAG=$(git describe --tags --abbrev=0)" >> $GITHUB_OUTPUT | |
fi | |
# yamllint enable rule:line-length | |
- name: "DEBUG: show retrieved last tag" | |
run: "echo Last release: ${{ steps.get_last_tag.outputs.LAST_TAG }}" | |
- name: Update the phpDoc configuration | |
run: php .github/GHPages/update-docgen-config.php | |
env: | |
TAG: ${{ steps.get_last_tag.outputs.LAST_TAG }} | |
- name: Generate the phpDoc documentation | |
run: phpDocumentor -n | |
- name: Make sure the phpdoc directory contains an empty .nojekyll file | |
run: touch ./docs/phpdoc/.nojekyll | |
- name: Transform the markdown docs for use in GH Pages | |
run: php .github/GHPages/update-website.php | |
# Retention is normally 90 days, but this artifact is only for reviewing | |
# and debugging the generated files for the website. | |
- name: Upload the generated files | |
uses: actions/upload-artifact@v3 | |
with: | |
name: generated-files | |
path: ./docs/ | |
if-no-files-found: error | |
retention-days: 5 | |
- name: Setup GH Pages | |
uses: actions/configure-pages@v3 | |
- name: Build the GH Pages site with Jekyll | |
uses: actions/jekyll-build-pages@v1 | |
with: | |
source: ./docs | |
destination: ./docs/_site | |
- name: Upload GH Pages artifact | |
uses: actions/upload-pages-artifact@v2 | |
with: | |
path: ./docs/_site | |
- name: Check GitHub Pages status | |
uses: crazy-max/ghaction-github-status@v4 | |
with: | |
pages_threshold: major_outage | |
deploy: | |
needs: build | |
# Don't run on forks, don't run on normal pushes or PRs (dry-runs). | |
if: always() && github.repository == 'PHPCSStandards/PHPCSUtils' && github.event_name != 'pull_request' && needs.build.result == 'success' | |
environment: | |
name: github-pages | |
url: ${{ steps.deployment.outputs.page_url }} | |
name: "Deploy the website" | |
runs-on: ubuntu-latest | |
steps: | |
- name: Deploy to GitHub Pages | |
id: deployment | |
uses: actions/deploy-pages@v2 |