Skip to content

🤖 Update infrastructure file(s) #759

🤖 Update infrastructure file(s)

🤖 Update infrastructure file(s) #759

Workflow file for this run

name: Build
on:
push:
branches:
- main
tags:
- '*'
pull_request:
branches:
- main
concurrency:
# Concurrency group that uses the workflow name and PR number if available
# or commit SHA as a fallback. If a new build is triggered under that
# concurrency group while a previous build is running it will be canceled.
# Repeated pushes to a PR will cancel all previous builds, while multiple
# merges to main will not cancel.
group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.sha }}
cancel-in-progress: true
jobs:
package:
runs-on: ubuntu-latest
steps:
- name: Retrieve the source code
uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Install build dependencies
run: |
source $CONDA/bin/activate
conda config --append channels conda-forge
conda install -y conda-build conda-verify sphinx numpydoc sphinxcontrib-autoprogram make
python -m pip install -e .
- name: Build the documentation as a test
run: |
source $CONDA/bin/activate
cd docs
make html
- name: Build the package
run: conda build conda-recipe --no-test
- name: Reduce the size of the build artifact
run: rm -rf /usr/share/miniconda/conda-bld/{git_cache,work,conda-pack*,*/.cache}
- name: Upload the build artifact
uses: actions/upload-artifact@v4
with:
name: package-${{ github.sha }}
path: /usr/share/miniconda/conda-bld
retention-days: 5
testbed:
defaults:
run:
shell: bash
runs-on: ${{ matrix.os }}
strategy:
fail-fast: false
matrix:
os: [ubuntu-latest,macos-14,windows-latest]
steps:
- name: Retrieve the source code
uses: actions/checkout@v4
- uses: conda-incubator/[email protected]
if: matrix.os == 'macos-14'
- id: conda-root
name: Set CONDA_ROOT
run: |
CONDA_ROOT=$(dirname $GITHUB_WORKSPACE)/conda
echo "value=$(dirname $GITHUB_WORKSPACE)/conda" >> $GITHUB_OUTPUT
echo "CONDA_ROOT=$CONDA_ROOT" >> $GITHUB_ENV
echo "CONDA_ROOT: $CONDA_ROOT"
# Use a smaller cache entry to enable a quicker exit if we
# have already built the testbed. Any small file will do
- id: cache-key
name: Retrieve cache key
uses: actions/cache@v4
with:
path: LICENSE.txt
key: key-${{ matrix.os }}-${{ hashFiles('testing') }}-5
- name: Retrieve or create the testbed cache
if: steps.cache-key.outputs.cache-hit != 'true'
uses: actions/cache@v4
with:
path: ${{ steps.conda-root.outputs.value }}
key: testbed-${{ matrix.os }}-${{ hashFiles('testing') }}-5
- name: Verify or create the testbed
if: steps.cache-key.outputs.cache-hit != 'true'
run: testing/setup_envs.sh purge-packages
tests:
defaults:
run:
shell: bash
runs-on: ${{ matrix.os }}
needs: [package,testbed]
strategy:
fail-fast: false
matrix:
os: [macos-14,ubuntu-latest,windows-latest]
pyver: ["3.8","3.9","3.10"]
include:
# include the appropriate dependencies for testing SquashFS on each OS
- os: macos-14
conda_deps: "conda-forge::squashfs-tools conda-forge::fish"
- os: ubuntu-latest
conda_deps: "conda-forge::squashfs-tools conda-forge::squashfuse conda-forge::fish"
- os: windows-latest
conda_deps: ""
steps:
- name: Retrieve the source code
uses: actions/checkout@v4
- id: conda-root
name: Set CONDA_ROOT
run: |
CONDA_ROOT=$(dirname $GITHUB_WORKSPACE)/conda
echo "value=$(dirname $GITHUB_WORKSPACE)/conda" >> $GITHUB_OUTPUT
echo "CONDA_ROOT=$CONDA_ROOT" >> $GITHUB_ENV
echo "CONDA_ROOT: $CONDA_ROOT"
- name: Retrieve the testbed cache
uses: actions/cache@v4
with:
path: ${{ steps.conda-root.outputs.value }}
key: testbed-${{ matrix.os }}-${{ hashFiles('testing') }}-5
- name: Download the build artifact
uses: actions/download-artifact@v4
with:
name: package-${{ github.sha }}
path: conda-bld
- name: Verify or create the testbed
run: testing/setup_envs.sh
- name: Create the test environment and run the tests
run: |
source $CONDA_ROOT/etc/profile.d/conda.sh
# Explicitly add defaults to silence the FutureWarning breaking JSON output
conda config --add channels defaults
conda info -a
mv conda-bld $CONDA_ROOT/conda-bld
conda create -n cptest local::conda-pack conda-forge::pytest conda-forge::pytest-cov defaults::python=${{ matrix.pyver }} zstandard>=0.23.0 ${{ matrix.conda_deps }}
conda activate cptest
pytest -v -ss --cov=conda_pack --cov-branch --cov-report=xml conda_pack/tests
- uses: codecov/codecov-action@v5
with:
token: ${{ secrets.CODECOV_TOKEN }}
upload:
needs: tests
runs-on: ubuntu-latest
if: github.event_name == 'push'
steps:
- name: Retrieve the source code
uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Download the build artifacts
uses: actions/download-artifact@v4
with:
name: package-${{ github.sha }}
path: conda-bld
- name: Install deployment dependencies and build the docs
run: |
source $CONDA/bin/activate
conda config --append channels conda-forge
conda install -y sphinx numpydoc sphinxcontrib-autoprogram make anaconda-client
python -m pip install -e .
cd docs
make html
- name: Deploy the documentation
if: startsWith(github.ref, 'refs/tags/')
id: deployment
uses: actions/upload-pages-artifact@v3
with:
path: ./docs/build/html
- name: Upload to anaconda.org
env:
ANACONDA_TOKEN: ${{ secrets.ANACONDA_TOKEN }}
GITHUB_REF: ${{ github.ref }}
run: |
source $CONDA/bin/activate
[[ "$GITHUB_REF" =~ ^refs/tags/ ]] || export LABEL="--label dev"
anaconda --verbose --token $ANACONDA_TOKEN upload --user ctools $LABEL conda-bld/*/*.tar.bz2 --force
deploy:
if: startsWith(github.ref, 'refs/tags/')
needs: upload
# Grant GITHUB_TOKEN the permissions required to make a Pages deployment
permissions:
pages: write # to deploy to Pages
id-token: write # to verify the deployment originates from an appropriate source
# Deploy to the github-pages environment
environment:
name: github-pages
url: ${{ steps.deployment.outputs.page_url }}
# Specify runner + deployment step
runs-on: ubuntu-latest
steps:
- name: Deploy to GitHub Pages
id: deployment
uses: actions/deploy-pages@v4 # or specific "vX.X.X" version tag for this action