Merge pull request #6038 from andrewpbray/patch-7 #14
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 workflow re-deploys SPECIFIC hubs to staging or prod if the single-user | |
# server image or config has changed based on the PR labels "hub: <hubname>". | |
# | |
# however, this workflow will be not run if the PR labels of "hub-images" or | |
# "jupyterhub-deployment" are present, as these labels will trigger the | |
# "deploy-jupyterhub-base-images.yaml" workflow which re-deploys every hub. | |
# | |
name: Deploy staging and prod hubs | |
on: | |
workflow_dispatch: | |
push: | |
branches: | |
- staging | |
- prod | |
jobs: | |
deploy-hubs-to-staging: | |
if: github.event_name == 'push' && github.ref == 'refs/heads/staging' | |
runs-on: ubuntu-latest | |
steps: | |
- name: Get PR labels | |
id: pr-labels | |
uses: irby/[email protected] | |
with: | |
github-token: ${{ secrets.GITHUB_TOKEN }} | |
- name: Pull out any hubs that need deploying from the labels on the merge commit to staging | |
run: | | |
echo "PR labels: ${{ steps.pr-labels.outputs.labels }}" | |
HUBS=() | |
# If the PR labels "hub-images" or "jupyterhub-deployment" are present, this | |
# means the base hub image has changed, and all hubs (staging or prod) need to | |
# be redeployed. The rest of this job will not run in that case. | |
if [ -c "${GITHUB_PR_LABEL_HUB_IMAGES}" ] || [ -c "${GITHUB_PR_LABEL_JUPYTERHUB_DEPLOYMENT}" ]; then | |
echo "Base hub image has changed, not deploying individual hubs to staging" | |
else | |
# deploy any hubs that have been labeled for deployment | |
for label in $(echo -e "${{ steps.pr-labels.outputs.labels }}"); do | |
if [[ "$label" == hub-* ]]; then | |
hub_name=$(echo $label | awk -F'-' '{print $2}') | |
HUBS+="$hub_name " | |
echo "DEPLOY=1" >> $GITHUB_ENV | |
fi | |
done | |
echo "DEPLOY_HUBS=${HUBS[@]}" >> $GITHUB_ENV | |
fi | |
- name: Check out the image repo | |
if: ${{ env.DEPLOY }} | |
uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 # OR "2" -> To retrieve the preceding commit. | |
- name: Setup python | |
if: ${{ env.DEPLOY }} | |
uses: actions/setup-python@v5 | |
with: | |
python-version: '3.11' | |
- name: Install dependencies | |
if: ${{ env.DEPLOY }} | |
run: | | |
python -m pip install --upgrade pip | |
pip install -r requirements.txt | |
pip install --force-reinstall git+https://github.com/shaneknapp/hubploy.git@major-refactor | |
- name: Auth to gcloud | |
if: ${{ env.DEPLOY }} | |
uses: google-github-actions/auth@v2 | |
with: | |
credentials_json: ${{ secrets.GKE_KEY }} | |
project_id: ${{ secrets.GCP_PROJECT_ID }} | |
- name: Install Google Cloud SDK | |
if: ${{ env.DEPLOY }} | |
uses: google-github-actions/setup-gcloud@v2 | |
with: | |
install_components: 'gke-gcloud-auth-plugin' | |
- name: Install SOPS | |
if: ${{ env.DEPLOY }} | |
run: | | |
mkdir -p ${HOME}/bin | |
curl -sSL https://github.com/getsops/sops/releases/download/v3.9.0/sops-v3.9.0.linux.amd64 -o ${HOME}/bin/sops | |
chmod 755 ${HOME}/bin/sops | |
echo "${HOME}/bin" >> $GITHUB_PATH | |
- name: Store SOPS secret in a file | |
if: ${{ env.DEPLOY }} | |
run: | | |
cat << EOF > ${HOME}/sops.key | |
${{ secrets.SOPS_KEY }} | |
EOF | |
echo "GOOGLE_APPLICATION_CREDENTIALS=${HOME}/sops.key" >> $GITHUB_ENV | |
- name: Install Helm | |
if: ${{ env.DEPLOY }} | |
run: | | |
curl -L https://get.helm.sh/helm-v3.13.3-linux-amd64.tar.gz | tar -xzf - | |
mv linux-amd64/helm /usr/local/bin | |
helm repo add jupyterhub https://jupyterhub.github.io/helm-chart/ | |
helm repo update | |
- name: Deploy hubs to staging | |
if: ${{ env.DEPLOY }} | |
run: | | |
for hub in $(echo -e "${{ env.DEPLOY_HUBS }}"); do | |
echo "Deploying $hub to staging" | |
echo "hubploy --verbose deploy $hub hub staging" | |
done | |
deploy-hubs-to-prod: | |
if: github.event_name == 'push' && github.ref == 'refs/heads/prod' | |
runs-on: ubuntu-latest | |
steps: | |
- name: Get PR labels | |
id: pr-labels | |
uses: irby/[email protected] | |
with: | |
github-token: ${{ secrets.GITHUB_TOKEN }} | |
- name: Pull out any hubs that need deploying from the labels on the merge commit to prod | |
run: | | |
echo "PR labels: ${{ steps.pr-labels.outputs.labels }}" | |
HUBS=() | |
# If the PR labels "hub-images" or "jupyterhub-deployment" are present, this | |
# means the base hub image has changed, and all hubs (staging or prod) need to | |
# be redeployed. The rest of this job will not run in that case. | |
if [ -c "${GITHUB_PR_LABEL_HUB_IMAGES}" ] || [ -c "${GITHUB_PR_LABEL_JUPYTERHUB_DEPLOYMENT}" ]; then | |
echo "Base hub image has changed, not deploying individual hubs to prod" | |
else | |
# deploy any hubs that have been labeled for deployment | |
for label in $(echo -e "${{ steps.pr-labels.outputs.labels }}"); do | |
if [[ "$label" == hub-* ]]; then | |
hub_name=$(echo $label | awk -F'-' '{print $2}') | |
HUBS+="$hub_name " | |
echo "DEPLOY=1" >> $GITHUB_ENV | |
fi | |
done | |
echo "DEPLOY_HUBS=${HUBS[@]}" >> $GITHUB_ENV | |
fi | |
- name: Check out the image repo | |
if: ${{ env.DEPLOY }} | |
uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 # OR "2" -> To retrieve the preceding commit. | |
- name: Setup python | |
if: ${{ env.DEPLOY }} | |
uses: actions/setup-python@v5 | |
with: | |
python-version: '3.11' | |
- name: Install dependencies | |
if: ${{ env.DEPLOY }} | |
run: | | |
python -m pip install --upgrade pip | |
pip install -r requirements.txt | |
pip install --force-reinstall git+https://github.com/shaneknapp/hubploy.git@major-refactor | |
- name: Auth to gcloud | |
if: ${{ env.DEPLOY }} | |
uses: google-github-actions/auth@v2 | |
with: | |
credentials_json: ${{ secrets.GKE_KEY }} | |
project_id: ${{ secrets.GCP_PROJECT_ID }} | |
- name: Install Google Cloud SDK | |
if: ${{ env.DEPLOY }} | |
uses: google-github-actions/setup-gcloud@v2 | |
with: | |
install_components: 'gke-gcloud-auth-plugin' | |
- name: Install SOPS | |
if: ${{ env.DEPLOY }} | |
run: | | |
mkdir -p ${HOME}/bin | |
curl -sSL https://github.com/getsops/sops/releases/download/v3.9.0/sops-v3.9.0.linux.amd64 -o ${HOME}/bin/sops | |
chmod 755 ${HOME}/bin/sops | |
echo "${HOME}/bin" >> $GITHUB_PATH | |
- name: Store SOPS secret in a file | |
if: ${{ env.DEPLOY }} | |
run: | | |
cat << EOF > ${HOME}/sops.key | |
${{ secrets.SOPS_KEY }} | |
EOF | |
echo "GOOGLE_APPLICATION_CREDENTIALS=${HOME}/sops.key" >> $GITHUB_ENV | |
- name: Install Helm | |
if: ${{ env.DEPLOY }} | |
run: | | |
curl -L https://get.helm.sh/helm-v3.13.3-linux-amd64.tar.gz | tar -xzf - | |
mv linux-amd64/helm /usr/local/bin | |
helm repo add jupyterhub https://jupyterhub.github.io/helm-chart/ | |
helm repo update | |
- name: Deploy hubs to prod | |
if: ${{ env.DEPLOY }} | |
run: | | |
for hub in $(echo -e "${{ env.DEPLOY_HUBS }}"); do | |
echo "Deploying $hub to prod" | |
echo "hubploy --verbose deploy $hub hub prod" | |
done |