Add ShieldGemma notebooks #326
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
# Notebook-related checks | |
name: Notebooks | |
on: | |
# Relevant PRs | |
pull_request: | |
paths: | |
- "**.ipynb" | |
# Allow manual runs | |
workflow_dispatch: | |
jobs: | |
# Format all notebooks. | |
nbfmt: | |
name: Notebook format | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: actions/setup-python@v4 | |
- name: Install tensorflow-docs | |
run: python3 -m pip install -U git+https://github.com/tensorflow/docs | |
- name: Fetch master branch | |
run: git fetch -u origin main:main | |
- name: Check notebook formatting | |
run: | | |
if [ "${{ github.event_name }}" == "pull_request" ]; then | |
# Only check notebooks modified in this pull request | |
readarray -t changed_notebooks < <(git diff --name-only main | grep '\.ipynb$' || true) | |
else | |
# Manual run, check everything | |
readarray -t changed_notebooks < <(find -name '*.ipynb') | |
fi | |
if [[ ${#changed_notebooks[@]} == 0 ]]; then | |
echo "No notebooks modified in this pull request." | |
exit 0 | |
else | |
echo "Check formatting with nbfmt:" | |
python3 -m tensorflow_docs.tools.nbfmt --test "${changed_notebooks[@]}" | |
fi | |
nblint: | |
name: Notebook lint | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: actions/setup-python@v4 | |
- uses: dorny/paths-filter@v2 | |
id: filter | |
with: | |
filters: | | |
website: | |
- 'site/en/**/**.ipynb' | |
github_docs: | |
- 'examples/**/**.ipynb' | |
- 'demos/**/**.ipynb' | |
templates: | |
- 'templates/**/**.ipynb' | |
- name: Install tensorflow-docs | |
run: python3 -m pip install -U git+https://github.com/tensorflow/docs | |
- name: Fetch main branch | |
run: git fetch -u origin main:main | |
# Full lint for website notebooks (incl. website button) | |
- name: Lint website notebooks | |
if: steps.filter.outputs.website == 'true' | |
run: | | |
if [ "${{ github.event_name }}" == "pull_request" ]; then | |
# Only check notebooks modified in this pull request | |
readarray -t changed_notebooks < <(git diff --name-only main site/en/ |grep '\.ipynb$' || true) | |
else | |
# Manual run, check everything | |
readarray -t changed_notebooks < <(find site/en/ -name '*.ipynb') | |
fi | |
if [[ ${#changed_notebooks[@]} == 0 ]]; then | |
echo "No website notebooks modified in this pull request." | |
exit 0 | |
else | |
echo "Lint check with nblint:" | |
python3 -m tensorflow_docs.tools.nblint \ | |
--styles=google,tensorflow \ | |
--arg=repo:google/generative-ai-docs --arg=branch:main \ | |
--arg=base_url:https://ai.google.dev/ \ | |
--exclude_lint=tensorflow::button_download \ | |
"${changed_notebooks[@]}" | |
fi | |
# Reduced lint for notebooks hosted in GitHub | |
- name: Lint documentation notebooks | |
if: steps.filter.outputs.github_docs == 'true' | |
run: | | |
if [ "${{ github.event_name }}" == "pull_request" ]; then | |
# Only check notebooks modified in this pull request | |
readarray -t changed_notebooks < <(git diff --name-only main demos/ examples/ |grep '\.ipynb$' || true) | |
else | |
# Manual run, check everything | |
readarray -t changed_notebooks < <(find demos/ examples/ -name '*.ipynb') | |
fi | |
if [[ ${#changed_notebooks[@]} == 0 ]]; then | |
echo "No GitHub doc notebooks modified in this pull request." | |
exit 0 | |
else | |
echo "Lint check with nblint:" | |
python3 -m tensorflow_docs.tools.nblint \ | |
--styles=google,tensorflow \ | |
--arg=repo:google/generative-ai-docs --arg=branch:main \ | |
--exclude_lint=tensorflow::button_download \ | |
--exclude_lint=tensorflow::button_website \ | |
"${changed_notebooks[@]}" | |
fi | |
# Basic lint for template notebooks | |
- name: Lint template notebooks | |
if: steps.filter.outputs.templates == 'true' | |
run: | | |
if [ "${{ github.event_name }}" == "pull_request" ]; then | |
# Only check notebooks modified in this pull request | |
readarray -t changed_notebooks < <(git diff --name-only main templates/ |grep '\.ipynb$' || true) | |
else | |
# Manual run, check everything | |
readarray -t changed_notebooks < <(find templates/ -name '*.ipynb') | |
fi | |
if [[ ${#changed_notebooks[@]} == 0 ]]; then | |
echo "No template notebooks modified in this pull request." | |
exit 0 | |
else | |
echo "Lint check with nblint:" | |
python3 -m tensorflow_docs.tools.nblint \ | |
--styles=google,tensorflow \ | |
--arg=repo:google/generative-ai-docs --arg=branch:main \ | |
--exclude_lint=tensorflow::button_download \ | |
--exclude_lint=tensorflow::button_website \ | |
--exclude_lint=tensorflow::button_colab \ | |
--exclude_lint=tensorflow::button_github \ | |
"${changed_notebooks[@]}" | |
fi | |