Skip to content

Commit 86d4c4f

Browse files
authored
test: improve pr deployments (#8720)
1 parent 844ef76 commit 86d4c4f

File tree

1 file changed

+70
-29
lines changed

1 file changed

+70
-29
lines changed

.github/workflows/pr-deploy.yaml

Lines changed: 70 additions & 29 deletions
Original file line numberDiff line numberDiff line change
@@ -29,7 +29,6 @@ jobs:
2929
PR_TITLE: ${{ steps.pr_number.outputs.PR_TITLE }}
3030
PR_URL: ${{ steps.pr_number.outputs.PR_URL }}
3131
PR_BRANCH: ${{ steps.pr_number.outputs.PR_BRANCH }}
32-
COMMENT_ID: ${{ steps.comment_id.outputs.comment-id }}
3332
CODER_BASE_IMAGE_TAG: ${{ steps.set_tags.outputs.CODER_BASE_IMAGE_TAG }}
3433
CODER_IMAGE_TAG: ${{ steps.set_tags.outputs.CODER_IMAGE_TAG }}
3534

@@ -43,6 +42,7 @@ jobs:
4342
PR_NUMBER=${{ github.event.inputs.pr_number }}"
4443
else
4544
PR_NUMBER=${{ github.event.issue.number }}"
45+
fi
4646
PR_TITLE=$(gh pr view $PR_NUMBER --json title | jq -r '.title')
4747
PR_BRANCH=$(gh pr view $PR_NUMBER --json headRefName | jq -r '.headRefName')
4848
echo "PR_URL=https://github.com/coder/coder/pull/$PR_NUMBER" >> $GITHUB_OUTPUT
@@ -62,24 +62,15 @@ jobs:
6262
CODER_BASE_IMAGE_TAG: ghcr.io/coder/coder-preview-base:pr${{ steps.pr_number.outputs.PR_NUMBER }}
6363
CODER_IMAGE_TAG: ghcr.io/coder/coder-preview:pr${{ steps.pr_number.outputs.PR_NUMBER }}
6464

65-
- name: Find Comment
66-
uses: peter-evans/find-comment@v2
67-
id: fc
68-
with:
69-
issue-number: ${{ steps.pr_number.outputs.PR_NUMBER }}
70-
comment-author: "github-actions[bot]"
71-
body-includes: This deployment will be deleted when the PR is closed
72-
7365
- name: Comment on PR
7466
id: comment_id
7567
uses: peter-evans/create-or-update-comment@v3
7668
with:
77-
comment-id: ${{ steps.fc.outputs.comment-id }}
7869
issue-number: ${{ steps.pr_number.outputs.PR_NUMBER }}
79-
edit-mode: replace
8070
body: |
8171
:rocket: Deploying PR ${{ steps.pr_number.outputs.PR_NUMBER }} ...
8272
:warning: This deployment will be deleted when the PR is closed.
73+
reactions: "-1"
8374

8475
build:
8576
needs: pr_commented
@@ -145,7 +136,7 @@ jobs:
145136
run: |
146137
set -euxo pipefail
147138
mkdir -p ~/.kube
148-
echo "${{ secrets.DELIVERYBOT_KUBECONFIG }}" > ~/.kube/config
139+
echo "${{ secrets.PR_DEPLOYMENTS_KUBECONFIG }}" > ~/.kube/config
149140
export KUBECONFIG=~/.kube/config
150141
151142
- name: Create PR namespace
@@ -155,6 +146,35 @@ jobs:
155146
kubectl delete namespace "pr${{ env.PR_NUMBER }}" || true
156147
kubectl create namespace "pr${{ env.PR_NUMBER }}"
157148
149+
- name: Setup ingress
150+
run: |
151+
cat <<EOF > ingress.yaml
152+
apiVersion: networking.k8s.io/v1
153+
kind: Ingress
154+
metadata:
155+
name: pr${{ env.PR_NUMBER }}
156+
namespace: pr${{ env.PR_NUMBER }}
157+
annotations:
158+
cert-manager.io/cluster-issuer: letsencrypt
159+
spec:
160+
tls:
161+
- hosts:
162+
- "*.${{ secrets.PR_DEPLOYMENTS_DOMAIN }}"
163+
secretName: pr${{ env.PR_NUMBER }}-tls
164+
rules:
165+
- host: "pr${{ env.PR_NUMBER }}.${{ secrets.PR_DEPLOYMENTS_DOMAIN }}"
166+
http:
167+
paths:
168+
- pathType: Prefix
169+
path: "/"
170+
backend:
171+
service:
172+
name: coder
173+
port:
174+
number: 80
175+
EOF
176+
kubectl apply -f ingress.yaml
177+
158178
- name: Install Helm chart
159179
run: |
160180
helm upgrade --install pr${{ env.PR_NUMBER }} ./helm \
@@ -164,25 +184,30 @@ jobs:
164184
--set coder.service.type=ClusterIP \
165185
--set coder.serviceAccount.enableDeployments=true \
166186
--set coder.env[0].name=CODER_ACCESS_URL \
167-
--set coder.env[0].value="" \
187+
--set coder.env[0].value="pr${{ env.PR_NUMBER }}.${{ secrets.PR_DEPLOYMENTS_DOMAIN }}" \
188+
--set coder.env[1].name=CODER_WILDCARD_ACCESS_URL \
189+
--set coder.env[1].value="*--pr${{ env.PR_NUMBER }}.${{ secrets.PR_DEPLOYMENTS_DOMAIN }}" \
190+
--set coder.env[2].name=CODER_EXPERIMENTS \
191+
--set coder.env[2].value="*" \
192+
# Uncomment this when https://github.com/coder/coder/issues/8714 is resolved
193+
# --set coder.env[3].name=CODER_OAUTH2_GITHUB_ALLOW_SIGNUPS \
194+
# --set coder.env[3].value=true \
195+
# --set coder.env[4].name=CODER_OAUTH2_GITHUB_CLIENT_ID \
196+
# --set coder.env[4].value=${{ secrets.PR_DEPLOYMENTS_GITHUB_OAUTH_CLIENT_ID }} \
197+
# --set coder.env[5].name=CODER_OAUTH2_GITHUB_CLIENT_SECRET \
198+
# --set coder.env[5].value=${{ secrets.PR_DEPLOYMENTS_GITHUB_OAUTH_CLIENT_SECRET }} \
199+
# --set coder.env[6].name=CODER_OAUTH2_GITHUB_ALLOWED_ORGS \
200+
# --set coder.env[6].value=coder \
201+
# --set coder.env[7].name=CODER_OAUTH2_GITHUB_REDIRECT_URI \
202+
# --set coder.env[7].value="https://pr${{ env.PR_NUMBER }}.${{ secrets.PR_DEPLOYMENTS_DOMAIN }}/gitauth/github/callback \
168203
--force
169204
170-
- name: Get deployment URL
171-
id: deployment_url
172-
run: |
173-
set -euo pipefail
174-
kubectl rollout status deployment/coder --namespace "pr${{ env.PR_NUMBER }}"
175-
POD_NAME=$(kubectl get pods -n "pr${{ env.PR_NUMBER }}" | awk 'NR==2{print $1}')
176-
CODER_ACCESS_URL=$(kubectl logs $POD_NAME -n "pr${{ env.PR_NUMBER }}" | grep "Web UI:" | awk -F ':' '{print $2":"$3}' | awk '{$1=$1};1')
177-
echo "::add-mask::$CODER_ACCESS_URL"
178-
echo "CODER_ACCESS_URL=$CODER_ACCESS_URL" >> $GITHUB_OUTPUT
179-
180205
- name: Install coder-logstream-kube
181206
run: |
182207
helm repo add coder-logstream-kube https://helm.coder.com/logstream-kube
183-
helm install coder-logstream-kube coder-logstream-kube/coder-logstream-kube \
208+
helm upgrade --install coder-logstream-kube coder-logstream-kube/coder-logstream-kube \
184209
--namespace "pr${{ env.PR_NUMBER }}" \
185-
--set url="${{ steps.deployment_url.outputs.CODER_ACCESS_URL }}"
210+
--set url="https://pr${{ env.PR_NUMBER }}.${{ secrets.PR_DEPLOYMENTS_DOMAIN }}"
186211
187212
- name: Send Slack notification
188213
run: |
@@ -191,17 +216,33 @@ jobs:
191216
"pr_number": "'"${{ env.PR_NUMBER }}"'",
192217
"pr_url": "'"${{ env.PR_URL }}"'",
193218
"pr_title": "'"${{ env.PR_TITLE }}"'",
194-
"pr_access_url": "'"${{ steps.deployment_url.outputs.CODER_ACCESS_URL }}"'" }' ${{ secrets.PR_DEPLOYMENTS_SLACK_WEBHOOK }}
219+
"pr_access_url": "'"${{ env.PR_DEPLOYMENT_ACCESS_URL }}'" }' ${{ secrets.PR_DEPLOYMENTS_SLACK_WEBHOOK }}
195220
echo "Slack notification sent"
221+
env:
222+
PR_DEPLOYMENT_ACCESS_URL: "https://pr${{ env.PR_NUMBER }}.${{ secrets.PR_DEPLOYMENTS_DOMAIN }}"
223+
224+
- name: Find Comment
225+
uses: peter-evans/find-comment@v2
226+
id: fc
227+
with:
228+
issue-number: ${{ env.PR_NUMBER }}
229+
comment-author: "github-actions[bot]"
230+
body-includes: This deployment will be deleted when the PR is closed
196231

197232
- name: Comment on PR
198233
uses: peter-evans/create-or-update-comment@v3
199234
with:
200235
issue-number: ${{ env.PR_NUMBER }}
201236
edit-mode: replace
202-
comment-id: ${{ needs.pr_commented.outputs.COMMENT_ID }}
237+
comment-id: ${{ steps.fc.outputs.comment-id }}
203238
body: |
204239
:heavy_check_mark: Deployed PR ${{ env.PR_NUMBER }} successfully.
205-
:rocket: Access the deployment link [here](https://codercom.slack.com/archives/C05DNE982E8).
240+
:rocket: Access the deployment link [here](${{ env.PR_DEPLOYMENT_ACCESS_URL }}).
206241
:warning: This deployment will be deleted when the PR is closed.
207-
reactions: "+1"
242+
reactions: |
243+
+1
244+
rocket
245+
reactions-edit-mode: replace
246+
247+
env:
248+
PR_DEPLOYMENT_ACCESS_URL: "https://pr${{ env.PR_NUMBER }}.${{ secrets.PR_DEPLOYMENTS_DOMAIN }}"

0 commit comments

Comments
 (0)