update CI/CD (scheduled CI and deploy released version to PyPI) #21
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
name: upload docs to gh-pages | |
on: | |
push: | |
branches: | |
- main | |
# - develop | |
# - ghactions | |
# - '*-autodoc' | |
- '!gh-pages' | |
tags: ['*'] | |
jobs: | |
deploy: | |
runs-on: ubuntu-22.04 | |
steps: | |
- name: Inject slug/short variables | |
uses: rlespinasse/[email protected] | |
- name: Checkout | |
uses: actions/checkout@v4 | |
with: | |
path: main | |
- name: Checkout gh-pages | |
uses: actions/checkout@v4 | |
with: | |
ref: gh-pages | |
path: gh-pages | |
- name: Set up Python | |
uses: actions/setup-python@v5 | |
with: | |
python-version: 3.11 | |
- name: Prepare LaTeX env | |
run: | | |
sudo apt update | |
sudo apt install openmpi-bin libopenmpi-dev | |
sudo apt install \ | |
texlive-latex-recommended texlive-latex-extra texlive-xetex \ | |
texlive-lang-japanese texlive-fonts-recommended texlive-fonts-extra latexmk | |
kanji-config-updmap-sys ipaex | |
- name: Install python packages | |
run: | | |
python -m pip install --upgrade pip | |
pip install sphinx sphinx-rtd-theme | |
- name: Build | |
run: | | |
cd ${GITHUB_WORKSPACE}/main | |
python -m pip install '.[all]' | |
cd ${GITHUB_WORKSPACE}/main/doc | |
sh ./make.sh --latex | |
- name: Deploy Configuration | |
run: | | |
mkdir ~/.ssh | |
ssh-keyscan -t rsa github.com >> ~/.ssh/known_hosts | |
echo "${{ secrets.GH_ACTIONS_DEPLOY_KEY }}" > ~/.ssh/id_rsa | |
chmod 400 ~/.ssh/id_rsa | |
- name: Push | |
env: | |
GIT_USER: "ODAT-SE Developers" | |
GIT_EMAIL: "[email protected]" | |
TARGET_NAME: ${{ env.GITHUB_REF_SLUG }} | |
run: | | |
cd ${GITHUB_WORKSPACE} | |
is_tag=NO | |
TARGET_NAME="${TARGET_NAME%-autodoc}" | |
test "_$(echo ${GITHUB_REF:-'//'} | cut -d/ -f2)" = "_tags" && is_tag=YES | |
# JA & EN manuals | |
for lang in ja en; do | |
rm -rf "gh-pages/manual/${TARGET_NAME}/${lang}" | |
mkdir -p "gh-pages/manual/${TARGET_NAME}" | |
cp -r "main/doc/${lang}/build/html" "gh-pages/manual/${TARGET_NAME}/${lang}" | |
if [ $is_tag = "YES" ]; then | |
# cp "main/doc/${lang}/build/latex/userguid_odatse_${lang}.pdf" "gh-pages/manual/${TARGET_NAME}/${lang}/ODAT-SE.pdf" | |
: | |
fi | |
done | |
# API manual | |
rm -rf "gh-pages/manual/${TARGET_NAME}/api" | |
mkdir -p "gh-pages/manual/${TARGET_NAME}" | |
cp -r "main/doc/api/build/html" "gh-pages/manual/${TARGET_NAME}/api" | |
cd gh-pages | |
git config --local user.name "${GIT_USER}" | |
git config --local user.email "${GIT_EMAIL}" | |
git remote set-url origin [email protected]:${GITHUB_REPOSITORY}.git | |
git add manual | |
if git commit -m "Deploy docs to ${TARGET_NAME} by GitHub Actions triggered by ${GITHUB_SHA}" | |
then | |
git push origin gh-pages | |
else | |
echo "Nothing to deploy" | |
fi |