-
Notifications
You must be signed in to change notification settings - Fork 16
92 lines (76 loc) · 2.72 KB
/
build-docker.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
# For more information see: https://help.github.com/actions/language-and-framework-guides/using-nodejs-with-github-actions
name: build-docker
on:
workflow_dispatch:
inputs:
dry-run:
type: boolean
description: 'Dry run, do not push containers to the registry.'
required: true
default: false
defaults:
run:
shell: bash
concurrency:
group: ${{ github.ref_name }}.${{ github.sha }}.build-docker
cancel-in-progress: true
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: Print inputs
run: |
echo "Dry run: ${{ github.event.inputs.dry-run }}"
- name: Checkout sources
uses: actions/checkout@v4
- name: Setup environment
uses: ./.github/actions/setup-environment
with:
compodoc: true
cypress: true
- name: Unit test all
run: |
npx nx run-many --target test --all --pass-with-no-tests --code-coverage --run-in-band --ci
npx nx run tools:coverage-stats
cat ./UNIT_COVERAGE.md
- name: Build all (production)
run: |
SKIP_FORMAT="true" yarn generate:env:documentation
npx nx run-many --target configure-env --all
npx nx run-many --target build --all --configuration production
npx nx run-many --target configure-env --all --reset
- name: Build documentation (compodoc, unit coverage, e2e coverage)
run: |
yarn test:reports
npx nx run tools:compodoc-build
yarn generate:changelog
yarn e2e:report || exit 1
- name: Check repository owner
id: check-origin
uses: ./.github/actions/check-origin
- name: Docker login
if: ${{ steps.check-origin.outputs.origin == 'true' }}
run: yarn docker:login "$DOCKER_REGISTRY_USER" "$DOCKER_REGISTRY_ACCESS_TOKEN"
env:
DOCKER_REGISTRY_USER: ${{ secrets.DOCKER_REGISTRY_USER }}
DOCKER_REGISTRY_ACCESS_TOKEN: ${{ secrets.DOCKER_REGISTRY_ACCESS_TOKEN }}
- name: Docker build apps
run: |
yarn docker:build base
yarn docker:build api production
yarn docker:build client production
yarn docker:build elements production
yarn docker:build documentation
- name: Docker push apps
if: ${{ github.event.inputs.dry-run == false && steps.check-origin.outputs.origin == 'true' }}
run: |
yarn docker:push base
yarn docker:push api-production
yarn docker:push client-production
yarn docker:push elements-production
yarn docker:push documentation
- name: Docker cleanup
if: always()
run: |
yarn docker:cleanup
docker logout