-
Notifications
You must be signed in to change notification settings - Fork 7
138 lines (111 loc) · 4.08 KB
/
ee-ep-merge-end-to-end.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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
name: 'CI: EE - EP Merge - Integration Test'
on:
# Allow manual triggering
workflow_dispatch:
# Allow being called by another GitHub Action
workflow_call:
env:
COMPOSE_PROFILES: 'bip,bgs'
VRO_DEV_SECRETS_FOLDER: "${{ github.workspace }}/.cache/abd-vro-dev-secrets"
jobs:
integration-test:
runs-on: ubuntu-latest
steps:
- name: 'Checkout source code'
uses: actions/checkout@v3
- name: "Checkout abd-vro-dev-secrets repo"
uses: actions/checkout@v3
with:
# Checkout using a PAT so that we can access the internal repo
token: ${{ secrets.ACCESS_TOKEN_CHECKOUT_INTERNAL_REPO }}
repository: 'department-of-veterans-affairs/abd-vro-dev-secrets'
path: "${{ env.VRO_DEV_SECRETS_FOLDER }}"
- name: 'Build the images'
uses: ./.github/actions/build-images
- name: 'Start the containers'
run: |
source scripts/setenv.sh
# create basic auth token for RabbitMQ and export to github environment
BASIC_AUTH=$(echo "${RABBITMQ_USERNAME}:${RABBITMQ_PASSWORD}" | base64)
{
echo "RABBITMQ_USERNAME=${RABBITMQ_USERNAME}"
echo "RABBITMQ_PASSWORD=${RABBITMQ_PASSWORD}"
echo "RABBITMQ_BASIC_AUTH=${BASIC_AUTH}"
} >> "$GITHUB_ENV"
export -p | sed 's/declare -x //'
./gradlew :dockerComposeUp
- name: 'Wait for containers to start'
run: sleep 60s
shell: bash
- name: 'Wait for RabbitMQ to be ready'
uses: indiesdev/[email protected]
with:
url: 'http://localhost:15672/api/vhosts'
method: 'GET'
basic-auth-token: '${{env.RABBITMQ_BASIC_AUTH}}'
accept: 200
# Retry every 2 seconds
timeout: 2000
# Quit after 60 seconds
retries: 30
- name: "Run Employee Experience Integration Tests"
run: |
./gradlew :domain-ee:ee-ep-merge-app:integrationTest
- name: "Start svc-bip-api and mock-bip-claims-api"
run: |
source scripts/setenv.sh
# Temporary workaround until secret is updated with correct value
export BIP_CLAIM_URL="mock-bip-claims-api:20300"
export -p | sed 's/declare -x //'
./gradlew :app:dockerComposeUp
./gradlew -p mocks docker
./gradlew -p mocks :dockerComposeUp
./gradlew :domain-ee:dockerComposeUp
- name: 'Wait for other containers to start'
run: sleep 60s
shell: bash
- name: 'Check disk space (Post-Build)'
uses: ./.github/actions/check-disk-space
- name: 'Send Merge Request'
uses: indiesdev/[email protected]
id: merge_request
with:
url: 'http://localhost:8140/merge'
method: 'POST'
body: '{"pending_claim_id":1001,"ep400_claim_id":1000}'
accept: 202
retries: 3
log-response: true
- name: 'Get Job ID'
shell: bash
id: get_job_id
run: |
job_id="${{ fromJSON(steps.merge_request.outputs.response).data.job.job_id }}"
echo "job_id=$job_id" >> "$GITHUB_OUTPUT"
# Allow time to finish processing
sleep 5s
- name: 'Get Merge Request Status'
uses: indiesdev/[email protected]
id: merge_status
with:
url: 'http://localhost:8140/merge/${{steps.get_job_id.outputs.job_id}}'
method: 'GET'
accept: 200
retries: 3
log-response: true
- name: 'Verify Merge Complete'
shell: bash
run: |
state="${{ fromJSON(steps.merge_status.outputs.response).data.job.state }}"
if [ "$state" != "COMPLETED_SUCCESS" ]; then
echo "Merge Request completed with error"
echo ${{ steps.merge_status.outputs.response }}
exit 10
fi
- name: 'Clean shutdown of all containers'
if: always()
shell: bash
run: |
docker ps
COMPOSE_PROFILES="all" ./gradlew dockerComposeDown
COMPOSE_PROFILES="all" ./gradlew -p mocks dockerComposeDown