Documentation Build #3398
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
# Copyright (c) 2020 Linaro Limited. | |
# SPDX-License-Identifier: Apache-2.0 | |
name: Documentation Build | |
on: | |
schedule: | |
- cron: '0 */3 * * *' | |
push: | |
tags: | |
- v* | |
pull_request: | |
env: | |
# NOTE: west docstrings will be extracted from the version listed here | |
WEST_VERSION: 1.2.0 | |
# The latest CMake available directly with apt is 3.18, but we need >=3.20 | |
# so we fetch that through pip. | |
CMAKE_VERSION: 3.20.5 | |
DOXYGEN_VERSION: 1.12.0 | |
# Job count is set to 2 less than the vCPU count of 16 because the total available RAM is 32GiB | |
# and each sphinx-build process may use more than 2GiB of RAM. | |
JOB_COUNT: 14 | |
jobs: | |
doc-file-check: | |
name: Check for doc changes | |
runs-on: ubuntu-22.04 | |
if: > | |
github.repository_owner == 'zephyrproject-rtos' | |
outputs: | |
file_check: ${{ steps.check-doc-files.outputs.any_modified }} | |
steps: | |
- name: checkout | |
uses: actions/checkout@v4 | |
with: | |
ref: ${{ github.event.pull_request.head.sha }} | |
fetch-depth: 0 | |
- name: Check if Documentation related files changed | |
uses: tj-actions/changed-files@v45 | |
id: check-doc-files | |
with: | |
files: | | |
doc/ | |
boards/**/doc/ | |
**.rst | |
include/ | |
kernel/include/kernel_arch_interface.h | |
lib/libc/** | |
subsys/testsuite/ztest/include/** | |
tests/ | |
**/Kconfig* | |
west.yml | |
scripts/dts/ | |
doc/requirements.txt | |
.github/workflows/doc-build.yml | |
scripts/pylib/pytest-twister-harness/src/twister_harness/device/device_adapter.py | |
scripts/pylib/pytest-twister-harness/src/twister_harness/helpers/shell.py | |
doc-build-html: | |
name: "Documentation Build (HTML)" | |
needs: [doc-file-check] | |
if: > | |
github.repository_owner == 'zephyrproject-rtos' && | |
( needs.doc-file-check.outputs.file_check == 'true' || github.event_name != 'pull_request' ) | |
runs-on: ubuntu-22.04 | |
timeout-minutes: 90 | |
concurrency: | |
group: doc-build-html-${{ github.ref }} | |
cancel-in-progress: true | |
steps: | |
- name: install-pkgs | |
run: | | |
sudo apt-get update | |
sudo apt-get install -y wget python3-pip git ninja-build graphviz lcov | |
wget --no-verbose "https://github.com/doxygen/doxygen/releases/download/Release_${DOXYGEN_VERSION//./_}/doxygen-${DOXYGEN_VERSION}.linux.bin.tar.gz" | |
sudo tar xf doxygen-${DOXYGEN_VERSION}.linux.bin.tar.gz -C /opt | |
echo "/opt/doxygen-${DOXYGEN_VERSION}/bin" >> $GITHUB_PATH | |
echo "${HOME}/.local/bin" >> $GITHUB_PATH | |
- name: checkout | |
uses: actions/checkout@v4 | |
with: | |
ref: ${{ github.event.pull_request.head.sha }} | |
fetch-depth: 0 | |
- name: Rebase | |
if: github.event_name == 'pull_request' | |
continue-on-error: true | |
env: | |
BASE_REF: ${{ github.base_ref }} | |
PR_HEAD: ${{ github.event.pull_request.head.sha }} | |
run: | | |
git config --global user.email "[email protected]" | |
git config --global user.name "Github Actions" | |
rm -fr ".git/rebase-apply" | |
rm -fr ".git/rebase-merge" | |
git rebase origin/${BASE_REF} | |
git clean -f -d | |
git log --graph --oneline HEAD...${PR_HEAD} | |
- name: cache-pip | |
uses: actions/cache@v4 | |
with: | |
path: ~/.cache/pip | |
key: pip-${{ hashFiles('doc/requirements.txt') }} | |
- name: install-pip | |
run: | | |
sudo pip3 install -U setuptools wheel pip | |
pip3 install -r doc/requirements.txt | |
pip3 install west==${WEST_VERSION} | |
pip3 install cmake==${CMAKE_VERSION} | |
pip3 install coverxygen | |
- name: west setup | |
run: | | |
west init -l . | |
- name: build-docs | |
shell: bash | |
run: | | |
if [[ "$GITHUB_REF" =~ "refs/tags/v" ]]; then | |
DOC_TAG="release" | |
else | |
DOC_TAG="development" | |
fi | |
if [[ "${{ github.event_name }}" == "pull_request" ]]; then | |
DOC_TARGET="html-fast" | |
else | |
DOC_TARGET="html" | |
fi | |
DOC_TAG=${DOC_TAG} \ | |
SPHINXOPTS="-j ${JOB_COUNT} -W --keep-going -T" \ | |
SPHINXOPTS_EXTRA="-q -t publish" \ | |
make -C doc ${DOC_TARGET} | |
# API documentation coverage | |
python3 -m coverxygen --xml-dir doc/_build/html/doxygen/xml/ --src-dir include/ --output doc-coverage.info | |
# deprecated page causing issues | |
lcov --remove doc-coverage.info \*/deprecated > new.info | |
genhtml --no-function-coverage --no-branch-coverage new.info -o coverage-report | |
- name: compress-docs | |
run: | | |
tar --use-compress-program="xz -T0" -cf html-output.tar.xz --directory=doc/_build html | |
tar --use-compress-program="xz -T0" -cf api-output.tar.xz --directory=doc/_build html/doxygen/html | |
tar --use-compress-program="xz -T0" -cf api-coverage.tar.xz coverage-report | |
- name: upload-build | |
uses: actions/upload-artifact@v4 | |
with: | |
name: html-output | |
path: html-output.tar.xz | |
- name: upload-api-coverage | |
uses: actions/upload-artifact@v4 | |
with: | |
name: api-coverage | |
path: api-coverage.tar.xz | |
- name: process-pr | |
if: github.event_name == 'pull_request' | |
run: | | |
REPO_NAME="${{ github.event.repository.name }}" | |
PR_NUM="${{ github.event.pull_request.number }}" | |
DOC_URL="https://builds.zephyrproject.io/${REPO_NAME}/pr/${PR_NUM}/docs/" | |
API_DOC_URL="https://builds.zephyrproject.io/${REPO_NAME}/pr/${PR_NUM}/docs/doxygen/html/" | |
API_COVERAGE_URL="https://builds.zephyrproject.io/${REPO_NAME}/pr/${PR_NUM}/api-coverage/" | |
echo "${PR_NUM}" > pr_num | |
echo "Documentation will be available shortly at: ${DOC_URL}" >> $GITHUB_STEP_SUMMARY | |
echo "API Documentation will be available shortly at: ${API_DOC_URL}" >> $GITHUB_STEP_SUMMARY | |
echo "API Coverage Report will be available shortly at: ${API_COVERAGE_URL}" >> $GITHUB_STEP_SUMMARY | |
- name: upload-pr-number | |
uses: actions/upload-artifact@v4 | |
if: github.event_name == 'pull_request' | |
with: | |
name: pr_num | |
path: pr_num | |
doc-build-pdf: | |
name: "Documentation Build (PDF)" | |
needs: [doc-file-check] | |
if: | | |
github.event_name != 'pull_request' && | |
github.repository_owner == 'zephyrproject-rtos' | |
runs-on: ubuntu-22.04 | |
container: texlive/texlive:latest | |
timeout-minutes: 120 | |
concurrency: | |
group: doc-build-pdf-${{ github.ref }} | |
cancel-in-progress: true | |
steps: | |
- name: Apply container owner mismatch workaround | |
run: | | |
git config --global --add safe.directory ${GITHUB_WORKSPACE} | |
- name: checkout | |
uses: actions/checkout@v4 | |
- name: install-pkgs | |
run: | | |
apt-get update | |
apt-get install -y python3-pip python3-venv ninja-build doxygen graphviz librsvg2-bin imagemagick | |
- name: cache-pip | |
uses: actions/cache@v4 | |
with: | |
path: ~/.cache/pip | |
key: pip-${{ hashFiles('doc/requirements.txt') }} | |
- name: setup-venv | |
run: | | |
python3 -m venv .venv | |
. .venv/bin/activate | |
echo PATH=$PATH >> $GITHUB_ENV | |
- name: install-pip | |
run: | | |
pip3 install -U setuptools wheel pip | |
pip3 install -r doc/requirements.txt | |
pip3 install west==${WEST_VERSION} | |
pip3 install cmake==${CMAKE_VERSION} | |
- name: west setup | |
run: | | |
west init -l . | |
- name: build-docs | |
shell: bash | |
continue-on-error: true | |
run: | | |
if [[ "$GITHUB_REF" =~ "refs/tags/v" ]]; then | |
DOC_TAG="release" | |
else | |
DOC_TAG="development" | |
fi | |
DOC_TAG=${DOC_TAG} \ | |
SPHINXOPTS="-q -j ${JOB_COUNT}" \ | |
LATEXMKOPTS="-quiet -halt-on-error" \ | |
make -C doc pdf | |
- name: upload-build | |
if: always() | |
uses: actions/upload-artifact@v4 | |
with: | |
name: pdf-output | |
if-no-files-found: ignore | |
path: | | |
doc/_build/latex/zephyr.pdf | |
doc/_build/latex/zephyr.log | |
doc-build-status-check: | |
if: always() | |
name: "Documentation Build Status" | |
needs: | |
- doc-build-pdf | |
- doc-file-check | |
- doc-build-html | |
uses: ./.github/workflows/ready-to-merge.yml | |
with: | |
needs_context: ${{ toJson(needs) }} |