-
Notifications
You must be signed in to change notification settings - Fork 585
64 lines (62 loc) · 3.33 KB
/
test-server.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
name: Run test server
on:
workflow_dispatch:
inputs:
ngrok_subdomain:
description: A subdomain to prefix ".ngrok.io" used for the server.
type: string
run_id:
description: The GitHub Actions run id of the triggering action, which will be used to await completion.
type: number
server_tag:
description: The docker tag to use when pulling the server
type: string
# Consider updating this in the calling workflow: https://github.com/realm/realm-js/blob/1a1a0edc354059122f1d9800c66a4a0860120fcb/.github/workflows/pr-realm-js.yml#L245
default: latest
jobs:
server:
name: Run test server
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Determine Ngrok subdomain
id: ngrok-config
run:
subdomain="${{ inputs.ngrok_subdomain || format('realm-js-test-server-{0}-{1}', github.run_id, github.run_attempt) }}";
echo "subdomain=${subdomain}" >> $GITHUB_OUTPUT;
echo "hostname=${subdomain}.ngrok.io" >> $GITHUB_OUTPUT;
- name: Start Ngrok
run: docker run --detach --network host --env NGROK_AUTHTOKEN ngrok/ngrok --connect_timeout 60 http --subdomain ${{ steps.ngrok-config.outputs.subdomain }} 9090
env:
NGROK_AUTHTOKEN: ${{ secrets.NGROK_AUTHTOKEN }}
- name: Preparing server entrypoint
# Writes an entrypoint script, which will patch the test-config to use the right hostnames, before it starts the server
run: |
echo '#!/bin/bash' >> patch-and-run.sh
echo 'NGROK_HOSTNAME=${{ steps.ngrok-config.outputs.hostname }}' >> patch-and-run.sh
# Replace localhost:9090 with the Ngrok hostname, "http" with "https" and "ws" with "wss"
echo 'sed -i -e "s/http:\/\/localhost:9090/https:\/\/${{ steps.ngrok-config.outputs.hostname }}/g" -e "s/ws:\/\/localhost:9090/wss:\/\/${{ steps.ngrok-config.outputs.hostname }}/g" /stitch/test_config.json' >> patch-and-run.sh
echo 'cat /stitch/test_config.json' >> patch-and-run.sh
# Start the server
echo '/run.sh' >> patch-and-run.sh
chmod u+x patch-and-run.sh
- name: Docker Login
uses: azure/docker-login@v1
with:
login-server: ghcr.io
username: realm-ci
password: ${{ secrets.REALM_CI_GITHUB_API_KEY }}
- name: Start server
run: docker run ${{ env.MODE }} --env AWS_ACCESS_KEY_ID --env AWS_SECRET_ACCESS_KEY --publish 9090:9090 --volume `pwd`/patch-and-run.sh:/patch-and-run.sh --entrypoint /patch-and-run.sh ghcr.io/realm/ci/mongodb-realm-test-server:${{ inputs.server_tag }}
env:
# Use --detach if a run_id is provided to watch for completion, --interactive otherwise
MODE: ${{ inputs.run_id && '--detach' || '--interactive' }}
AWS_ACCESS_KEY_ID: ${{ secrets.BAAS_AWS_ACCESS_KEY_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.BAAS_AWS_SECRET_ACCESS_KEY }}
- name: Wait for triggering run to complete
if: ${{ inputs.run_id }}
# Using " > /dev/null" because this will print the status of all jobs and steps every second
# Using "--interval 60" because we don't want to hit the GitHub actions requests limit
run: gh run watch --interval 60 ${{ inputs.run_id }} > /dev/null
env:
GH_TOKEN: ${{ github.token }}