-
Notifications
You must be signed in to change notification settings - Fork 310
481 lines (442 loc) · 17.9 KB
/
ci.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
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
name: Garage CI
env:
GARAGE_GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }}
PR_COMMIT_RANGE: origin/${{ github.base_ref }}...origin/${{ github.head_ref }}
DOCKER_TAG: garage-ci-${{ github.run_id }}
OWNER: "rlworkgroup"
DOCKER_CACHE_REPO: "garage-ci"
MJKEY: ${{ secrets.MJKEY }}
CI_USER: rlworkgroupbot
IS_PR_FROM_FORK: ${{ github.event.client_payload.pull_request.head.repo.fork }}
on:
schedule:
- cron: '0 9 * * *'
push:
branches:
- master
# Triggers on release candidates from master
tags:
- 'v20[2-9][0-9].[0-9][0-9].[0-9]+rc[0-9]'
pull_request:
branches:
- master
repository_dispatch:
types: [ ok-to-test-command ]
jobs:
comment_link_to_output_on_fork_pr:
name: Post link to CI output for fork PRs
runs-on: ubuntu-latest
# can't use env.IS_PR_FROM_FORK here because env is not available here
if: github.event.client_payload.pull_request.head.repo.fork
steps:
- name: Dump the client payload context
env:
PAYLOAD_CONTEXT: ${{ toJson(github.event.client_payload) }}
run: echo "$PAYLOAD_CONTEXT"
- name: Create URL to the run output
id: vars
run: echo ::set-output name=run-url::https://github.com/$GITHUB_REPOSITORY/actions/runs/$GITHUB_RUN_ID
- name: Create comment
uses: peter-evans/create-or-update-comment@v1
with:
token: ${{ secrets.CI_REGISTRY_TOKEN }}
repository: ${{ github.event.client_payload.github.payload.repository.full_name }}
issue-number: ${{ github.event.client_payload.github.payload.issue.number }}
body: |
[Command run output][1] for ${{ github.event.client_payload.pull_request.html_url }}/commits/${{ github.event.client_payload.pull_request.head.sha }}
[1]: ${{ steps.vars.outputs.run-url }}
build_docker_container:
name: Build Docker Container
runs-on: ubuntu-latest
if: ${{ !(github.event.pull_request.head.repo.fork && github.event_name == 'pull_request') }}
steps:
- name: Docker info
run: docker version
- uses: actions/checkout@v2
if: ${{ !env.IS_PR_FROM_FORK }}
with:
fetch-depth: 0
- uses: actions/checkout@v2
if: env.IS_PR_FROM_FORK
with:
ref: ${{ github.event.client_payload.pull_request.merge_commit_sha }}
fetch-depth: 0
- name: Login to GitHub Package Registry
run: echo ${{ secrets.CI_REGISTRY_TOKEN }} | docker login docker.pkg.github.com -u ${CI_USER} --password-stdin
- name: Build Docker container
run: |
DOCKER_BUILDKIT=1 docker build . \
-f docker/Dockerfile \
--target garage-dev \
-t "${DOCKER_TAG}" \
--build-arg GARAGE_GH_TOKEN \
--cache-from="rlworkgroup/garage"
- name: Push to cache (GitHub Package Registry)
run: |
docker tag "${DOCKER_TAG}" "docker.pkg.github.com/${OWNER}/${DOCKER_CACHE_REPO}/${DOCKER_TAG}"
docker push "docker.pkg.github.com/${OWNER}/${DOCKER_CACHE_REPO}/${DOCKER_TAG}"
- name: Update check status for PRs from forks
uses: LouisBrunner/[email protected]
if: always() && env.IS_PR_FROM_FORK
with:
token: ${{ secrets.GITHUB_TOKEN }}
name: Build Docker Container
sha: ${{ github.event.client_payload.pull_request.head.sha }}
conclusion: ${{ job.status }}
check_pre_commit:
name: Check pre-commit
runs-on: ubuntu-latest
needs: build_docker_container
steps:
- name: Login to GitHub Package Registry
if: github.event_name == 'pull_request' || env.IS_PR_FROM_FORK
run: echo ${{ secrets.CI_REGISTRY_TOKEN }} | docker login docker.pkg.github.com -u ${CI_USER} --password-stdin
- name: Pull from cache (GitHub Package Registry)
if: github.event_name == 'pull_request' || env.IS_PR_FROM_FORK
run: docker pull "docker.pkg.github.com/${OWNER}/${DOCKER_CACHE_REPO}/${DOCKER_TAG}"
- name: Tag docker image
if: github.event_name == 'pull_request' || env.IS_PR_FROM_FORK
run: docker tag docker.pkg.github.com/${OWNER}/${DOCKER_CACHE_REPO}/${DOCKER_TAG} ${DOCKER_TAG}
- name: Export commit range for fork PRs
if: env.IS_PR_FROM_FORK
run: |
echo "PR_COMMIT_RANGE=${{ github.event.client_payload.pull_request.base.sha }}...${{ github.event.client_payload.pull_request.head.sha }}" >> $GITHUB_ENV
- name: Check pre-commit
if: github.event_name == 'pull_request' || env.IS_PR_FROM_FORK
run: |
docker run \
-e PR_COMMIT_RANGE \
-e MJKEY \
--memory 6500m \
--memory-swap 6500m \
"${DOCKER_TAG}" scripts/ci/check_precommit.sh
- name: Update check status for PRs from forks
uses: LouisBrunner/[email protected]
if: env.IS_PR_FROM_FORK && always()
with:
token: ${{ secrets.GITHUB_TOKEN }}
name: Check pre-commit
sha: ${{ github.event.client_payload.pull_request.head.sha }}
conclusion: ${{ job.status }}
doctest:
name: Run Doctest
runs-on: ubuntu-latest
needs: check_pre_commit
steps:
- name: Login to GitHub Package Registry
run: echo ${{ secrets.CI_REGISTRY_TOKEN }} | docker login docker.pkg.github.com -u ${CI_USER} --password-stdin
- name: Pull from cache (GitHub Package Registry)
run: docker pull "docker.pkg.github.com/${OWNER}/${DOCKER_CACHE_REPO}/${DOCKER_TAG}"
- name: Tag docker image
run: docker tag docker.pkg.github.com/${OWNER}/${DOCKER_CACHE_REPO}/${DOCKER_TAG} ${DOCKER_TAG}
- name: Doctest
run: |
docker run \
-e MJKEY \
--memory 6500m \
--memory-swap 6500m \
"${DOCKER_TAG}" \
/bin/bash -c \
'pip list && pushd docs && make doctest clean && popd; cat /tmp/*.log'
- name: Update check status for PRs from forks
uses: LouisBrunner/[email protected]
if: env.IS_PR_FROM_FORK && always()
with:
token: ${{ secrets.GITHUB_TOKEN }}
name: Run Doctest
sha: ${{ github.event.client_payload.pull_request.head.sha }}
conclusion: ${{ job.status }}
normal_test:
name: Normal Tests
runs-on: ubuntu-latest
needs: check_pre_commit
steps:
- name: Login to GitHub Package Registry
run: echo ${{ secrets.CI_REGISTRY_TOKEN }} | docker login docker.pkg.github.com -u ${CI_USER} --password-stdin
- name: Pull from cache (GitHub Package Registry)
run: docker pull "docker.pkg.github.com/${OWNER}/${DOCKER_CACHE_REPO}/${DOCKER_TAG}"
- name: Tag docker image
run: docker tag docker.pkg.github.com/${OWNER}/${DOCKER_CACHE_REPO}/${DOCKER_TAG} ${DOCKER_TAG}
- name: Normal tests
run: |
ci_env="$(bash <(curl -s https://codecov.io/env))" &&
docker run \
-e GITHUB_ACTIONS `# used by codecov` \
-e CODECOV_TOKEN \
$ci_env\
--memory 6500m \
--memory-swap 6500m \
"${DOCKER_TAG}" \
/bin/bash -c \
'[ ! -f ${MJKEY_PATH} ] || mv ${MJKEY_PATH} ${MJKEY_PATH}.bak &&
pytest --cov=garage --cov-report=xml --reruns 1 -m \
"not gpu and not nightly and not huge and not flaky and not large and not mujoco and not mujoco_long" --durations=20 &&
for i in {1..5}; do
bash <(curl -s https://codecov.io/bash --retry 5) -Z && break
if [ $i == 5 ]; then
exit 0
else
echo "Retry ${i}..."
sleep 30
fi
done'
- name: Update check status for PRs from forks
uses: LouisBrunner/[email protected]
if: env.IS_PR_FROM_FORK && always()
with:
token: ${{ secrets.GITHUB_TOKEN }}
name: Normal Tests
sha: ${{ github.event.client_payload.pull_request.head.sha }}
conclusion: ${{ job.status }}
large_test:
name: Large Tests
runs-on: ubuntu-latest
needs: check_pre_commit
steps:
- name: Login to GitHub Package Registry
run: echo ${{ secrets.CI_REGISTRY_TOKEN }} | docker login docker.pkg.github.com -u ${CI_USER} --password-stdin
- name: Pull from cache (GitHub Package Registry)
run: docker pull "docker.pkg.github.com/${OWNER}/${DOCKER_CACHE_REPO}/${DOCKER_TAG}"
- name: Tag docker image
run: docker tag docker.pkg.github.com/${OWNER}/${DOCKER_CACHE_REPO}/${DOCKER_TAG} ${DOCKER_TAG}
- name: Large tests
run: |
ci_env="$(bash <(curl -s https://codecov.io/env))" &&
docker run \
-e GITHUB_ACTIONS \
-e CODECOV_TOKEN \
$ci_env\
--memory 6500m \
--memory-swap 6500m \
"${DOCKER_TAG}" \
/bin/bash -c \
'[ ! -f ${MJKEY_PATH} ] || mv ${MJKEY_PATH} ${MJKEY_PATH}.bak &&
pytest --cov=garage --cov-report=xml --reruns 1 -m "large and not flaky" --durations=20 &&
for i in {1..5}; do
bash <(curl -s https://codecov.io/bash --retry 5) -Z && break
if [ $i == 5 ]; then
exit 0
else
echo "Retry ${i}..."
sleep 30
fi
done'
- name: Update check status for PRs from forks
uses: LouisBrunner/[email protected]
if: env.IS_PR_FROM_FORK && always()
with:
token: ${{ secrets.GITHUB_TOKEN }}
name: Large Tests
sha: ${{ github.event.client_payload.pull_request.head.sha }}
conclusion: ${{ job.status }}
mujoco_test:
name: MuJoCo-Based Tests
runs-on: ubuntu-latest
needs: check_pre_commit
steps:
- name: Login to GitHub Package Registry
run: echo ${{ secrets.CI_REGISTRY_TOKEN }} | docker login docker.pkg.github.com -u ${CI_USER} --password-stdin
- name: Pull from cache (GitHub Package Registry)
run: docker pull "docker.pkg.github.com/${OWNER}/${DOCKER_CACHE_REPO}/${DOCKER_TAG}"
- name: Tag docker image
run: docker tag docker.pkg.github.com/${OWNER}/${DOCKER_CACHE_REPO}/${DOCKER_TAG} ${DOCKER_TAG}
- name: MuJoCo tests
run: |
ci_env="$(bash <(curl -s https://codecov.io/env))" &&
docker run \
-e MJKEY \
-e GITHUB_ACTIONS \
-e CODECOV_TOKEN \
$ci_env\
--memory 6500m \
--memory-swap 6500m \
"${DOCKER_TAG}" \
/bin/bash -c \
'pytest --cov=garage --cov-report=xml --reruns 1 -m "mujoco and not flaky" --durations=20 &&
for i in {1..5}; do
bash <(curl -s https://codecov.io/bash --retry 5) -Z && break
if [ $i == 5 ]; then
exit 0
else
echo "Retry ${i}..."
sleep 30
fi
done'
- name: Update check status for PRs from forks
uses: LouisBrunner/[email protected]
if: env.IS_PR_FROM_FORK && always()
with:
token: ${{ secrets.GITHUB_TOKEN }}
name: MuJoCo-Based Tests
sha: ${{ github.event.client_payload.pull_request.head.sha }}
conclusion: ${{ job.status }}
mujoco_test_long:
name: Large MuJoCo-Based Tests
runs-on: ubuntu-latest
needs: check_pre_commit
steps:
- name: Login to GitHub Package Registry
run: echo ${{ secrets.CI_REGISTRY_TOKEN }} | docker login docker.pkg.github.com -u ${CI_USER} --password-stdin
- name: Pull from cache (GitHub Package Registry)
run: docker pull "docker.pkg.github.com/${OWNER}/${DOCKER_CACHE_REPO}/${DOCKER_TAG}"
- name: Tag docker image
run: docker tag docker.pkg.github.com/${OWNER}/${DOCKER_CACHE_REPO}/${DOCKER_TAG} ${DOCKER_TAG}
- name: Large MuJoCo tests
run: |
ci_env="$(bash <(curl -s https://codecov.io/env))" &&
docker run \
-e MJKEY \
-e GITHUB_ACTIONS \
-e CODECOV_TOKEN \
$ci_env\
--memory 6500m \
--memory-swap 6500m \
"${DOCKER_TAG}" \
/bin/bash -c \
'pytest --cov=garage --cov-report=xml --reruns 1 -m "mujoco_long and not flaky" --durations=20 &&
for i in {1..5}; do
bash <(curl -s https://codecov.io/bash --retry 5) -Z && break
if [ $i == 5 ]; then
exit 0
else
echo "Retry ${i}..."
sleep 30
fi
done'
- name: Update check status for PRs from forks
uses: LouisBrunner/[email protected]
if: env.IS_PR_FROM_FORK && always()
with:
token: ${{ secrets.GITHUB_TOKEN }}
name: Large MuJoCo-Based Tests
sha: ${{ github.event.client_payload.pull_request.head.sha }}
conclusion: ${{ job.status }}
nightly_test:
name: Nightly Tests
runs-on: ubuntu-latest
needs: build_docker_container
if: github.event_name == 'schedule'
steps:
- name: Login to GitHub Package Registry
run: echo ${{ secrets.CI_REGISTRY_TOKEN }} | docker login docker.pkg.github.com -u ${CI_USER} --password-stdin
- name: Pull from cache (GitHub Package Registry)
run: docker pull "docker.pkg.github.com/${OWNER}/${DOCKER_CACHE_REPO}/${DOCKER_TAG}"
- name: Tag docker image
run: docker tag docker.pkg.github.com/${OWNER}/${DOCKER_CACHE_REPO}/${DOCKER_TAG} ${DOCKER_TAG}
- name: Nightly tests
run: |
docker run \
-e MJKEY \
--memory 6500m \
--memory-swap 6500m \
"${DOCKER_TAG}" pytest -v --reruns 1 -m nightly
verify_envs_conda:
name: Verify Conda Environment Installation
runs-on: ubuntu-latest
needs: build_docker_container
if: github.event_name == 'schedule'
steps:
- name: Login to GitHub Package Registry
run: echo ${{ secrets.CI_REGISTRY_TOKEN }} | docker login docker.pkg.github.com -u ${CI_USER} --password-stdin
- name: Pull from cache (GitHub Package Registry)
run: docker pull "docker.pkg.github.com/${OWNER}/${DOCKER_CACHE_REPO}/${DOCKER_TAG}"
- name: Tag docker image
run: docker tag docker.pkg.github.com/${OWNER}/${DOCKER_CACHE_REPO}/${DOCKER_TAG} ${DOCKER_TAG}
- name: Verify Conda
run: |
docker run \
-e MJKEY \
--memory 6500m \
--memory-swap 6500m \
"${DOCKER_TAG}" \
/bin/bash -c \
'CONDA_ROOT=$HOME/miniconda \
CONDA=${CONDA_ROOT}/bin/conda \
GARAGE_BIN=${CONDA_ROOT}/envs/garage-ci/bin; \
touch ${MJKEY_PATH} && \
wget https://repo.continuum.io/miniconda/Miniconda3-latest-Linux-x86_64.sh -O miniconda.sh && \
bash miniconda.sh -b -p ${CONDA_ROOT} && \
hash -r && \
${CONDA} config --set always_yes yes --set changeps1 no && \
${CONDA} install -c anaconda setuptools && \
${CONDA} update -q conda && \
${CONDA} init && \
${CONDA} info -a && \
${CONDA} create -n garage-ci python=3.6 pip -y && \
${GARAGE_BIN}/pip install --upgrade pip setuptools && \
${GARAGE_BIN}/pip install dist/garage.tar.gz[all,dev] && \
${GARAGE_BIN}/pylint --disable=all --enable=import-error garage'
verify_envs_pipenv:
name: Verify Pipenv Environment Installation
runs-on: ubuntu-latest
needs: build_docker_container
# For unclear reasons this step takes over six hours on GitHub Actions.
# To enable the CI to run, it is disabled for now.
# if: github.event_name == 'schedule'
if: false
steps:
- uses: actions/checkout@v2
with:
fetch-depth: 0
- name: Login to GitHub Package Registry
run: echo ${{ secrets.CI_REGISTRY_TOKEN }} | docker login docker.pkg.github.com -u ${CI_USER} --password-stdin
- name: Pull from cache (GitHub Package Registry)
run: docker pull "docker.pkg.github.com/${OWNER}/${DOCKER_CACHE_REPO}/${DOCKER_TAG}"
- name: Tag docker image
run: docker tag docker.pkg.github.com/${OWNER}/${DOCKER_CACHE_REPO}/${DOCKER_TAG} ${DOCKER_TAG}
- name: Verify Pipenv
run: |
docker run \
-e MJKEY \
--memory 6500m \
--memory-swap 6500m \
"${DOCKER_TAG}" \
/bin/bash -c \
"export PATH=\$PATH_NO_VENV && \
export VIRTUAL_ENV= && \
export PIPENV_MAX_RETRIES=2 && \
touch \${MJKEY_PATH} && \
pip3 install --upgrade pip setuptools && \
pip3 install pipenv && \
pipenv --python=3.6 && \
pipenv install dist/garage.tar.gz[all,dev] && \
pipenv graph && \
# pylint will verify all imports work
pipenv run pylint --disable=all --enable=import-error garage"
deploy_to_pypi:
name: Deploy to PyPI
runs-on: ubuntu-latest
needs: [normal_test, large_test, mujoco_test, mujoco_test_long, doctest]
if: startsWith(github.ref, 'refs/tags/v')
steps:
- uses: actions/checkout@v2
with:
fetch-depth: 0
- name: Set up Python 3.6
uses: actions/setup-python@v1
with:
python-version: 3.6
- name: Update Version
run: echo ${GITHUB_REF##*/} > VERSION
- name: Setup Distribution
run: >-
python setup.py sdist
- name: Deploy to PyPI
uses: pypa/gh-action-pypi-publish@master
with:
user: __token__
password: ${{ secrets.PYPI_TOKEN }}
delete_docker_container:
name: Delete Docker Container
runs-on: ubuntu-latest
needs: [build_docker_container, normal_test, large_test, mujoco_test, mujoco_test_long, nightly_test, verify_envs_conda, verify_envs_pipenv]
# There's currently no working version of this action available, so disable it and delete packages manually
if: ${{ false && always() && needs.build_docker_container.result == 'success' }}
steps:
- uses: actions/delete-package-versions@v2
with:
owner: ${{ env.OWNER }}
repo: ${{ env.DOCKER_CACHE_REPO }}
package-name: ${{ env.DOCKER_TAG }}
token: ${{ secrets.CI_REGISTRY_TOKEN }}