-
Notifications
You must be signed in to change notification settings - Fork 110
105 lines (104 loc) · 3.42 KB
/
server-32bit.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
on:
push:
jobs:
docker:
# temporarily suppress this job to work around rate limit
if: false
runs-on: buildjet-4vcpu-ubuntu-2204-arm
permissions:
packages: write
steps:
- uses: actions/checkout@v3
- uses: docker/setup-qemu-action@v2
- uses: docker/setup-buildx-action@v2
- uses: docker/login-action@v2
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- uses: docker/build-push-action@v4
with:
file: etc/packaging/32bit/Dockerfile
tags: ghcr.io/viamrobotics/viam-server:armv7
pull: true
push: true
cache-from: type=registry,ref=ghcr.io/viamrobotics/viam-server:buildcache
cache-to: type=registry,ref=ghcr.io/viamrobotics/viam-server:buildcache
lint:
# needs: [docker]
runs-on: buildjet-4vcpu-ubuntu-2204-arm
# concurrency: '32bit-${{ github.ref }}'
permissions:
packages: read
steps:
- uses: docker/login-action@v2
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- uses: actions/checkout@v3
# note: we're linting on 32-bit because atomicalign analyzer only works on 32-bit architecture
- name: lint
run: docker run --rm -v $PWD/:/rdk ghcr.io/viamrobotics/viam-server:armv7 make lint-32bit
test:
# if: false
# needs: [docker]
runs-on: buildjet-4vcpu-ubuntu-2204-arm
# concurrency: '32bit-${{ github.ref }}'
strategy:
fail-fast: false
matrix:
index: ['0', '1', '2', '3', '4']
permissions:
packages: read
steps:
- uses: docker/login-action@v2
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- uses: actions/checkout@v3
- name: test
env:
EXTRA_FLAGS: -tags no_tflite,no_pigpio
GO_TAGS: no_tflite,no_pigpio
CGO_ENABLED: '1'
run: docker run --rm -v $PWD/:/rdk ghcr.io/viamrobotics/viam-server:armv7 sh -c "chown -R `whoami` .git && go version && go list -json $EXTRA_FLAGS ./... | etc/splitter.py ${{ matrix.index }} --nbins 5 --command \"go test $EXTRA_FLAGS\" --fail-empty"
build:
needs: [test]
runs-on: buildjet-4vcpu-ubuntu-2204-arm
permissions:
packages: read
steps:
- uses: docker/login-action@v2
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- uses: actions/checkout@v3
- name: build
run: docker run --rm -v $PWD/:/rdk ghcr.io/viamrobotics/viam-server:armv7 sh -c "git config --global --add safe.directory '*' && go build -v -tags no_pigpio,no_tflite ./web/cmd/server"
- name: show arch
run: file server
- uses: actions/upload-artifact@v3
with:
path: server
upload:
needs: [build]
if: github.ref_name == 'main'
runs-on: ubuntu-latest
steps:
- uses: actions/download-artifact@v3
- name: rename
run: mv artifact/server viam-server-latest-armv7l
- name: Authorize GCP Upload
uses: google-github-actions/auth@v1
with:
credentials_json: '${{ secrets.GCP_CREDENTIALS }}'
- name: upload
uses: google-github-actions/[email protected]
with:
headers: "cache-control: no-cache"
path: viam-server-latest-armv7l
destination: 'packages.viam.com/apps/viam-server/'
parent: false