Skip to content

ci-locks

ci-locks #199

Workflow file for this run

# Reference:
# - https://github.com/actions/cache
# - https://github.com/actions/checkout
# - https://github.com/actions/download-artifact
# - https://github.com/actions/upload-artifact
# - https://github.com/conda-incubator/setup-miniconda
name: ci-locks
on:
workflow_dispatch:
schedule:
# every sunday @ 00h03
- cron: "3 0 * * 0"
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
jobs:
build-locks:
name: "${{ matrix.session }} (${{ matrix.version }})"
runs-on: ubuntu-latest
defaults:
run:
shell: bash -l {0}
env:
ENV_NAME: "ci-locks"
strategy:
fail-fast: false
matrix:
os: ["ubuntu-latest"]
version: ["py39", "py310", "py311"]
session: ["lock"]
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0
- name: "environment configure"
env:
# Maximum cache period (in weeks) before forcing a cache refresh.
CACHE_WEEKS: 2
run: |
echo "CACHE_PERIOD=$(date +%Y).$(expr $(date +%U) / ${CACHE_WEEKS})" >> ${GITHUB_ENV}
- name: "conda package cache"
uses: ./.github/workflows/composite/conda-pkg-cache
with:
cache_period: ${{ env.CACHE_PERIOD }}
env_name: ${{ env.ENV_NAME }}
- name: "conda install"
uses: conda-incubator/setup-miniconda@v2
with:
miniforge-version: latest
channels: conda-forge,defaults
channel-priority: true
auto-update-conda: true
activate-environment: ${{ env.ENV_NAME }}
use-only-tar-bz2: false
- name: "conda environment cache"
uses: ./.github/workflows/composite/conda-env-cache
with:
cache_period: ${{ env.CACHE_PERIOD }}
env_name: ${{ env.ENV_NAME }}
install_packages: "pip 'tox<4'"
- name: "conda info"
run: |
conda info
conda list
- name: "tox cache"
uses: ./.github/workflows/composite/tox-cache
- name: "lock (${{ matrix.version }})"
env:
VTK_BUILD: " - vtk=*=qt_*"
run: |
tox -e ${{ matrix.version }}-lock
- uses: actions/upload-artifact@v3
with:
name: lock-artifacts
path: ${{ github.workspace }}/requirements/locks/${{ matrix.version }}*.txt
create-pr:
needs: build-locks
name: "create pull-request"
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0
- uses: actions/download-artifact@v3
with:
name: lock-artifacts
path: ${{ github.workspace }}/requirements/locks
- name: "generate token"
uses: tibdex/github-app-token@v2
id: generate-token
with:
app_id: ${{ secrets.AUTH_APP_ID }}
private_key: ${{ secrets.AUTH_APP_PRIVATE_KEY }}
- name: "generate pull-request"
id: cpr
uses: peter-evans/create-pull-request@153407881ec5c347639a548ade7d8ad1d6740e38
with:
token: ${{ steps.generate-token.outputs.token }}
add-paths: ${{ github.workspace }}/requirements/locks/*.txt
commit-message: "updated conda lock files"
branch: conda-lock-auto-update
delete-branch: true
title: "[geovista.ci] conda lock auto-update"
body: |
🤖 Bleep! Bloop!
Conda lock files for `linux-64` auto-updated to latest resolved environment of `geovista` dependencies.
labels: |
new: pull request
bot
- name: "show pull-request"
if: steps.cpr.outputs.pull-request-number != ''
run: |
echo "### :rocket: Pull-Request Summary" >> ${GITHUB_STEP_SUMMARY}
echo "" >> ${GITHUB_STEP_SUMMARY}
echo "The following locks pull-request has been auto-generated:" >> ${GITHUB_STEP_SUMMARY}
echo "- **PR** #${{ steps.cpr.outputs.pull-request-number }}" >> ${GITHUB_STEP_SUMMARY}
echo "- **URL** ${{ steps.cpr.outputs.pull-request-url }}" >> ${GITHUB_STEP_SUMMARY}
echo "- **Operation** [${{ steps.cpr.outputs.pull-request-operation }}]" >> ${GITHUB_STEP_SUMMARY}
echo "- **SHA** ${{ steps.cpr.outputs.pull-request-head-sha }}" >> ${GITHUB_STEP_SUMMARY}