test of deployment use kubectl
Some checks failed
Build and Push Docker Image / build-and-push (push) Failing after 10s

This commit is contained in:
Richard Mrasek
2026-06-12 08:44:49 +02:00
parent f4e7e79ec1
commit 9acae349c4

View File

@@ -76,59 +76,28 @@ jobs:
docker push "${IMAGE_REPO}:latest" docker push "${IMAGE_REPO}:latest"
docker push "${IMAGE_REPO}:${SHORT_SHA}" docker push "${IMAGE_REPO}:${SHORT_SHA}"
- name: Install helm and kubectl - name: Setup kubectl
run: | run: |
ARCH="$(uname -m)"
if [ "${ARCH}" = "x86_64" ]; then
ARCH="amd64"
elif [ "${ARCH}" = "aarch64" ]; then
ARCH="arm64"
fi
if ! command -v helm >/dev/null 2>&1; then
apk add --no-cache curl tar gzip ca-certificates
HELM_VERSION="v3.16.4"
curl -fsSL "https://get.helm.sh/helm-${HELM_VERSION}-linux-${ARCH}.tar.gz" -o /tmp/helm.tgz
tar -xzf /tmp/helm.tgz -C /tmp
mv "/tmp/linux-${ARCH}/helm" /usr/local/bin/helm
chmod +x /usr/local/bin/helm
fi
if ! command -v kubectl >/dev/null 2>&1; then
KUBECTL_VERSION="v1.31.2"
curl -fsSL "https://dl.k8s.io/release/${KUBECTL_VERSION}/bin/linux/${ARCH}/kubectl" -o /usr/local/bin/kubectl
chmod +x /usr/local/bin/kubectl
fi
helm version
kubectl version --client
- name: Deploy to Dagster with Helm
run: |
if [ -z "${{ secrets.KUBE_CONFIG_B64 }}" ]; then
echo "Missing KUBE_CONFIG_B64 secret"
exit 1
fi
COMMIT_SHA="${GITHUB_SHA:-$GITEA_SHA}"
SHORT_SHA="$(echo "${COMMIT_SHA}" | cut -c1-12)"
mkdir -p "${HOME}/.kube" mkdir -p "${HOME}/.kube"
echo "${{ secrets.KUBE_CONFIG_B64 }}" | base64 -d > "${HOME}/.kube/config" echo "${{ secrets.KUBE_CONFIG_B64 }}" | base64 -d > "${HOME}/.kube/config"
export KUBECONFIG="${HOME}/.kube/config" chmod 600 "${HOME}/.kube/config"
helm upgrade --install "${HELM_RELEASE}" dagster \ - name: Update Dagster user deployment image
--repo "https://code.europa.eu/api/v4/projects/1304/packages/helm/stable" \ run: |
--version "${DAGSTER_CHART_VERSION}" \ COMMIT_SHA="${GITHUB_SHA:-$GITEA_SHA}"
--namespace "${K8S_NAMESPACE}" \ SHORT_SHA="$(echo "${COMMIT_SHA}" | cut -c1-12)"
--reuse-values \
--set-string "dagster.dagster-user-deployments.deployments[0].image.repository=${IMAGE_REPO}" \ # Patch the dagster-user-deployments to update the image tag
--set-string "dagster.dagster-user-deployments.deployments[0].image.tag=${SHORT_SHA}" kubectl patch statefulset dagster-user-deployments \
-n "${K8S_NAMESPACE}" \
DEPLOYMENT_NAME="$(kubectl -n "${K8S_NAMESPACE}" get deployment -o jsonpath='{range .items[*]}{.metadata.name}{"\n"}{end}' | grep 'template-code-location' | head -n 1)" --type='json' \
if [ -n "${DEPLOYMENT_NAME}" ]; then -p="[{'op': 'replace', 'path': '/spec/template/spec/containers/0/image', 'value':'${IMAGE_REPO}:${SHORT_SHA}'}]"
kubectl -n "${K8S_NAMESPACE}" rollout restart "deployment/${DEPLOYMENT_NAME}"
kubectl -n "${K8S_NAMESPACE}" rollout status "deployment/${DEPLOYMENT_NAME}" --timeout=300s # Trigger rollout restart to pick up new image
else kubectl rollout restart statefulset/dagster-user-deployments \
echo "No deployment name matched template-code-location; Helm upgrade completed without explicit rollout restart." -n "${K8S_NAMESPACE}"
fi
# Wait for rollout to complete
kubectl rollout status statefulset/dagster-user-deployments \
-n "${K8S_NAMESPACE}" \
--timeout=5m