| # Licensed to the Apache Software Foundation (ASF) under one |
| # or more contributor license agreements. See the NOTICE file |
| # distributed with this work for additional information |
| # regarding copyright ownership. The ASF licenses this file |
| # to you under the Apache License, Version 2.0 (the |
| # "License"); you may not use this file except in compliance |
| # with the License. You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, |
| # software distributed under the License is distributed on an |
| # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| # KIND, either express or implied. See the License for the |
| # specific language governing permissions and limitations |
| # under the License. |
| |
| on: |
| push: |
| branches: |
| - main |
| paths: |
| - .asf.yaml |
| - .github/workflows/docs.yaml |
| - docs/** |
| |
| name: Deploy DataFusion site |
| |
| jobs: |
| build-docs: |
| name: Build docs |
| runs-on: ubuntu-latest |
| steps: |
| - name: Checkout docs sources |
| uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 |
| |
| - name: Checkout asf-site branch |
| uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 |
| with: |
| ref: asf-site |
| path: asf-site |
| |
| - name: Setup Python |
| uses: actions/setup-python@a309ff8b426b58ec0e2a45f0f869d46889d02405 # v6.2.0 |
| with: |
| python-version: "3.12" |
| |
| - name: Install dependencies |
| run: | |
| set -x |
| python3 -m venv venv |
| source venv/bin/activate |
| pip install -r docs/requirements.txt |
| - name: Install dependency graph tooling |
| run: | |
| set -x |
| sudo apt-get update |
| sudo apt-get install -y graphviz |
| cargo install cargo-depgraph --version ^1.6 --locked |
| |
| - name: Build docs |
| run: | |
| set -x |
| source venv/bin/activate |
| cd docs |
| ./build.sh |
| |
| - name: Copy & push the generated HTML |
| run: | |
| set -x |
| cd asf-site/ |
| rsync \ |
| -a \ |
| --delete \ |
| --exclude '/.git/' \ |
| ../docs/build/html/ \ |
| ./ |
| cp ../.asf.yaml . |
| touch .nojekyll |
| git status --porcelain |
| if [ "$(git status --porcelain)" != "" ]; then |
| git config user.name "github-actions[bot]" |
| git config user.email "github-actions[bot]@users.noreply.github.com" |
| git add --all |
| git commit -m 'Publish built docs triggered by ${{ github.sha }}' |
| git push || git push --force |
| fi |