-
Notifications
You must be signed in to change notification settings - Fork 0
90 lines (75 loc) · 2.88 KB
/
test-build.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
name: Test && Build && Push
# Controls when the action will run. Triggers the workflow on push or pull request
# events but only for the develop and master branches
on:
pull_request:
branches: [develop, master]
# A workflow run is made up of one or more jobs that can run sequentially or in parallel
jobs:
test:
# The type of runner that the job will run on
runs-on: ubuntu-latest
strategy:
matrix:
node-version: [18.x]
# Steps represent a sequence of tasks that will be executed as part of the job
steps:
# Checks-out your repository under $GITHUB_WORKSPACE, so your job can access it
- uses: actions/checkout@v3
- name: Use Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v3
with:
node-version: ${{ matrix.node-version }}
- name: Cache node_modules
uses: actions/cache@v3
env:
cache-name: ${{ matrix.node-version }}-cache-node-modules
with:
path: ~/.npm
key: ${{ runner.os }}-${{ env.cache-name }}-${{ hashFiles('package-lock.json') }}
restore-keys: |
${{ runner.os }}-${{ env.cache-name }}-
- run: npm ci --loglevel error --no-fund
- run: npm run build
- run: npm test
build:
runs-on: ubuntu-latest
needs: test
steps:
# Checks-out your repository under $GITHUB_WORKSPACE, so your job can access it
- uses: actions/checkout@v3
- name: Set up QEMU
uses: docker/setup-qemu-action@v2
with:
platforms: amd64,arm64
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2
- name: Cache app docker layers
uses: actions/cache@v3
with:
path: /tmp/.buildx-layer-cache
key: ${{ runner.os }}-buildx-${{ github.head_ref }}-${{ github.sha }}
restore-keys: |
${{ runner.os }}-buildx-${{ github.head_ref }}-
${{ runner.os }}-buildx-
- name: Login to GitHub Container Registry
# Don't login if dependabot is creating the PR
if: ${{ !startsWith(github.head_ref, 'dependabot') }}
uses: docker/login-action@v2
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
# For debugging capture the selected branch
- name: Extracted branch
run: echo "Extracted branch ${{ github.head_ref }}"
- name: Build and push
uses: docker/build-push-action@v4
with:
# Don't push if dependabot is creating the PR
push: ${{ !startsWith(github.head_ref, 'dependabot') }}
platforms: linux/amd64,linux/arm64/v8
tags: ghcr.io/userofficeproject/user-office-factory:${{ github.head_ref }}
cache-from: |
type=gha,scope=${{ github.workflow }}:linux/amd64
type=gha,scope=${{ github.workflow }}:linux/arm64/v8