Skip to content

Workflow file for this run

name: Deploy documentation with GitHub Pages dependencies preinstalled
on:
push:
branches: ["develop", "master"]
workflow_dispatch: # enable manual workflow execution
# Set permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages
permissions:
contents: read
pages: write
id-token: write
# Allow only one concurrent deployment, skipping runs queued between the run in-progress and latest queued.
# However, do NOT cancel in-progress runs as we want to allow these production deployments to complete.
concurrency:
group: "pages"
cancel-in-progress: false
jobs:
build:
# prevent this action from running on forks
if: github.repository == 'abinit/abipy'
defaults:
run:
shell: bash -l {0} # enables conda/mamba env activation by reading bash profile
strategy:
fail-fast: false
matrix:
config:
- os: ubuntu-latest
python: '3.11'
runs-on: ubuntu-latest
env:
PMG_MAPI_KEY: ${{ secrets.PMG_MAPI_KEY }}
# This is used in the flow scripts to generate the graph with graphviz.
READTHEDOCS: 1
steps:
- name: Check out Abipy repo
uses: actions/checkout@v4
- name: Setup Pages
uses: actions/configure-pages@v3
- name: Set up Miniconda
uses: conda-incubator/setup-miniconda@v2
with:
auto-update-conda: true
- name: Installing abinit from conda-forge and abipy with python=${{ matrix.config.python }}
run: |
conda create -n abipy python=${{ matrix.config.python }} --yes
conda activate abipy
conda install abinit -c conda-forge --yes
mpirun -n 1 abinit --version
mpirun -n 1 abinit --build
# Update submodules with data.
git submodule update --remote --init
git submodule update --recursive --remote
pip install --editable .
mkdir -p $HOME/.abinit/abipy/
cp abipy/data/managers/gh_manager.yml $HOME/.abinit/abipy/manager.yml
cp abipy/data/managers/gh_scheduler.yml $HOME/.abinit/abipy/scheduler.yml
# TEMPORARY HACK THAT MIGHT BE NEEDED IF THE PYMATGEN GUYS BREAK STUFF
#pip install git+https://github.com/gmatteo/pymatgen.git@master -U
- name: Build docs with Sphinx
run: |
conda activate abipy
cd docs
source install.sh
make -j
- name: Upload artifact
uses: actions/upload-pages-artifact@v2
with:
path: docs/_build/html/ # Important. Set to the website output dir
deploy:
environment:
name: github-pages
url: ${{ steps.deployment.outputs.page_url }}
runs-on: ubuntu-latest
needs: build
steps:
- name: Deploy to GitHub Pages
id: deployment
uses: actions/deploy-pages@v3