chore(python): upgrade as high as it works #908
Workflow file for this run
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
# This is a GitHub workflow defining a set of jobs with a set of steps. | |
# ref: https://docs.github.com/en/actions/learn-github-actions/workflow-syntax-for-github-actions | |
# | |
name: Test | |
on: | |
pull_request: | |
paths-ignore: | |
- "docs/**" | |
- "**.md" | |
- "**.rst" | |
- ".github/workflows/*" | |
- "!.github/workflows/test.yaml" | |
push: | |
paths-ignore: | |
- "docs/**" | |
- "**.md" | |
- "**.rst" | |
- ".github/workflows/*" | |
- "!.github/workflows/test.yaml" | |
branches: ["main"] | |
tags: ["**"] | |
workflow_dispatch: | |
env: | |
commit_msg: ${{ github.event.head_commit.message }} | |
jobs: | |
main-tests: | |
runs-on: ubuntu-24.04 | |
timeout-minutes: 7 | |
strategy: | |
fail-fast: false | |
matrix: | |
include: | |
# We test against different versions of Python and Golang, but not | |
# against different versions of Node. | |
# | |
# - The Python version installed where dask-gateway and | |
# dask-gateway-proxy is run by the end user matters, so we test | |
# against all the versions we intend to support. | |
# | |
# We could for example choose to test against the versions that | |
# hasn't reached end of life yet: https://endoflife.date/python. | |
# | |
# - The Golang version that compiles | |
# dask-gateway-server/dask-gateway-proxy bundled for the | |
# dask-gateway-server Python package is the only thing that matters. | |
# Due to that, we can test fewer versions of Golang. | |
# | |
# We could for example choose to test against the versions that | |
# hasn't reached end of life yet: https://endoflife.date/go. | |
# | |
# - Node is a dependency for JupyterHub's configurable-http-proxy that | |
# we test integration with. We can test against only one version and | |
# that would be fine. | |
# | |
- python-version: "3.10" | |
go-version: "1.20" | |
- python-version: "3.11" | |
go-version: "1.20" | |
- python-version: "3.12" | |
go-version: "1.20" | |
- python-version: "3.13" | |
go-version: "1.21" | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: actions/setup-python@v5 | |
with: | |
python-version: "${{ matrix.python-version }}" | |
- uses: actions/setup-go@v5 | |
with: | |
go-version: "${{ matrix.go-version }}" | |
- uses: actions/setup-node@v4 | |
# jupyterhub will when being mock started as part of running tests depend | |
# on the Node npm package configurable-http-proxy. | |
# | |
- name: Install jupyterhub with system dependencies | |
run: | | |
npm install -g configurable-http-proxy | |
pip install jupyterhub | |
- name: Install Python test requirements | |
run: | | |
pip install -r tests/requirements.txt | |
- name: List Python dependencies | |
run: | | |
pip freeze | |
- name: Check that golang binary was built | |
run: | | |
echo "As part of installing dask-gateway-server, a golang binary" | |
echo "should be built and bundled, this checks that it was." | |
FILE=dask-gateway-server/dask_gateway_server/proxy/dask-gateway-proxy | |
if [ -f "$FILE" ]; then | |
echo "$FILE exists." | |
else | |
echo "$FILE does not exist." | |
exit 1 | |
fi | |
- name: Run Python tests | |
run: | | |
pytest -v tests/ -k 'not kubernetes' | |
- name: Install Go test requirements | |
run: | | |
cd dask-gateway-server/dask-gateway-proxy | |
go get github.com/stretchr/testify/assert | |
# pkg level tests | |
- name: Run Go Tests - pkg/router | |
run: | | |
cd dask-gateway-server/dask-gateway-proxy | |
go test ./pkg/router | |
- name: Run Go Tests - pkg/sni | |
run: | | |
cd dask-gateway-server/dask-gateway-proxy | |
go test ./pkg/sni | |
# logging framework tests | |
- name: Run Go Tests - internal/logging | |
run: | | |
cd dask-gateway-server/dask-gateway-proxy | |
go test ./internal/logging | |
kubernetes-tests: | |
name: Test k8s backend & chart | |
runs-on: ubuntu-24.04 | |
timeout-minutes: 15 | |
strategy: | |
fail-fast: false | |
matrix: | |
# We run this job multiple times with different parameterization | |
# specified below, these parameters have no meaning on their own and | |
# gain meaning on how job steps use them. | |
# | |
# k3s-version: https://github.com/rancher/k3s/tags | |
# k3s-channel: https://update.k3s.io/v1-release/channels | |
# | |
include: | |
- k3s-channel: v1.29 | |
dask-namespace: separate-namespace | |
- k3s-channel: v1.30 | |
dask-namespace: default | |
upgrade-from: "2022.4.0" | |
- k3s-channel: v1.31 | |
dask-namespace: default | |
- k3s-channel: v1.32 | |
dask-namespace: default | |
- k3s-channel: stable | |
dask-namespace: default | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
# chartpress requires git history to set chart version and image tags | |
# correctly | |
fetch-depth: 0 | |
- uses: actions/setup-python@v5 | |
with: | |
python-version: "3.13" | |
# Starts a k8s cluster with NetworkPolicy enforcement and installs both | |
# kubectl and helm | |
# | |
# ref: https://github.com/jupyterhub/action-k3s-helm/ | |
# | |
- uses: jupyterhub/action-k3s-helm@v4 | |
with: | |
k3s-channel: ${{ matrix.k3s-channel }} | |
metrics-enabled: false | |
traefik-enabled: false | |
docker-enabled: true | |
- name: Install Python test requirements | |
run: | | |
DASK_GATEWAY_SERVER__NO_PROXY=true pip install -r tests/requirements.txt | |
pip list | |
- name: Generate values.schema.json from YAML equivalent | |
run: resources/helm/tools/generate-json-schema.py | |
- name: helm lint | |
run: | | |
helm lint resources/helm/dask-gateway \ | |
--values=resources/helm/testing/chart-install-values.yaml | |
- name: helm template | |
run: | | |
helm template test-dask-gateway resources/helm/dask-gateway \ | |
--include-crds \ | |
--values=resources/helm/testing/chart-install-values.yaml | |
- if: matrix.dask-namespace != 'default' | |
run: | | |
kubectl create namespace ${{ matrix.dask-namespace }} || true | |
- name: helm install previous version ${{ matrix.upgrade-from }} | |
if: matrix.upgrade-from != '' | |
run: | | |
# relocate to a directory where there isn't a folder named | |
# dask-gateway to avoid making helm think we mean a local folder | |
cd resources/helm/testing | |
helm install \ | |
test-dask-gateway \ | |
dask-gateway \ | |
--repo=https://helm.dask.org \ | |
--version=${{ matrix.upgrade-from }} \ | |
--values=chart-install-values.yaml \ | |
--wait \ | |
--timeout 1m0s | |
- working-directory: resources/helm | |
env: | |
# DOCKER_BUILDKIT is required for building images with --mount flags, | |
# as used in dask-gateway/Dockerfile. | |
DOCKER_BUILDKIT: "1" | |
run: chartpress | |
# If the Helm chart's CRDs have changed, helm won't upgrade them when | |
# running helm upgrade. | |
# | |
# See https://github.com/dask/dask-gateway/issues/553. | |
# | |
- name: Manual upgrade of CRDs | |
if: matrix.upgrade-from != '' | |
run: | | |
# A charts CRDs are installed once by default, but they aren't | |
# upgraded subsequently. Due to this, we manually upgrade the CRDs | |
# here. | |
kubectl apply --server-side --force-conflicts -f resources/helm/dask-gateway/crds/daskclusters.yaml | |
kubectl apply --server-side --force-conflicts -f resources/helm/dask-gateway/crds/traefik.yaml | |
- name: helm install (or upgrade) | |
run: | | |
helm upgrade \ | |
test-dask-gateway \ | |
resources/helm/dask-gateway \ | |
--install \ | |
--values=resources/helm/testing/chart-install-values.yaml \ | |
--set gateway.backend.namespace=${{ matrix.dask-namespace }} \ | |
--wait \ | |
--timeout 1m0s | |
- name: pytest | |
run: | | |
TEST_DASK_GATEWAY_KUBE=true \ | |
TEST_DASK_GATEWAY_KUBE_ADDRESS=http://localhost:30200/services/dask-gateway/ \ | |
TEST_DASK_GATEWAY_KUBE_NAMESPACE=${{ matrix.dask-namespace }} \ | |
pytest -v tests/kubernetes | |
# ref: https://github.com/jupyterhub/action-k8s-namespace-report | |
- name: Kubernetes namespace report | |
uses: jupyterhub/action-k8s-namespace-report@v1 | |
if: always() | |
with: | |
important-workloads: >- | |
deploy/api-test-dask-gateway | |
deploy/controller-test-dask-gateway | |
deploy/traefik-test-dask-gateway | |
# These tests starts a container with a specific backend (that can start | |
# schedulers/workers somehow), and installing test dependencies and running | |
# tests from within the container. | |
# | |
containerized-backend-tests: | |
name: "Test ${{ matrix.backend }} backend" | |
runs-on: ubuntu-24.04 | |
timeout-minutes: 5 | |
# packages read access is required for pull to the backend containers | |
permissions: | |
contents: read | |
packages: read | |
strategy: | |
fail-fast: false | |
matrix: | |
backend: | |
- hadoop | |
- pbs | |
- slurm | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Login to ghcr.io read access to CI image | |
run: echo "${{ secrets.github_token }}" | docker login ghcr.io -u $ --password-stdin | |
- name: Start container and mount local git repo | |
run: ./continuous_integration/docker/${{ matrix.backend }}/start.sh | |
- name: Install test requirements (inside container) | |
run: ./continuous_integration/docker/${{ matrix.backend }}/install.sh | |
- name: Run tests (inside container) | |
run: ./continuous_integration/docker/${{ matrix.backend }}/test.sh | |
- name: Print logs for debugging | |
if: always() | |
run: ./continuous_integration/docker/${{ matrix.backend }}/print_logs.sh |