29
29
PR_TITLE : ${{ steps.pr_number.outputs.PR_TITLE }}
30
30
PR_URL : ${{ steps.pr_number.outputs.PR_URL }}
31
31
PR_BRANCH : ${{ steps.pr_number.outputs.PR_BRANCH }}
32
- COMMENT_ID : ${{ steps.comment_id.outputs.comment-id }}
33
32
CODER_BASE_IMAGE_TAG : ${{ steps.set_tags.outputs.CODER_BASE_IMAGE_TAG }}
34
33
CODER_IMAGE_TAG : ${{ steps.set_tags.outputs.CODER_IMAGE_TAG }}
35
34
43
42
PR_NUMBER=${{ github.event.inputs.pr_number }}"
44
43
else
45
44
PR_NUMBER=${{ github.event.issue.number }}"
45
+ fi
46
46
PR_TITLE=$(gh pr view $PR_NUMBER --json title | jq -r '.title')
47
47
PR_BRANCH=$(gh pr view $PR_NUMBER --json headRefName | jq -r '.headRefName')
48
48
echo "PR_URL=https://github.com/coder/coder/pull/$PR_NUMBER" >> $GITHUB_OUTPUT
@@ -62,24 +62,15 @@ jobs:
62
62
CODER_BASE_IMAGE_TAG : ghcr.io/coder/coder-preview-base:pr${{ steps.pr_number.outputs.PR_NUMBER }}
63
63
CODER_IMAGE_TAG : ghcr.io/coder/coder-preview:pr${{ steps.pr_number.outputs.PR_NUMBER }}
64
64
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
-
73
65
- name : Comment on PR
74
66
id : comment_id
75
67
uses : peter-evans/create-or-update-comment@v3
76
68
with :
77
- comment-id : ${{ steps.fc.outputs.comment-id }}
78
69
issue-number : ${{ steps.pr_number.outputs.PR_NUMBER }}
79
- edit-mode : replace
80
70
body : |
81
71
:rocket: Deploying PR ${{ steps.pr_number.outputs.PR_NUMBER }} ...
82
72
:warning: This deployment will be deleted when the PR is closed.
73
+ reactions : " -1"
83
74
84
75
build :
85
76
needs : pr_commented
@@ -145,7 +136,7 @@ jobs:
145
136
run : |
146
137
set -euxo pipefail
147
138
mkdir -p ~/.kube
148
- echo "${{ secrets.DELIVERYBOT_KUBECONFIG }}" > ~/.kube/config
139
+ echo "${{ secrets.PR_DEPLOYMENTS_KUBECONFIG }}" > ~/.kube/config
149
140
export KUBECONFIG=~/.kube/config
150
141
151
142
- name : Create PR namespace
@@ -155,6 +146,35 @@ jobs:
155
146
kubectl delete namespace "pr${{ env.PR_NUMBER }}" || true
156
147
kubectl create namespace "pr${{ env.PR_NUMBER }}"
157
148
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
+
158
178
- name : Install Helm chart
159
179
run : |
160
180
helm upgrade --install pr${{ env.PR_NUMBER }} ./helm \
@@ -164,25 +184,30 @@ jobs:
164
184
--set coder.service.type=ClusterIP \
165
185
--set coder.serviceAccount.enableDeployments=true \
166
186
--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 \
168
203
--force
169
204
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
-
180
205
- name : Install coder-logstream-kube
181
206
run : |
182
207
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 \
184
209
--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 }}"
186
211
187
212
- name : Send Slack notification
188
213
run : |
@@ -191,17 +216,33 @@ jobs:
191
216
"pr_number": "'"${{ env.PR_NUMBER }}"'",
192
217
"pr_url": "'"${{ env.PR_URL }}"'",
193
218
"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 }}
195
220
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
196
231
197
232
- name : Comment on PR
198
233
uses : peter-evans/create-or-update-comment@v3
199
234
with :
200
235
issue-number : ${{ env.PR_NUMBER }}
201
236
edit-mode : replace
202
- comment-id : ${{ needs.pr_commented .outputs.COMMENT_ID }}
237
+ comment-id : ${{ steps.fc .outputs.comment-id }}
203
238
body : |
204
239
: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 }} ).
206
241
: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