Create parameter deprecation annotation #4470
Workflow file for this run
  
    
      This file contains hidden or 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 | |
| on: # cf. https://github.community/t/how-to-trigger-an-action-on-push-or-pull-request-but-not-both/16662 | |
| push: | |
| branches: | |
| - master | |
| pull_request: | |
| branches: | |
| - master | |
| jobs: | |
| check-reference-pdf-files: | |
| runs-on: ubuntu-latest | |
| permissions: {} | |
| steps: | |
| - name: Checkout ποΈ | |
| uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 | |
| with: | |
| persist-credentials: false | |
| - name: Set up Python 3.14 π§ | |
| uses: actions/setup-python@e797f83bcb11b83ae66e0230d6156d7c80228e7c # v6.0.0 | |
| with: | |
| python-version: 3.14 | |
| - name: Install system dependencies βοΈ | |
| run: sudo apt-get update --allow-releaseinfo-change && sudo apt-get install qpdf | |
| - name: Check all PDF reference files used in tests β | |
| run: | | |
| # Using qpdf | |
| find . -name '*.pdf' | xargs -n 1 sh -c 'qpdf --check --password=fpdf2 $0 || exit 255' | |
| export PYTHONPATH=$PWD | |
| # Using Datalogics PDF Checker: | |
| scripts/install-pdfchecker.sh | |
| time scripts/pdfchecker.py --process-all-test-pdf-files | |
| scripts/pdfchecker.py --print-aggregated-report | |
| # Using VeraPDF: | |
| scripts/install-verapdf.sh | |
| time scripts/verapdf.py --process-all-test-pdf-files | |
| scripts/verapdf.py --print-aggregated-report | |
| scripts/check-PDF-A-with-verapdf.sh | |
| lint: | |
| runs-on: ubuntu-24.04 | |
| permissions: | |
| security-events: write # for zizmor | |
| steps: | |
| - name: Checkout ποΈ | |
| uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 | |
| with: | |
| persist-credentials: false | |
| - name: Set up Python 3.13 π§ | |
| uses: actions/setup-python@e797f83bcb11b83ae66e0230d6156d7c80228e7c # v6.0.0 | |
| with: | |
| python-version: 3.13 # guarddog / pygit2 still have issues with 3.14 | |
| - name: Install Python dependencies βοΈ | |
| run: | | |
| python -m pip install --upgrade pip setuptools wheel | |
| pip install --upgrade . -r test/linters-requirements.txt -r test/requirements.txt | |
| # Running zizmor 1st, because it is blocking PR merge | |
| - name: Run zizmor π | |
| run: zizmor --format=sarif . > results.sarif | |
| env: | |
| GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
| - name: Upload SARIF file | |
| uses: github/codeql-action/upload-sarif@16140ae1a102900babc80a33c44059580f687047 # v4.30.9 | |
| with: | |
| sarif_file: results.sarif | |
| category: zizmor | |
| - name: Run linters π | |
| run: | | |
| black --check . | |
| pylint fpdf test tutorial/tuto*.py | |
| bandit -c .banditrc.yml -r contributors/ fpdf/ tutorial/ | |
| semgrep scan --config auto --error --strict --exclude-rule=python.lang.security.insecure-hash-function.insecure-hash-function fpdf | |
| - name: Scan project with grype π | |
| uses: anchore/scan-action@a5605eb0943e46279cb4fbd9d44297355d3520ab # v7.0.2 | |
| with: | |
| path: "." | |
| fail-build: true | |
| - name: Scan project dependencies with guarddog πΆ | |
| # GuardDog is very slow, we only execute it on the master branch: | |
| if: github.ref == 'refs/heads/master' | |
| run: | | |
| pip install guarddog | |
| # Scanning direct dependencies: | |
| time guarddog pypi scan defusedxml | |
| time guarddog pypi scan Pillow | |
| time guarddog pypi scan fonttools | |
| # Scanning dev dependencies: | |
| time guarddog pypi verify contributors/requirements.txt | |
| time guarddog pypi verify docs/requirements.txt | |
| time guarddog pypi verify test/linters-requirements.txt | |
| time guarddog pypi verify test/requirements.txt | |
| - name: Spell Check Repo βοΈ | |
| uses: crate-ci/typos@80c8a4945eec0f6d464eaf9e65ed98ef085283d1 # v1.38.1 | |
| test: | |
| strategy: | |
| matrix: | |
| python-version: ['3.10', '3.11', '3.12', '3.13', '3.14'] | |
| platform: [ubuntu-latest, windows-latest, macos-latest] | |
| runs-on: ${{ matrix.platform }} | |
| permissions: {} | |
| steps: | |
| - name: Checkout ποΈ | |
| uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 | |
| with: | |
| persist-credentials: false | |
| - name: Set up Python ${{ matrix.python-version }} π§ | |
| uses: actions/setup-python@e797f83bcb11b83ae66e0230d6156d7c80228e7c # v6.0.0 | |
| with: | |
| python-version: ${{ matrix.python-version }} | |
| - name: Install system dependencies βοΈ | |
| if: ${{ startsWith(matrix.platform, 'ubuntu') }} | |
| # Ghostscript is needed for test/table/test_table_extraction.py | |
| run: sudo apt-get update --allow-releaseinfo-change && sudo apt-get install ghostscript | |
| - name: Install qpdf βοΈ | |
| # We run the unit tests WITHOUT qpdf for a single parallel execution / Python version: | |
| if: ${{ startsWith(matrix.platform, 'ubuntu') && matrix.python-version != '3.13' }} | |
| run: sudo apt-get update --allow-releaseinfo-change && sudo apt-get install qpdf | |
| - name: Install qpdf on Windows | |
| if: startsWith(matrix.platform, 'windows') | |
| shell: pwsh | |
| run: | | |
| choco install qpdf -y | |
| qpdf --version | |
| - name: Install Python dependencies βοΈ | |
| # Temporarily writing a constraints file to make sure numpy 2.3.3 is used | |
| # for python 3.14 | |
| shell: bash | |
| run: | | |
| python -m pip install --upgrade pip setuptools wheel | |
| # --- Create constraints file --- | |
| # For Python 3.14 only - temporary solution while camelot-py | |
| # update its dependencies | |
| CONSTRAINTS_FILE="constraints.txt" | |
| if [[ "${{ matrix.python-version }}" == "3.14" ]]; then | |
| echo "numpy>=2.3.3" > "$CONSTRAINTS_FILE" | |
| echo "Added numpy>=2.3.3 to $CONSTRAINTS_FILE" | |
| else | |
| : > "$CONSTRAINTS_FILE" # create empty file | |
| echo "Created empty $CONSTRAINTS_FILE" | |
| fi | |
| # --- Install dependencies respecting constraints --- | |
| pip install --upgrade . -r test/requirements.txt -c "$CONSTRAINTS_FILE" | |
| - name: Run tests β | |
| shell: bash | |
| env: | |
| CHECK_EXEC_TIME: ${{ matrix.python-version == '3.10' && 'test-enabled' || '' }} | |
| CHECK_RSS_MEMORY: ${{ matrix.python-version == '3.14' && 'test-enabled' || '' }} | |
| run: | | |
| # Ensuring there is no `generate=True` left remaining in calls to assert_pdf_equal: | |
| grep -IRF generate=True test/ && exit 1 | |
| # Executing all tests: | |
| if [[ "${{ matrix.platform }}" == "ubuntu-latest" ]]; then | |
| echo "Running with --trace-memory-usage (Ubuntu)" | |
| pytest -vv --trace-memory-usage | |
| else | |
| echo "Running without trace-memory-usage (${{ matrix.platform }})" | |
| pytest -vv | |
| fi | |
| - name: Upload coverage report to codecov.io β | |
| # We only upload coverage ONCE, for a single parallel execution / Python version: | |
| if: ${{ startsWith(matrix.platform, 'ubuntu') && matrix.python-version == '3.13' }} | |
| run: bash <(curl -s https://codecov.io/bash) | |
| - name: Run tests with the minimal versions of fpdf2 direct dependencies β | |
| if: ${{ startsWith(matrix.platform, 'ubuntu') && matrix.python-version == '3.10' }} | |
| run: | | |
| # Ensuring that those minimal versions remain compatible: | |
| sed -i '/install_requires/,/\n/s/>=/==/' setup.cfg | |
| pip install . | |
| # Targeting only a subset of tests because: A) it's faster and B) some tests are dependant on a specific version of fonttools or Pillow | |
| # Deselect test involving TTF fonts due to differences with old fonttools version. | |
| pytest -vv test/barcodes test/drawing test/errors test/image/test_load_image.py test/metadata test/shapes test/signing test/text_region test/utils --deselect test/drawing/test_drawing_text.py::test_text_ttf_transforms | |
| doc: | |
| runs-on: ubuntu-latest | |
| permissions: | |
| # required to deploy doc, by pushing commits to branch gh-pages: | |
| contents: write | |
| pages: write | |
| steps: | |
| - name: Harden Runner | |
| # Security hardening because this is a sensitive job, | |
| # where extra care should be taken NOT to leak any secret | |
| uses: step-security/harden-runner@f4a75cfd619ee5ce8d5b864b0d183aff3c69b55a # v2.13.1 | |
| with: | |
| egress-policy: block | |
| allowed-endpoints: | |
| github.com:443 | |
| api.github.com:443 | |
| *.githubusercontent.com:443 | |
| pypi.org:443 | |
| files.pythonhosted.org:443 | |
| registry.npmjs.org:443 | |
| api.star-history.com:443 | |
| cdnjs.cloudflare.com:443 | |
| colab.research.google.com:443 | |
| fonts.googleapis.com:443 | |
| fonts.gstatic.com:443 | |
| img.shields.io:443 | |
| unpkg.com:443 | |
| borbpdf.com:443 | |
| # Starting from api.star-history.com, the endpoints whitelist reason is the mkdocs privacy plugin | |
| - name: Checkout ποΈ | |
| uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 | |
| with: | |
| persist-credentials: false | |
| # Required for mkdocs git-revision-date-localized plugin: | |
| fetch-depth: 0 | |
| - name: Set up Python 3.14 π§ | |
| uses: actions/setup-python@e797f83bcb11b83ae66e0230d6156d7c80228e7c # v6.0.0 | |
| with: | |
| python-version: 3.14 | |
| - name: Install Python dependencies βοΈ | |
| run: | | |
| python -m pip install --upgrade pip setuptools wheel | |
| pip install --upgrade . -r docs/requirements.txt -r contributors/requirements.txt | |
| - name: Generate HTML documentation ποΈ | |
| run: | | |
| mkdir -p public/ | |
| # Setting PDF manual version: | |
| sed -i "s/author:.*/author: v$(python setup.py -V 2>/dev/null)/" mkdocs.yml | |
| cp tutorial/notebook.ipynb docs/ | |
| python -m mkdocs build | |
| pdoc --html -o public/ fpdf --template-dir docs/pdoc | |
| scripts/add_pdoc_to_search_index.py | |
| - name: Build contributors map πΊοΈ | |
| # As build_contributors_html_page.py can hang due to GitHub rate-limiting, we only execute this on master for now | |
| if: github.ref == 'refs/heads/master' | |
| env: | |
| # Needed by contributors/build_contributors_html_page.py: | |
| GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
| PYTHONUNBUFFERED: 1 | |
| run: | | |
| cd contributors/ | |
| npm ci | |
| ./build_contributors_html_page.py py-pdf/fpdf2 | |
| cp -t ../public/ contributors.html contributors-map-small.png | |
| - name: Deploy documentation π | |
| if: github.ref == 'refs/heads/master' | |
| uses: peaceiris/actions-gh-pages@4f9cc6602d3f66b9c108549d475ec49e8ef4d45e # v4.0.0 | |
| with: | |
| github_token: ${{ secrets.GITHUB_TOKEN }} | |
| publish_dir: public/ | |
| publish: | |
| if: github.ref == 'refs/heads/master' | |
| runs-on: ubuntu-latest | |
| environment: | |
| name: pypi | |
| url: https://pypi.org/p/fpdf2 | |
| permissions: | |
| # Trusted publishing configured there: https://pypi.org/manage/project/fpdf2/settings/publishing/ | |
| id-token: write | |
| steps: | |
| - name: Harden Runner | |
| # Security hardening because this is a sensitive job, | |
| # where extra care should be taken NOT to leak any secret | |
| uses: step-security/harden-runner@f4a75cfd619ee5ce8d5b864b0d183aff3c69b55a # v2.13.1 | |
| with: | |
| egress-policy: block | |
| allowed-endpoints: | |
| ghcr.io:443 | |
| github.com:443 | |
| *.githubusercontent.com:443 | |
| pypi.org:443 | |
| files.pythonhosted.org:443 | |
| *.sigstore.dev:443 | |
| upload.pypi.org:443 | |
| - name: Checkout ποΈ | |
| uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 | |
| with: | |
| persist-credentials: false | |
| - name: Set up Python 3.14 π§ | |
| uses: actions/setup-python@e797f83bcb11b83ae66e0230d6156d7c80228e7c # v6.0.0 | |
| with: | |
| python-version: '3.14' | |
| - name: Build distributions for Pypi ποΈ | |
| id: build | |
| run: | | |
| echo Versions already released on Pypi: $(curl -Ls 'https://pypi.org/pypi/fpdf2/json' | jq -r '.releases|keys[]') | |
| pip install --upgrade setuptools twine wheel . | |
| echo Current code version: $(python setup.py -V) | |
| # Checking if current code version has already been released: | |
| if ! curl -Ls 'https://pypi.org/pypi/fpdf2/json' | jq -r '.releases|keys[]' | grep "^$(python setup.py -V)\$"; then echo publish=yes >> "$GITHUB_OUTPUT"; python setup.py sdist bdist_wheel; twine check dist/*; fi | |
| - name: Publish package distributions to PyPI π | |
| if: steps.build.outputs.publish == 'yes' | |
| uses: pypa/gh-action-pypi-publish@ed0c53931b1dc9bd32cbe73a98c7f6766f8a527e # v1.13.0 | |
| # Doc: https://github.com/marketplace/actions/pypi-publish | |
| with: | |
| print-hash: true |