Skip to content

Propagate documentation #738

Propagate documentation

Propagate documentation #738

name: Propagate documentation
on:
schedule:
- cron: '0 3 * * *'
workflow_dispatch:
inputs:
dry-run:
description: 'If true, run the merge locally but do not push to remote'
required: false
default: 'false'
slack-notifications:
description: 'If true, send slack notifications when errors occur'
required: false
default: 'false'
jobs:
propagate-doc-upwards:
runs-on: ubuntu-22.04
strategy:
# we want to run the full build on all os: don't cancel running jobs even if one fails
fail-fast: false
matrix:
repo:
- bonita-continuous-delivery-doc
- bonita-doc
- bonita-test-toolkit-doc
steps:
- name: Checkout bonita-documentation-site
uses: actions/checkout@v4
with:
path: ./bonita-documentation-site
- name: Checkout ${{ matrix.repo }}
uses: actions/checkout@v4
with:
repository: bonitasoft/${{ matrix.repo }}
token: ${{ secrets.GH_PAT_TOKEN }} # Dedicated token to have 'write permission' (we later push to this repository)
path: ./${{ matrix.repo }}
# Number of commits to fetch. 0 indicates all history for all branches and tags.
fetch-depth: '0'
- name: Run propagate doc upwards
env:
NO_PUSH: ${{ github.event.inputs.dry-run }}
REPO_NAME: ${{ matrix.repo }}
run: |
cd ./${{ matrix.repo }}
# configure committer information
git config user.email "[email protected]"
git config user.name "GitHub Actions"
echo "########################################"
echo "Performing the doc propagation"
echo "########################################"
./.././bonita-documentation-site/scripts/propagate_doc_upwards.bash
- name: Send message to Slack channel
if: failure() && (github.event_name == 'schedule' || (github.event_name == 'workflow_dispatch' && github.event.inputs.slack-notifications == 'true') )
uses: bonitasoft/actions/packages/notify-slack@v2
with:
CHANNEL_ID: ${{ vars.SLACK_CHANNEL_ID }}
MESSAGE: |
:fire: Propagating documentation upwards failed for repository *${{matrix.repo}}*.
@channel *We need someone*!
- Add a :fire_extinguisher:if you take the action to resolve the conflicts (only one person is required)
- Add a :sweat_drops: when it’s done (and eventually a :party_parrot:)
More details on solving the conflicts locally <https://bonitasoft.atlassian.net/wiki/spaces/BS/pages/1181483014/Bonita+documentation+site+content+update#Bonita| there>
SLACK_BOT_TOKEN: ${{ secrets.SLACK_BOT_TOKEN }}