-
Notifications
You must be signed in to change notification settings - Fork 193
144 lines (139 loc) · 5.52 KB
/
on-push.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
139
140
141
142
143
144
name: Push
on:
# Only build on main branch when pushed (when PR is merged)
push:
branches:
- main
# Only build in PR on creation/update
pull_request:
jobs:
build:
runs-on: ubuntu-22.04
steps:
- uses: actions/checkout@v1
- uses: volta-cli/action@v4
- uses: actions/cache@v2
with:
path: '**/node_modules'
key: ${{ runner.os }}-modules-${{ hashFiles('**/yarn.lock') }}
- run: yarn install --frozen-lockfile
- run: yarn run lint
- run: yarn run build:release
unit-test:
runs-on: ubuntu-22.04
steps:
- uses: actions/checkout@v1
- uses: volta-cli/action@v4
- uses: actions/cache@v2
with:
path: '**/node_modules'
key: ${{ runner.os }}-modules-${{ hashFiles('**/yarn.lock') }}
- run: yarn install --frozen-lockfile
- run: yarn run playwright install
- name: create .env file
run: |
echo "${{ secrets.E2E_GITHUB_PRIVATE_KEY }}" > jira-test.pem
echo "APP_URL=http://localhost" > .env
echo "WEBHOOK_PROXY_URL=http://localhost" >> .env
echo "APP_KEY=com.github.integration.fusion-test" >> .env
echo "NODE_ENV=test" >> .env
echo "APP_NAME=jira" >> .env
echo "APP_ID=${{ secrets.E2E_GITHUB_APP_ID }}" >> .env
echo "WEBHOOK_SECRETS=${{ secrets.E2E_GITHUB_WEBHOOK_SECRETS }}" >> .env
echo "COOKIE_SESSION_KEY=${{ secrets.E2E_COOKIE_SESSION_KEY }}" >> .env
echo "GITHUB_CLIENT_ID=${{ secrets.E2E_GITHUB_CLIENT_ID }}" >> .env
echo "GITHUB_CLIENT_SECRET=${{ secrets.E2E_GITHUB_CLIENT_SECRET }}" >> .env
echo "PRIVATE_KEY_PATH=jira-test.pem" >> .env
echo "ATLASSIAN_URL=${{ secrets.E2E_ATLASSIAN_URL }}" >> .env
- run: docker-compose up -d app
- name: wait for app to be ready
run: curl --head -X GET -f --retry 30 --retry-all-errors --retry-delay 5 http://localhost:8080/healthcheck
- run: yarn run db:test
- name: Run tests
env:
REDISX_CACHE_HOST: localhost
REDISX_CACHE_PORT: 6379
DATABASE_URL: postgres://postgres:postgres@localhost:5432/jira-test
AWS_DEFAULT_REGION: us-west-1
AWS_ACCESS_KEY_ID: localkey
AWS_SECRET_ACCESS_KEY: localsecret
AWS_EC2_METADATA_DISABLED: true
NODE_OPTIONS: "--max_old_space_size=4096"
run: yarn test
- uses: actions/upload-artifact@v3
if: always()
with:
name: test-coverage
retention-days: 14
path: |
coverage/
e2e-test:
runs-on: ubuntu-22.04
timeout-minutes: 60
# This will prevent multiple e2e tests from running concurrently, only one at a time to prevent collisions
concurrency: e2e
steps:
- uses: actions/checkout@v1
- uses: volta-cli/action@v4
- uses: docker-practice/actions-setup-docker@master
- uses: actions/cache@v2
with:
path: '**/node_modules'
key: ${{ runner.os }}-modules-${{ hashFiles('**/yarn.lock') }}
- run: yarn install --frozen-lockfile
- run: yarn spa:build
- name: create .env file
run: |
echo "${{ secrets.E2E_GITHUB_PRIVATE_KEY }}" > jira-e2e-test.pem
echo "APP_URL=http://localhost" > .env
echo "WEBHOOK_PROXY_URL=http://localhost" >> .env
echo "NGROK_AUTHTOKEN=${{ secrets.E2E_NGROK_AUTHTOKEN }}" >> .env
echo "APP_KEY=com.github.integration.fusion-arc-e2e" >> .env
echo "NODE_ENV=e2e" >> .env
echo "APP_NAME=jira-e2e" >> .env
echo "APP_ID=${{ secrets.E2E_GITHUB_APP_ID }}" >> .env
echo "WEBHOOK_SECRETS=${{ secrets.E2E_GITHUB_WEBHOOK_SECRETS }}" >> .env
echo "COOKIE_SESSION_KEY=${{ secrets.E2E_COOKIE_SESSION_KEY }}" >> .env
echo "GITHUB_CLIENT_ID=${{ secrets.E2E_GITHUB_CLIENT_ID }}" >> .env
echo "GITHUB_CLIENT_SECRET=${{ secrets.E2E_GITHUB_CLIENT_SECRET }}" >> .env
echo "PRIVATE_KEY_PATH=jira-e2e-test.pem" >> .env
echo "ATLASSIAN_URL=${{ secrets.E2E_ATLASSIAN_URL }}" >> .env
echo "JIRA_ADMIN_USERNAME=${{ secrets.E2E_JIRA_USERNAME }}" >> .env
echo "JIRA_ADMIN_PASSWORD=${{ secrets.E2E_JIRA_PASSWORD }}" >> .env
echo "GITHUB_USERNAME=${{ secrets.E2E_GITHUB_USERNAME }}" >> .env
echo "GITHUB_PASSWORD=${{ secrets.E2E_GITHUB_PASSWORD }}" >> .env
echo "GITHUB_URL=https://github.com" >> .env
echo "LOG_LEVEL=debug" >> .env
- run: COMPOSE_PROFILES=e2e docker-compose up -d
- name: wait for app to be ready
run: curl --head -X GET -f --retry 30 --retry-all-errors --retry-delay 5 http://localhost:8080/healthcheck
- run: yarn run test:e2e
- name: export system logs
if: always()
run: |
free -h > memory.log
top -c -b -n 1 > processes.log
cat /var/log/syslog > sys.log
journalctl -k > journal.log
- name: export docker logs
if: always()
run: |
docker ps -a > docker-ps.log
docker stats --no-stream > docker-stats.log
docker-compose logs --no-color > docker-compose.log
- uses: actions/upload-artifact@v3
if: always()
with:
name: e2e-output
retention-days: 14
path: |
test/e2e/test-results/
*.log
docker:
runs-on: ubuntu-22.04
steps:
- uses: actions/checkout@v1
- name: Build Docker image
uses: docker/[email protected]
with:
file: Dockerfile